关于坐标的最后一个有关问题了
关于坐标的最后一个问题了
就是用CDC* pdc变量调用textout,可以改变字体属性,现在问题又来了,就是在一个区域他重新绘制,上次绘制的字体会被当前绘制的字体覆盖掉,如果上次的字体大于当前的字体,就覆盖不到,就会出错,我试着重绘是把setbkcolor设置成背景色,但是还是达不到我要的效果,我应该用什么方法?
------解决方案--------------------
先用原字体绘空格串" ",再用新字体绘字串
------解决方案--------------------
用双缓冲 在内存中画好了 在贴上去就没事了
------解决方案--------------------
在MFC中有个系统自带的事件句柄,你添加ctlcolor句柄,在那里面可以选择你要显示的控件。
------解决方案--------------------
在MFC中有个自带的系统的事件句柄,你在那里面添加个ctlcolor句柄,在那里你可以选择你想显示的控件。
------解决方案--------------------
有内存绘图部分请叁考
// DrawTest.cpp : implementation file
//
#include "stdafx.h"
#include "DlgDraw.h"
#include "DrawTest.h"
#include <time.h>
#include <math.h>
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CDrawTest dialog
CDrawTest::CDrawTest(CWnd* pParent /*=NULL*/)
: CDialog(CDrawTest::IDD, pParent)
{
//{{AFX_DATA_INIT(CDrawTest)
// NOTE: the ClassWizard will add member initialization here
//}}AFX_DATA_INIT
}
void CDrawTest::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDrawTest)
// NOTE: the ClassWizard will add DDX and DDV calls here
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CDrawTest, CDialog)
//{{AFX_MSG_MAP(CDrawTest)
ON_WM_PAINT()
ON_WM_TIMER()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CDrawTest message handlers
BOOL CDrawTest::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
m_Low = 0;
m_High = 1024;
m_now =0;
SetTimer(1,100,NULL);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CDrawTest::OnPaint()
{
CPaintDC dc(this); // device context for painting
// TODO: Add your message handler code here
// Do not call CDialog::OnPaint() for painting messages
}
void CDrawTest::DrawWave(CDC *pDC)
{
CRect rect;
CString str;
int i;
int m_left,m_top,m_right,m_bottom;
int m_Interval = (m_High - m_Low)/10;
if (m_Interval < 1) m_Interval = 1;
// 获取绘制坐标的文本框
CWnd* pWnd = GetDlgItem(IDC_COORD);
pWnd->GetClientRect(&rect);
pDC->Rectangle(&rect);
m_left = rect.left+10;
m_top = rect.top+10;
m_right = rect.right-10;
m_bottom = rect.bottom-20;
int m_IntervalPan = (m_right - m_left)/11;
if (m_IntervalPan < 1 ) m_IntervalPan =1;
// 创建画笔对象
CPen* pPenRed = new CPen;
// 红色画笔
pPenRed->CreatePen(PS_SOLID,1,RGB(255,0,0));
// 创建画笔对象
CPen* pPenBlue = new CPen;
// 蓝色画笔
pPenBlue->CreatePen(PS_SOLID,1,RGB(0,0, 255));
// 创建画笔对象
CPen* pPenGreen = new CPen;
// 绿色画笔
pPenGreen->CreatePen(PS_DOT,1,RGB(0,255,0));
// 选中当前红色画笔,并保存以前的画笔
CGdiObject* pOldPen = pDC->SelectObject(pPenRed);
// 绘制坐标轴
pDC->MoveTo(m_left,m_top);
// 垂直轴
pDC->LineTo(m_left,m_bottom);
// 水平轴
pDC->LineTo(m_right,m_bottom);
// 写X轴刻度值
for(i=0;i<10;i++)
{
就是用CDC* pdc变量调用textout,可以改变字体属性,现在问题又来了,就是在一个区域他重新绘制,上次绘制的字体会被当前绘制的字体覆盖掉,如果上次的字体大于当前的字体,就覆盖不到,就会出错,我试着重绘是把setbkcolor设置成背景色,但是还是达不到我要的效果,我应该用什么方法?
------解决方案--------------------
先用原字体绘空格串" ",再用新字体绘字串
------解决方案--------------------
用双缓冲 在内存中画好了 在贴上去就没事了
------解决方案--------------------
在MFC中有个系统自带的事件句柄,你添加ctlcolor句柄,在那里面可以选择你要显示的控件。
------解决方案--------------------
在MFC中有个自带的系统的事件句柄,你在那里面添加个ctlcolor句柄,在那里你可以选择你想显示的控件。
------解决方案--------------------
有内存绘图部分请叁考
// DrawTest.cpp : implementation file
//
#include "stdafx.h"
#include "DlgDraw.h"
#include "DrawTest.h"
#include <time.h>
#include <math.h>
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CDrawTest dialog
CDrawTest::CDrawTest(CWnd* pParent /*=NULL*/)
: CDialog(CDrawTest::IDD, pParent)
{
//{{AFX_DATA_INIT(CDrawTest)
// NOTE: the ClassWizard will add member initialization here
//}}AFX_DATA_INIT
}
void CDrawTest::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDrawTest)
// NOTE: the ClassWizard will add DDX and DDV calls here
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CDrawTest, CDialog)
//{{AFX_MSG_MAP(CDrawTest)
ON_WM_PAINT()
ON_WM_TIMER()
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CDrawTest message handlers
BOOL CDrawTest::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
m_Low = 0;
m_High = 1024;
m_now =0;
SetTimer(1,100,NULL);
return TRUE; // return TRUE unless you set the focus to a control
// EXCEPTION: OCX Property Pages should return FALSE
}
void CDrawTest::OnPaint()
{
CPaintDC dc(this); // device context for painting
// TODO: Add your message handler code here
// Do not call CDialog::OnPaint() for painting messages
}
void CDrawTest::DrawWave(CDC *pDC)
{
CRect rect;
CString str;
int i;
int m_left,m_top,m_right,m_bottom;
int m_Interval = (m_High - m_Low)/10;
if (m_Interval < 1) m_Interval = 1;
// 获取绘制坐标的文本框
CWnd* pWnd = GetDlgItem(IDC_COORD);
pWnd->GetClientRect(&rect);
pDC->Rectangle(&rect);
m_left = rect.left+10;
m_top = rect.top+10;
m_right = rect.right-10;
m_bottom = rect.bottom-20;
int m_IntervalPan = (m_right - m_left)/11;
if (m_IntervalPan < 1 ) m_IntervalPan =1;
// 创建画笔对象
CPen* pPenRed = new CPen;
// 红色画笔
pPenRed->CreatePen(PS_SOLID,1,RGB(255,0,0));
// 创建画笔对象
CPen* pPenBlue = new CPen;
// 蓝色画笔
pPenBlue->CreatePen(PS_SOLID,1,RGB(0,0, 255));
// 创建画笔对象
CPen* pPenGreen = new CPen;
// 绿色画笔
pPenGreen->CreatePen(PS_DOT,1,RGB(0,255,0));
// 选中当前红色画笔,并保存以前的画笔
CGdiObject* pOldPen = pDC->SelectObject(pPenRed);
// 绘制坐标轴
pDC->MoveTo(m_left,m_top);
// 垂直轴
pDC->LineTo(m_left,m_bottom);
// 水平轴
pDC->LineTo(m_right,m_bottom);
// 写X轴刻度值
for(i=0;i<10;i++)
{