您的位置:首页 > 编程语言 > C语言/C++

VC++ 6.0 C8051F340 MFC programming note

2015-10-16 09:42 531 查看
/**************************************************************************************
*          VC++ 6.0 C8051F340 MFC programming note
* 声明:
*     本文主要在使用VC++ 6.0 MFC的时候,对一些之前不知道的东西进行记录。
*
*                                               2015-10-16 晴 深圳 南山平山村 曾剑锋
*************************************************************************************/

\\\\\\\\\\\\\\\\\-*- 目录 -*-//////////////////
|  一、vc6 MFC 输出调试信息:
|  二、vc6 MFC 字符串拷贝:
|  三、vc6 MFC 字符串格式化:
|  四、vc6 MFC 获取控件:
|  五、vc6 MFC 控件失效:
|  六、vc6 MFC 字符串转数字:
|  七、工作者线程AfxBeginThread的原型如下:
+---------------------------------------------+

一、vc6 MFC 输出调试信息:
1. 在 Project | Setting 中,选项 Post-builder step 里新建command,输入:
editbin /SUBSYSTEM:CONSOLE $(OUTDIR)\filename.exe(其中 filename 为可执行文件名)
2. 就可以使用 printf 或者 std::cout在控制台中输出了。
3. 例如你的可执行文件名为 HelloWorld.exe,则你新建的 command  就为
editbin /SUBSYSTEM:CONSOLE $(OUTDIR)\HelloWorld.exe

二、vc6 MFC 字符串拷贝:
1. CString是一个动态TCHAR数组,BSTR是一种专有格式的字符串(需要用系统提供的函数来操纵,
LPCTSTR只是一个常量的TCHAR指针。这里相当于转换CString 变量为指针,因为这里使用了strcpy函数
2. strcpy(szcode,(LPCTSTR)strcode);

三、vc6 MFC 字符串格式化:
strtmp=strcode;
strcode.Format("%08s",strtmp);                // 不够八位补零

四、vc6 MFC 获取控件:
1. 基本用法(得到当前对话框中的控件):
CButton* btn = (CButton*)GetDlgItem(IDC_BUTTON_SEND);
btn->SetWindowTextW(_T("hello"));
2. 如果想得到其他对话框中的控件,用GetDlgItem(hwnd,IDD);
3. Demo: GetDlgItem(IDC_BUTTON_CONNECT)->SetWindowText("Connect");

五、vc6 MFC 控件失效:
1. EnableWindow:这个是MFC里面的一个函数。
2. GetDlgItem(IDC_COMBO_CANIND)->EnableWindow(TRUE);
参数说明:
IDC_COMBO_CANIND:是设置某个控件的一个ID,这个ID是固定的一个ID代表一个控件
GetDlgItem函数代表得到ID为IDC_EDIT_INPUTFILE的控件的指针,
然后调用函数EnableWindow()设置为true代表这个控件是可用的
如果设置为false 就是不可用 界面上看 是灰色的 你无法点击

六、vc6 MFC 字符串转数字:
1. 数据转换:
/**
* 这里仅仅是将字符串数据转成数字
*/
CString strcode = "1";
strcpy(szcode,(LPCTSTR)strcode);
if(strtodata((unsigned char*)szcode,sztmp,4,0)!=0)
{
MessageBox("Format error for AccCode !","Warning",MB_OK|MB_ICONQUESTION);
return;
}
code=(((DWORD)sztmp[0])<<24)+(((DWORD)sztmp[1])<<16)+(((DWORD)sztmp[2])<<8)+
((DWORD)sztmp[3]);
2. strtodata的原型:
int CTestDlg::strtodata(unsigned char *str, unsigned char *data,int len,int flag)
{
unsigned char cTmp=0;
int i=0;
for(int j=0;j<len;j++)
{
if(chartoint(str[i++],&cTmp))        // 判断字符串结尾
return 1;
data[j]=cTmp;
if(chartoint(str[i++],&cTmp))        // 判断字符串结尾
return 1;
data[j]=(data[j]<<4)+cTmp;
if(flag==1)                            // 这个应该是为了除掉空格格式化的效果
i++;
}
return 0;
}

七、工作者线程AfxBeginThread的原型如下:
1. CWinThread* AfxBeginThread(AFX_THREADPROC pfnThreadProc,
  LPVOID lParam,
  int nPriority = THREAD_PRIORITY_NORMAL,
  UINT nStackSize = 0,
  DWORD dwCreateFlags = 0,
  LPSECURITY_ATTRIBUTES lpSecurityAttrs = NULL
  );//用于创建工作者线程
返回值:            成功时返回一个指向新线程的线程对象的指针,否则NULL。
pfnThreadProc :     线程的入口函数,声明一定要如下: UINT MyThreadFunction(LPVOID pParam),不能设置为NULL;
pParam :            传递入线程的参数,注意它的类型为:LPVOID,所以我们可以传递一个结构体入线程.
nPriority :         线程的优先级,一般设置为 0 .让它和主线程具有共同的优先级.
nStackSize :        指定新创建的线程的栈的大小.如果为 0,新创建的线程具有和主线程一样的大小的栈
dwCreateFlags :     指定创建线程以后,线程有怎么样的标志.可以指定两个值:
CREATE_SUSPENDED :  线程创建以后,会处于挂起状态,直到调用:ResumeThread
0 :                 创建线程后就开始运行.
lpSecurityAttrs :   指向一个 SECURITY_ATTRIBUTES 的结构体,用它来标志新创建线程的安全性.如果为 NULL,
那么新创建的线程就具有和主线程一样的安全性.
如果要在线程内结束线程,可以在线程内调用 AfxEndThread.
结束线程的两种方式
当你在后台用线程来打印一些图形时.有时在打印一部分后,你希望可以停下来,那么此如何让线程停止呢.
2. 常见用法
AfxBeginThread(ThreadProc,this);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: