MFC中串口类的使用

本文介绍了一个在MFC中使用串口控件的方法,包括自动获取可用串口、响应串口事件和打开关闭串口的操作。通过创建并设置MSComm对象,实现了串口的配置和数据接收。
摘要由CSDN通过智能技术生成

串口控件

 

//自动获取串口:

 voidCENVVAR_CONFIGDlg::GetCom()

{

   //程序启动时获取全部可用串口

    HANDLE  hCom;

     int i,num,k;

    CString str;

    BOOL flag;

   

   ((CComboBox *)GetDlgItem(IDC_COMBO_COM))->ResetContent();

   flag = FALSE;

   num = 0;

   for (i = 1;i <= 16;i++)

   {//此程序支持16个串口

       str.Format("\\\\.\\COM%d",i);

       hCom = CreateFile(str, 0, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL,0);

       if(INVALID_HANDLE_VALUE != hCom )

       {//能打开该串口,则添加该串口

           CloseHandle(hCom);

           str = str.Mid(4);

           ((CComboBox *)GetDlgItem(IDC_COMBO_COM))->AddString(str);

            if (flag == FALSE)

           {

                flag = TRUE;

                num = i;

           }

       }

    }

    i= ((CComboBox *)GetDlgItem(IDC_COMBO_COM))->GetCount();

   if (i == 0)

   {//若找不到可用串口则禁用“打开串口”功能

       ((CComboBox *)GetDlgItem(IDC_COMBO_COM))->EnableWindow(FALSE);

    }

   else

    {

       k = ((CComboBox *)GetDlgItem((IDC_COMBO_COM)))->GetCount();

       ((CComboBox *)GetDlgItem(IDC_COMBO_COM))->SetCurSel(k - 1);

       //mCom.

MFC串口通信程序代码,含界面 // 串口通信.cpp : 定义应用程序的行为。 // #include "stdafx.h" #include "串口通信.h" #include "串口通信Dlg.h" #ifdef _DEBUG #define new DEBUG_NEW #endif // C串口通信App BEGIN_MESSAGE_MAP(C串口通信App, CWinApp) ON_COMMAND(ID_HELP, &CWinApp::OnHelp) END_MESSAGE_MAP() // C串口通信App 构造 C串口通信App::C串口通信App() { // 支持重新启动管理器 m_dwRestartManagerSupportFlags = AFX_RESTART_MANAGER_SUPPORT_RESTART; // TODO: 在此处添加构造代码, // 将所有重要的初始化放置在 InitInstance } // 唯一的一个 C串口通信App 对象 C串口通信App theApp; // C串口通信App 初始化 BOOL C串口通信App::InitInstance() { // 如果一个运行在 Windows XP 上的应用程序清单指定要 // 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式, //则需要 InitCommonControlsEx()。 否则,将无法创建窗口。 INITCOMMONCONTROLSEX InitCtrls; InitCtrls.dwSize = sizeof(InitCtrls); // 将它设置为包括所有要在应用程序使用的 // 公共控件。 InitCtrls.dwICC = ICC_WIN95_CLASSES; InitCommonControlsEx(&InitCtrls); CWinApp::InitInstance(); AfxEnableControlContainer(); // 创建 shell 管理器,以防对话框包含 // 任何 shell 树视图控件或 shell 列表视图控件。 CShellManager *pShellManager = new CShellManager; // 激活“Windows Native”视觉管理器,以便在 MFC 控件启用主题 CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows)); // 标准初始化 // 如果未使用这些功能并希望减小 // 最终可执行文件的大小,则应移除下列 // 不需要的特定初始化例程 // 更改用于存储设置的注册表项 // TODO: 应适当修改该字符串, // 例如修改为公司或组织名 SetRegistryKey(_T("应用程序向导生成的本地应用程序")); C串口通信Dlg dlg; m_pMainWnd = &dlg; INT_PTR nResponse = dlg.DoModal(); if (nResponse == IDOK) { // TODO: 在此放置处理何时用 // “确定”来关闭对话框的代码 } else if (nResponse == IDCANCEL) { // TODO: 在此放置处理何时用 // “取消”来关闭对话框的代码 } else if (nResponse == -1) { TRACE(traceAppMsg, 0, "警告: 对话框创建失败,应用程序将意外终止。\n"); TRACE(traceAppMsg, 0, "警告: 如果您在对话框上使用 MFC 控件,则无法 #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS。\n"); } // 删除上面创建的 shell 管理器。 if (pShellManager != NULL) { delete pShellManager; } // 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序, // 而不是启动应用程序的消息泵。 return FALSE; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值