GNU plot을 사용하기 + 실시간 plot해보기
아래 링크를 들어가면 다 있다.
그누플랏1: http://blog.daum.net/pg365/28
그누플랏2: http://blog.daum.net/pg365/28
실시간 플랏: http://blog.daum.net/pg365/28
코드:
// hdp_mfcDlg.cpp : 구현 파일
//
#include "stdafx.h"
#include "hdp_mfc.h"
#include "hdp_mfcDlg.h"
#include "afxdialogex.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// 응용 프로그램 정보에 사용되는 CAboutDlg 대화 상자입니다.
class CAboutDlg : public CDialogEx
{
public:
CAboutDlg();
// 대화 상자 데이터입니다.
enum { IDD = IDD_ABOUTBOX };
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 지원입니다.
// 구현입니다.
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()
// Chdp_mfcDlg 대화 상자
Chdp_mfcDlg::Chdp_mfcDlg(CWnd* pParent /*=NULL*/)
: CDialogEx(Chdp_mfcDlg::IDD, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void Chdp_mfcDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(Chdp_mfcDlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_WM_TIMER()
ON_WM_DESTROY()
ON_BN_CLICKED(IDOK, &Chdp_mfcDlg::OnBnClickedOk)
ON_BN_CLICKED(IDCANCEL, &Chdp_mfcDlg::OnBnClickedCancel)
ON_BN_CLICKED(IDC_BUTTON_PLOT, &Chdp_mfcDlg::OnBnClickedButtonPlot)
END_MESSAGE_MAP()
// Chdp_mfcDlg 메시지 처리기
BOOL Chdp_mfcDlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
// 시스템 메뉴에 "정보..." 메뉴 항목을 추가합니다.
// IDM_ABOUTBOX는 시스템 명령 범위에 있어야 합니다.
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
BOOL bNameValid;
CString strAboutMenu;
bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
ASSERT(bNameValid);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
// 이 대화 상자의 아이콘을 설정합니다. 응용 프로그램의 주 창이 대화 상자가 아닐 경우에는
// 프레임워크가 이 작업을 자동으로 수행합니다.
SetIcon(m_hIcon, TRUE); // 큰 아이콘을 설정합니다.
SetIcon(m_hIcon, FALSE); // 작은 아이콘을 설정합니다.
// TODO: 여기에 추가 초기화 작업을 추가합니다.
CRect rtGraph;
GetDlgItem(IDC_STATIC_RT_GRAPH)->GetWindowRect(rtGraph);
ScreenToClient(rtGraph);
// 오실로스코프 컨트롤을 생성하고 설정한다.
// 1. cos,sin,tan 3개의 그래프 예약
_rtGraph = new COScopeCtrl(3);
_rtGraph->Create(WS_VISIBLE | WS_CHILD, rtGraph, this, IDC_STATIC_RT_GRAPH);
// 2. Y축의 범위를 정한다.
_rtGraph->SetRanges(-1., 1.);
// 3. 오토 스케일링도 해준다. (잘 동작 안하는듯)
_rtGraph->autofitYscale = true;
// 4. X축과 Y축의 라벨을 정한다.
_rtGraph->SetYUnits(_T("Value"));
_rtGraph->SetXUnits(_T("Time"));
// 5. 각 데이터의 legend를 정한다. (0부터 시작한다.)
_rtGraph->SetLegendLabel(_T("cos(t)"), 0);
_rtGraph->SetLegendLabel(_T("sin(t)"), 1);
_rtGraph->SetLegendLabel(_T("-sins(t)"), 2);
// 6. 각 데이터의 색을 정한다.
_rtGraph->SetPlotColor(RGB(255, 0, 0), 0);
_rtGraph->SetPlotColor(RGB(0, 255, 0), 1);
_rtGraph->SetPlotColor(RGB(0, 0, 255), 2);
// 7. Y축 크기의 스케일링을 한다.
_rtGraph->SetTrendRatio(0, 1);
_rtGraph->SetTrendRatio(1, 1);
_rtGraph->SetTrendRatio(2, 1);
_rtGraph->InvalidateCtrl();
// 오실로스코프 컨트롤을 그리기 위한 타이머 이벤트 활성화
SetTimer(1000, 10, NULL);
return TRUE; // 포커스를 컨트롤에 설정하지 않으면 TRUE를 반환합니다.
}
void Chdp_mfcDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
}
// 대화 상자에 최소화 단추를 추가할 경우 아이콘을 그리려면
// 아래 코드가 필요합니다. 문서/뷰 모델을 사용하는 MFC 응용 프로그램의 경우에는
// 프레임워크에서 이 작업을 자동으로 수행합니다.
void Chdp_mfcDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 그리기를 위한 디바이스 컨텍스트입니다.
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 클라이언트 사각형에서 아이콘을 가운데에 맞춥니다.
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 아이콘을 그립니다.
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialogEx::OnPaint();
}
}
// 사용자가 최소화된 창을 끄는 동안에 커서가 표시되도록 시스템에서
// 이 함수를 호출합니다.
HCURSOR Chdp_mfcDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void Chdp_mfcDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
if (nIDEvent == 1000) {
double t = (double)GetTickCount() / 1000.;
double value[3] = { cos(t), sin(t), -sin(t) };
_rtGraph->AppendPoints(value);
}
CDialog::OnTimer(nIDEvent);
CDialogEx::OnTimer(nIDEvent);
}
void Chdp_mfcDlg::OnDestroy()
{
CDialogEx::OnDestroy();
// TODO: 여기에 메시지 처리기 코드를 추가합니다.
// 오실로스코프 컨트롤 삭제
delete _rtGraph;
}
void Chdp_mfcDlg::OnBnClickedOk()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CDialogEx::OnOK();
}
void Chdp_mfcDlg::OnBnClickedCancel()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CDialogEx::OnCancel();
}
void Chdp_mfcDlg::OnBnClickedButtonPlot()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
m_pPlot1 = new CStaticGNUPlot();
RECT rc2 = { 300, 20, 600, 500 };
m_pPlot1->Create(_T(""), WS_CHILD, rc2, this, 3333);
m_pPlot1->ShowWindow(SW_SHOW);
FILE *fp = fopen("temp.txt", "wt");
if (fp) {
for (double i = 0; i<20.; i += 0.01) {
fprintf(fp, "%f, %f\n", i, sin(i));
}
fclose(fp);
}
m_pPlot1->init("C:\\Program Files\\gnuplot\\bin\\wgnuplot.exe");
//m_pPlot1->cmd("plot x**2");
m_pPlot1->cmd("plot 'temp.txt' with lines");
}
파일
'Enginius > C / C++' 카테고리의 다른 글
[MFC] Radio Button, Edit Box, Check Box, CString2char* (0) | 2014.11.25 |
---|---|
[MFC] gsl 사용하기 (0) | 2014.11.24 |
[Visual Studio] OpenCV 설치하고 프로젝트 설치하기 (0) | 2014.08.14 |
[MFC] 그림을 그릴 수 있는 기본적인 프로젝트 (2) | 2014.08.06 |
[윈도우 C++ 예제] 소켓 통신으로 구조체를 보내기 (1) | 2014.07.31 |