testmatcom_mfcview.cpp
来自「《精通matlab与c++混合编程》的光盘内容」· C++ 代码 · 共 381 行
CPP
381 行
// testmatcom_mfcView.cpp : implementation of the CTestmatcom_mfcView class
//
#include "stdafx.h"
#include "testmatcom_mfc.h"
#include "testmatcom_mfcDoc.h"
#include "testmatcom_mfcView.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CTestmatcom_mfcView
IMPLEMENT_DYNCREATE(CTestmatcom_mfcView, CView)
BEGIN_MESSAGE_MAP(CTestmatcom_mfcView, CView)
//{{AFX_MSG_MAP(CTestmatcom_mfcView)
ON_WM_SIZE()
ON_COMMAND(ID_DRAWNOISE, OnDrawnoise)
ON_WM_TIMER()
ON_COMMAND(ID_SINGRAPH, OnSingraph)
ON_COMMAND(ID_SCOPE1, OnScope1)
ON_COMMAND(ID_SCOPE, OnScope)
//}}AFX_MSG_MAP
// Standard printing commands
ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CTestmatcom_mfcView construction/destruction
CTestmatcom_mfcView::CTestmatcom_mfcView()
{
// TODO: add construction code here
isInitMatcom=0;
m_hFlag=0;
m_scopeflag = 0;
m_nScopeTimerID =0;
m_scopeflag1=0;
}
CTestmatcom_mfcView::~CTestmatcom_mfcView()
{
if(isInitMatcom)
{
exitM();
isInitMatcom=0;
}
}
BOOL CTestmatcom_mfcView::PreCreateWindow(CREATESTRUCT& cs)
{
// TODO: Modify the Window class or styles here by modifying
// the CREATESTRUCT cs
return CView::PreCreateWindow(cs);
}
/////////////////////////////////////////////////////////////////////////////
// CTestmatcom_mfcView drawing
void CTestmatcom_mfcView::OnDraw(CDC* pDC)
{
CTestmatcom_mfcDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
// TODO: add draw code for native data here
}
/////////////////////////////////////////////////////////////////////////////
// CTestmatcom_mfcView printing
BOOL CTestmatcom_mfcView::OnPreparePrinting(CPrintInfo* pInfo)
{
// default preparation
return DoPreparePrinting(pInfo);
}
void CTestmatcom_mfcView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: add extra initialization before printing
}
void CTestmatcom_mfcView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
// TODO: add cleanup after printing
}
/////////////////////////////////////////////////////////////////////////////
// CTestmatcom_mfcView diagnostics
#ifdef _DEBUG
void CTestmatcom_mfcView::AssertValid() const
{
CView::AssertValid();
}
void CTestmatcom_mfcView::Dump(CDumpContext& dc) const
{
CView::Dump(dc);
}
CTestmatcom_mfcDoc* CTestmatcom_mfcView::GetDocument() // non-debug version is inline
{
ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTestmatcom_mfcDoc)));
return (CTestmatcom_mfcDoc*)m_pDocument;
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CTestmatcom_mfcView message handlers
void CTestmatcom_mfcView::OnInitialUpdate()
{
CView::OnInitialUpdate();
// TODO: Add your specialized code here and/or call the base class
if(!isInitMatcom)
{
initM(MATCOM_VERSION);
isInitMatcom=1;
m_h = winaxes(m_hWnd);
this->m_hFlag=1;
axesposition(10,10,100,100);
double bounddata[4]={0,2*3.1415926,-1,1};
Mm mbound;
M_VECTOR(mbound,bounddata);
axis(mbound);
//axis
title((CL(TM("SIN函数图形"))));
xlabel((CL(TM("x"))));
ylabel((CL(TM("y"))));
set(m_h,(CL(TM("Color")),TM("black")));
set(m_h,(CL(TM("Box")),TM("on")));
//axis(mbound);
Mm x,y;
x=linspace(0,2*pi,100);
y=msin(x);
m_data = y;
m_hline=plot((CL(x),m_data,TM("y")));
m_h1 = winaxes(m_hWnd);
Mm pos;
pos=(BR(240),240,200,200);
set(m_h1,TM("RealPosition"),pos);
Mm color;
color = zeros(1,3);
color.r(1)=0;color.r(2)=0;color.r(3)=0;
set(m_h,TM("color"),color);
m_data1 = randn(1,150);
m_hline1=plot((CL(m_data1),TM("b")));
set(m_hline1,TM("Xdata"),linspace(1,150,150));
set(m_hline1,TM("Ydata"),m_data1);
drawnow();
double * phandle=NULL;
phandle = m_h1.addr();
int nrow,ncol;
nrow = m_h1.rows();
ncol = m_h1.cols();
title(CL(TM("当前的图形")));
}
}
void CTestmatcom_mfcView::OnSize(UINT nType, int cx, int cy)
{
CView::OnSize(nType, cx, cy);
// TODO: Add your message handler code here
//figure(CL(1));
if(this->m_hFlag>0)
{
//axes(m_h);
if(IsMatcomHanleValid(m_h))
{
Mm pos;
pos = zeros(1,4);
pos.r(1)=0;pos.r(2)=0;
pos.r(3)=cx;pos.r(4)=cy/2;
set(m_h,TM("RealPosition"),pos);
}
if(IsMatcomHanleValid(m_h1))
{
Mm pos;
pos = zeros(1,4);
pos.r(1)=0;pos.r(2)=cy/2;
pos.r(3)=cx;pos.r(4)=cy/2;
set(m_h1,TM("RealPosition"),pos);
}
//axesposition(0,0,cx,cy);
}
}
void CTestmatcom_mfcView::OnDrawnoise()
{
// TODO: Add your command handler code here
if(this->isInitMatcom)
{
m_data = randn(1,200);
if(IsMatcomHanleValid(m_h))
{
set(m_hline,TM("Xdata"),linspace(1,200,200));
set(m_hline,TM("Ydata"),m_data);
drawnow();
}
}
}
bool CTestmatcom_mfcView::IsMatcomHanleValid(Mm handle)
{
if(this->isInitMatcom)
{
Mm len,isH;
isH = ishandle(handle);
len = length(isH);
if(((int)(len.r(1)))&&((int)(isH.r(1))))
{
return true;
}
else
{
return false;
}
}
else
{
return false;
}
}
void CTestmatcom_mfcView::OnTimer(UINT nIDEvent)
{
// TODO: Add your message handler code here and/or call default
if(this->isInitMatcom)
{
if(IsMatcomHanleValid(m_h))
{
if(this->m_scopeflag1)
{
Mm ydata,tmp;
ydata = get(m_hline1,TM("Ydata"));
int nydatalen;
nydatalen = ydata.rows()*ydata.cols();
for(int i=1;i<nydatalen;i++)
{
ydata.r(i)=ydata.r(i+1);
}
tmp = randM(1,1);
ydata.r(nydatalen) = tmp.r(1);
set(m_hline1,TM("Ydata"),ydata);
drawnow();
}
if(this->m_scopeflag)
{
Mm ydata;
ydata = get(m_hline,TM("Ydata"));
int nydatalen;
double lastYdata;
nydatalen = ydata.rows()*ydata.cols();
lastYdata = ydata.r(nydatalen);
for(int i=nydatalen;i>=2;i--)
{
ydata.r(i)=ydata.r(i-1);
}
ydata.r(1) = lastYdata;
set(m_hline,TM("Ydata"),ydata);
drawnow();
}
}
}
CView::OnTimer(nIDEvent);
}
/*将第一个切换为绘制移动的正弦曲线*/
void CTestmatcom_mfcView::OnSingraph()
{
// TODO: Add your command handler code here
if(this->isInitMatcom)
{
if(IsMatcomHanleValid(m_h))
{
Mm x,y;
x=linspace(0,2*pi,100);
y=msin(x);
set(m_hline,TM("Xdata"),x);
set(m_hline,TM("Ydata"),y);
drawnow();
}
}
}
/*第二个实时曲线绘制窗口的启动和暂停函数*/
void CTestmatcom_mfcView::OnScope1()
{
// TODO: Add your command handler code here
if(this->isInitMatcom)
{
if(IsMatcomHanleValid(m_h1))
{
if(m_scopeflag1==0)
{
Mm ydata,tmp;
ydata = get(m_hline1,TM("Ydata"));
int nydatalen;
nydatalen = ydata.rows()*ydata.cols();
for(int i=1;i<nydatalen;i++)
{
ydata.r(i)=ydata.r(i+1);
}
tmp = randM(1,1);
ydata.r(nydatalen) = tmp.r(1);
set(m_hline1,TM("Ydata"),ydata);
drawnow();
if(m_nScopeTimerID<=0)
{
m_nScopeTimerID = SetTimer(1,50,NULL);
}
m_scopeflag1 = 1;
}
else
{
m_scopeflag1 =0 ;
}
}
}
}
/*第一个实时曲线绘制窗口的启动和暂停函数*/
void CTestmatcom_mfcView::OnScope()
{
// TODO: Add your command handler code here
if(this->isInitMatcom)
{
if(IsMatcomHanleValid(m_h))
{
if(m_scopeflag==0)
{
Mm ydata;
ydata = get(m_hline,TM("Ydata"));
int nydatalen;
double lastYdata;
nydatalen = ydata.rows()*ydata.cols();
lastYdata = ydata.r(nydatalen);
for(int i=nydatalen;i>=2;i--)
{
ydata.r(i)=ydata.r(i-1);
}
ydata.r(1) = lastYdata;
set(m_hline,TM("Ydata"),ydata);
drawnow();
if(m_nScopeTimerID<=0)
{
m_nScopeTimerID = SetTimer(1,10,NULL);
}
m_scopeflag = 1;
}
else
{
m_scopeflag =0 ;
}
}
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?