基本信息
源码名称:串口调试助手源代码(详细中文注释)
源码大小:105.40M
文件格式:.rar
开发语言:C/C++
更新时间:2019-04-24
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
该资源有两个,一是串口调试助手的源代码,可以实现数据的接收和发送;二是实现点击某个按钮发送指定数据的应用程序的源代码。代码都是含有详细的中文注释,可以直接编译通过,且内含可执行文件都是可以直接运行的。适合作为串口助手开发与原理了解的参考,希望本资源对您有用
该资源有两个,一是串口调试助手的源代码,可以实现数据的接收和发送;二是实现点击某个按钮发送指定数据的应用程序的源代码。代码都是含有详细的中文注释,可以直接编译通过,且内含可执行文件都是可以直接运行的。适合作为串口助手开发与原理了解的参考,希望本资源对您有用
// SerialassistantDlg.cpp : 实现文件 // #include "stdafx.h" #include "Serialassistant.h" #include "SerialassistantDlg.h" #include "afxdialogex.h" #ifdef _DEBUG #define new DEBUG_NEW #endif // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 class CAboutDlg : public CDialogEx { public: CAboutDlg(); // 对话框数据 #ifdef AFX_DESIGN_TIME enum { IDD = IDD_ABOUTBOX }; #endif protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现 protected: DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX) { } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx) END_MESSAGE_MAP() // CSerialassistantDlg 对话框 CSerialassistantDlg::CSerialassistantDlg(CWnd* pParent /*=NULL*/) : CDialogEx(IDD_SERIALASSISTANT_DIALOG, pParent) , m_setOk(false) , m_strTXData(_T("")) , m_strRXData(_T("")) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CSerialassistantDlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); DDX_Control(pDX, IDC_COMBO_COM, m_comboCom); DDX_Control(pDX, IDC_MSCOMM1, m_ctrlComm); DDX_Text(pDX, IDC_EDIT_TXDATA, m_strTXData); DDX_Text(pDX, IDC_EDIT_RXDATA, m_strRXData); } BEGIN_MESSAGE_MAP(CSerialassistantDlg, CDialogEx) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_CBN_SELCHANGE(IDC_COMBO_COM, &CSerialassistantDlg::OnCbnSelchangeComboCom) ON_BN_CLICKED(IDC_BUTTON_SEND, &CSerialassistantDlg::OnBnClickedButtonSend) ON_BN_CLICKED(IDC_BUTTON_CLEANUP, &CSerialassistantDlg::OnBnClickedButtonCleanup) END_MESSAGE_MAP() // CSerialassistantDlg 消息处理程序 BOOL CSerialassistantDlg::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: 在此添加额外的初始化代码 m_comboCom.AddString(_T("COM1")); // 为组合框控件的列表框添加列表项 m_comboCom.AddString(_T("COM2")); m_comboCom.AddString(_T("COM3")); m_comboCom.AddString(_T("COM4")); m_comboCom.AddString(_T("COM5")); m_comboCom.AddString(_T("COM6")); m_comboCom.AddString(_T("COM7")); m_comboCom.AddString(_T("COM8")); m_comboCom.AddString(_T("COM9")); m_comboCom.AddString(_T("COM10")); return TRUE; // 除非将焦点设置到控件,否则返回 TRUE } void CSerialassistantDlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialogEx::OnSysCommand(nID, lParam); } } // 如果向对话框添加最小化按钮,则需要下面的代码 // 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序, // 这将由框架自动完成。 void CSerialassistantDlg::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 CSerialassistantDlg::OnQueryDragIcon() { return static_cast<HCURSOR>(m_hIcon); } void CSerialassistantDlg::OnCbnSelchangeComboCom() //组合框的消息处理函数,但选择串口后会触发该函数执行,即串口初始化操作 { // TODO: 在此添加控件通知处理程序代码 int nSel; nSel = m_comboCom.GetCurSel();//获取组合框控件的列表框中选中项的索引 //串口控件添加控制变量m_ctrlComm,该内容非常的重要,相当于定义了一个串口类,然后就可以调用串口控制类中的相关函数进行操作。 m_ctrlComm.put_CommPort(nSel 1);//选择串口号(这里因为列表框的索引号是从0开始,所以(nSel 1)对应的才是我们所选的串口号) m_ctrlComm.put_PortOpen(TRUE);//打开串口 m_ctrlComm.put_RThreshold(2);//收到两个字节引发OnComm事件 m_ctrlComm.put_InputMode(1);//输入模式选为二进制 m_ctrlComm.put_Settings(_T("9600,n,8,1"));//设置串口参数,波特率,无奇偶校验,位停止位,位数据位 m_ctrlComm.put_InputMode(1); // 以二进制方式检取数据 m_ctrlComm.put_RThreshold(1); //参数1表示每当串口接收缓冲区中有多于或等于1个字符时将引发一个接收数据的OnComm事件 m_ctrlComm.put_InputLen(0); //设置当前接收区数据长度为0 m_ctrlComm.get_Input();//先预读缓冲区以清除残留数据 m_setOk = true; //标记串口设置OK } BEGIN_EVENTSINK_MAP(CSerialassistantDlg, CDialogEx) ON_EVENT(CSerialassistantDlg, IDC_MSCOMM1, 1, CSerialassistantDlg::OnComm, VTS_NONE) END_EVENTSINK_MAP() void CSerialassistantDlg::OnComm() //该程序为串口控键进行数据的接收和显示 { // TODO: 在此处添加消息处理程序代码 VARIANT variant_inp; //Variant 是一种特殊的数据类型,除了定长String数据及用户定义类型外,可以包含任何种类的数据。 COleSafeArray safearray_inp; LONG len, k; BYTE rxdata[2048]; //设置BYTE数组,用于存储接收到的数据,所以最大只能接收2048个字节的数据 CString strtemp; if (m_ctrlComm.get_CommEvent() == 2) //事件值为2表示接收缓冲区内有字符 { ////////以下你可以根据自己的通信协议加入处理代码 variant_inp = m_ctrlComm.get_Input(); //读缓冲区 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);//字符型 strtemp.Format(_T("%c"), bt); //将字符送入临时变量strtemp存放 m_strRXData = strtemp; //加入接收编辑框对应字符串 } } UpdateData(FALSE); //更新编辑框内容 } void CSerialassistantDlg::OnBnClickedButtonSend() { // TODO: 在此添加控件通知处理程序代码 if (m_setOk == true) //判断是否打开并初始化串口 { UpdateData(TRUE); //读取编辑框内容 m_ctrlComm.put_Output(COleVariant(m_strTXData)); //发送数据,COleVariant用于将任意类型的数据转化为VARIANT类型数据 } else { MessageBox(_T("请先选择COM口")); } } void CSerialassistantDlg::OnBnClickedButtonCleanup() { // TODO: 在此添加控件通知处理程序代码 m_strRXData = ""; UpdateData(FALSE);//更新编辑框内容 }