⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 点阵控制dlg.cpp

📁 结合液晶显示系统
💻 CPP
字号:
// 点阵控制Dlg.cpp : implementation file
//

#include "stdafx.h"
#include "点阵控制.h"
#include "点阵控制Dlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif


//点的宽度
#define   POINTER_WIDTH     16
//点的高度
#define   POINTER_HEIGHT    16

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About
class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyDlg dialog

CMyDlg::CMyDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CMyDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CMyDlg)
	m_strRXData = _T("");
	m_strTXData = _T("");
	m_setport = 0;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);

}

void CMyDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CMyDlg)
	DDX_Control(pDX, IDC_CHECK_HEXDISPLAY, m_ctrlHexDiaplay);
	DDX_Control(pDX, IDC_CHECK_HEXSEND, m_ctrlHexSend);
	DDX_Control(pDX, IDC_MSCOMM_NEW, m_ctrlComm);
	DDX_Text(pDX, IDC_EDIT_RXDATA, m_strRXData);
	DDX_Text(pDX, IDC_EDIT_TXDATA, m_strTXData);
	DDX_Text(pDX, IDC_EDIT_SETPORT, m_setport);
	DDV_MinMaxInt(pDX, m_setport, 1, 10);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CMyDlg, CDialog)
	//{{AFX_MSG_MAP(CMyDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON_MANUALSEND, OnButtonManualsend)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyDlg message handlers

BOOL CMyDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon

	// TODO: Add extra initialization here
	m_portnum=1;
	m_setport=1;
	UpdateData(FALSE);
	m_ctrlComm.SetCommPort(m_portnum); //选择com1
	
	if( !m_ctrlComm.GetPortOpen())
	m_ctrlComm.SetPortOpen(TRUE);//打开串口
	else
	AfxMessageBox("cannot open serial port");

	m_ctrlComm.SetSettings("9600,n,8,1"); //波特率9600,无校验,8个数据位,1个停止位 

	m_ctrlComm.SetInputMode(1); //1:表示以二进制方式检取数据
	m_ctrlComm.SetRThreshold(1); 
	//参数1表示每当串口接收缓冲区中有多于或等于1个字符时将引发一个接收数据的OnComm事件
	m_ctrlComm.SetInputLen(0); //设置当前接收区数据长度为0
	m_ctrlComm.GetInput();//先预读缓冲区以清除残留数据
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

int CMyDlg::String2Hex(CString str, CByteArray &senddata)
{
int hexdata,lowhexdata;
int hexdatalen=0;
int len=str.GetLength();
senddata.SetSize(len/2);
for(int i=0;i<len;)
{
char lstr,hstr=str[i];
if(hstr==' ')
{
i++;
continue;
}
i++;
if(i>=len)
break;
lstr=str[i];
hexdata=ConvertHexChar(hstr);
lowhexdata=ConvertHexChar(lstr);
if((hexdata==16)||(lowhexdata==16))
break;
else 
hexdata=hexdata*16+lowhexdata;
i++;
senddata[hexdatalen]=(char)hexdata;
hexdatalen++;
}
senddata.SetSize(hexdatalen);
return hexdatalen;
}

//这是一个将字符转换为相应的十六进制值的函数
//好多C语言书上都可以找到
//功能:若是在0-F之间的字符,则转换为相应的十六进制字符,否则返回-1
char CMyDlg::ConvertHexChar(char ch) 
{
if((ch>='0')&&(ch<='9'))
return ch-0x30;
else if((ch>='A')&&(ch<='F'))
return ch-'A'+10;
else if((ch>='a')&&(ch<='f'))
return ch-'a'+10;
else return (-1);
}


void CMyDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CMyDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		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;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CMyDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

BEGIN_EVENTSINK_MAP(CMyDlg, CDialog)
    //{{AFX_EVENTSINK_MAP(CMyDlg)
	ON_EVENT(CMyDlg, IDC_MSCOMM_NEW, 1 /* OnComm */, OnOnCommMscommNew, VTS_NONE)
	//}}AFX_EVENTSINK_MAP
END_EVENTSINK_MAP()

void CMyDlg::OnOnCommMscommNew() 
{
	// TODO: Add your control notification handler code here
	VARIANT variant_inp;
    COleSafeArray safearray_inp;
    LONG len,k;
    BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed.
    CString strtemp;
    if(m_ctrlComm.GetCommEvent()==2) //事件值为2表示接收缓冲区内有字符
    {             ////////以下你可以根据自己的通信协议加入处理代码
        variant_inp=m_ctrlComm.GetInput(); //读缓冲区
        safearray_inp=variant_inp; //VARIANT型变量转换为ColeSafeArray型变量
        len=safearray_inp.GetOneDimSize(); //得到有效数据长度
        for(k=0;k<len;k++)
            safearray_inp.GetElement(&k,rxdata+k);//转换为BYTE型数组
        for(k=0;k<len;k++) //将数组转换为Cstring型变量
        {
            BYTE bt=*(char*)(rxdata+k); //字符型
			if(m_ctrlHexDiaplay.GetCheck())
				strtemp.Format("%02X ",bt); //将字符以十六进制方式送入临时变量strtemp存放,注意这里加入一个空隔
			else 
				strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放

          //  strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放
            m_strRXData+=strtemp; //加入接收编辑框对应字符串 
        }
    }
    UpdateData(FALSE); //更新编辑框内容

	
}

void CMyDlg::OnButtonManualsend() 
{
	// TODO: Add your control notification handler code here
		UpdateData(TRUE);
		m_strRXData.Empty();
		m_DD="";
	if(m_strTXData.GetAt(0)==0)
		MessageBox("请先输入显示内容!!!",NULL);

else
{
	//判断是不是英文字符
	if (m_strTXData.GetAt(0) > 0) //deal singlebyte char or multibyte char
	{
		ProcessEnglish();		
	}
	//中文字符
	else
	{
		ProcessChinese();		
	}
}
		UpdateData(TRUE); //读取编辑框内容
	m_portnum=m_setport;
		if(m_ctrlComm.GetPortOpen())
		m_ctrlComm.SetPortOpen(FALSE);

	m_ctrlComm.SetCommPort(m_portnum); //选择com1
	if( !m_ctrlComm.GetPortOpen())
	m_ctrlComm.SetPortOpen(TRUE);//打开串口
	else
	AfxMessageBox("cannot open serial port");

	m_ctrlComm.SetSettings("9600,n,8,1"); //波特率9600,无校验,8个数据位,1个停止位 

	m_ctrlComm.SetInputMode(1); //1:表示以二进制方式检取数据
	m_ctrlComm.SetRThreshold(1); 
	//参数1表示每当串口接收缓冲区中有多于或等于1个字符时将引发一个接收数据的OnComm事件
	m_ctrlComm.SetInputLen(0); //设置当前接收区数据长度为0
	m_ctrlComm.GetInput();//先预读缓冲区以清除残留数据

	m_strRXData=m_DD;             
	UpdateData(FALSE);
//	if(m_ctrlHexSend.GetCheck())
//	{
		CByteArray hexdata;
		int len=String2Hex(m_DD,hexdata); //此处返回的len可以用于计算发送了多少个十六进制数
		m_ctrlComm.SetOutput(COleVariant(hexdata)); //发送十六进制数据
//	}
//	else 
//		m_ctrlComm.SetOutput(COleVariant(m_strTXData));//发送ASCII字符数据
/*
	int a[]={0x10,0x40,0x11,0x41,0x11,0x42,0x11,0x44,0x22,0x48,0xE2,0x70,0x32,0x40,0x2C,0x40,
0x24,0x40,0x2A,0x7C,0x5A,0x42,0x49,0x42,0x41,0x42,0x07,0x4E,0x00,0x40,0x00,0x00};
	m_strTXData=(CString)(*a);
	m_ctrlComm.SetOutput(COleVariant(m_strTXData));
	*/
}
void CMyDlg::ProcessChinese()
{
	unsigned char th = m_strTXData.GetAt(0);
	unsigned char tl = m_strTXData.GetAt(1);
	//开辟字库缓冲区大小,一个字节8个点
	unsigned char Libbuff[POINTER_WIDTH*POINTER_HEIGHT>>3];			//除以8,用移位实现
	unsigned char VerLibbuff[POINTER_WIDTH*POINTER_HEIGHT>>3];		//除以8,得到字节数
	ULONG    address;
	UCHAR    BitIndex;
	CFile myfile;

	//清空显示缓冲区
//	m_HorizonLib.Empty();
//	m_VerticalLib.Empty();

	//根据汉字内码计算在文件中地址
	address = ((th-0xa1)*94+(tl-0xa1))*32;
	//计算,calculate the address

	//打开字库文件
	if(!myfile.Open("HZK16",CFile::typeBinary|CFile::modeReadWrite,NULL))
	{
		AfxMessageBox("error");
		return ;
	}
	//读取字模缓冲区
	myfile.Seek(address,CFile::begin);
	myfile.Read(Libbuff,sizeof(Libbuff));
	myfile.Close();

   
	//横排----->竖排
	for(int i = 0;i<sizeof(VerLibbuff);i++)
	{
		BitIndex = 0x01;
		UINT HorizonRow;
		UINT HorizonCol;
		VerLibbuff[i] = 0;

		//找出列号
		if(i<(sizeof(VerLibbuff)>>1))
		{
			HorizonCol = i;
		}
		else
		{
			HorizonCol = i -  (sizeof(VerLibbuff)>>1);
		}
		for(int j=0;j<8;j++)
		{
			//找出行号
			if(i<(sizeof(VerLibbuff)>>1))
			{
				HorizonRow = j;
			}
			else
			{
				HorizonRow = j+8;
			}
			UCHAR temp2 = 0x80;
			//找到对应位置位
			if(Libbuff[HorizonRow*2+(HorizonCol>>3)]&(temp2>>(HorizonCol%8)))
			{
				VerLibbuff[i] = VerLibbuff[i] | BitIndex;
			}
			BitIndex = BitIndex<<1;			
		}
	}
	

	//将字模显示出来
//	DisplayResult(Libbuff,POINTER_WIDTH,POINTER_HEIGHT);

	//显示横排结果
	for(i=0;i<sizeof(Libbuff);i++)
	{
		char temp[3];
		unsigned char Value = Libbuff[i];
		if(((i%8)==0)&&(i!=0))
		{
//			m_HorizonLib += "\r\n" ;
		}
//		m_HorizonLib += " 0x" ;
		if(Value<16)
		{
			temp[0] = '0';
			itoa(Value,&temp[1],16);
		}
		else
		{

			itoa(Value,temp,16);
		}
//		m_HorizonLib += temp;
		m_DD+=temp;		
	}
	char a=0x30;
	m_DD+=a;
	m_DD+=a;
	
	//显示竖排结果
	for(i=0;i<sizeof(VerLibbuff);i++)
	{
		char temp[3];
		unsigned char Value = VerLibbuff[i];
		if(((i%8)==0)&&(i!=0))
		{
//			m_VerticalLib += "\r\n" ;
			;
		}
//		m_VerticalLib += " 0x" ;
		if(Value<16)
		{
			temp[0] = '0';
			itoa(Value,&temp[1],16);
		}
		else
		{

			itoa(Value,temp,16);
		}
//		m_VerticalLib += temp;
		
	}
//	UpdateData(FALSE);
	//dc.GetGlyphOutline();
}
void CMyDlg::ProcessEnglish()
{
	UINT addr;
	//开辟字库缓冲区大小,一个字节8个点
	unsigned char Libbuff[16];
	unsigned char VerLibbuff[16];
	CFile myfile;
	UCHAR    BitIndex;
	
//	m_HorizonLib.Empty();
//	m_VerticalLib.Empty();
	
	//打开字库文件
	if(!myfile.Open("ASC16",CFile::typeBinary|CFile::modeReadWrite,NULL))
	{
		AfxMessageBox("error");
		return ;
	}
	addr = m_strTXData.GetAt(0)<<4;
	myfile.Seek(addr,CFile::begin);
	myfile.Read(Libbuff,16);
	myfile.Close();

	
//	DisplayResult(Libbuff,8,16);

	//横排------>竖排
	for(int i = 0;i<sizeof(VerLibbuff);i++)
	{
		BitIndex = 0x01;
		UINT HorizonRow;
		UINT HorizonCol;
		VerLibbuff[i] = 0;

		//找出列号
		if(i<8)
		{
			HorizonCol = i;
		}
		else
		{
			HorizonCol = i -  8;
		}
		for(int j=0;j<8;j++)
		{
			//找出行号
			if(i<8)
			{
				HorizonRow = j;
			}
			else
			{
				HorizonRow = j+8;
			}
			UCHAR temp2 = 0x80;
			//找到对应位置位
			if(Libbuff[HorizonRow]&(temp2>>(HorizonCol%8)))
			{
				VerLibbuff[i] = VerLibbuff[i] | BitIndex;
			}
			BitIndex = BitIndex<<1;
			
		}
	}
	char a=0x30;
	//显示横排结果
	for(i=0;i<sizeof(Libbuff);i++)
	{
		char temp[3];
		unsigned char Value = Libbuff[i];
		if(((i%8)==0)&&(i!=0))
		{
//			m_HorizonLib += "\r\n" ;
		}
//		m_HorizonLib += " 0x" ;
		if(Value<16)
		{
			temp[0] = '0';
			itoa(Value,&temp[1],16);
		}
		else
		{

			itoa(Value,temp,16);
		}
//		m_HorizonLib += temp;
		m_DD+=temp;	
		m_DD+=a;
		m_DD+=a;		
	}
	m_DD+=a;
	m_DD+=a;
	//显示竖排结果
	for(i=0;i<sizeof(VerLibbuff);i++)
	{
		char temp[3];
		unsigned char Value = VerLibbuff[i];
		if(((i%8)==0)&&(i!=0))
		{
//			m_VerticalLib += "\r\n" ;
		}
//		m_VerticalLib += " 0x" ;
		if(Value<16)
		{
			temp[0] = '0';
			itoa(Value,&temp[1],16);
		}
		else
		{

			itoa(Value,temp,16);
		}
//		m_VerticalLib += temp;	
	}
//	UpdateData(FALSE);
	
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -