MFC如何使用自定义函数调用控件关联的变量

自定义了一个返回值为空的函数 void abc();
void abc
{
m_button1.MoveWindow(0,0,100,100);
}
显示m_button1未定义标示,但在OnInit中就可以使用?这是为什么呢?
如题,如何在自定义的函数中使用控件的关联变量呢?????

2个回答

 void abc()修改为
void XXXDlg::abc(); (头文件也要修改)
或者不定义成成员函数,加上一个参数,
void abc(CButton* pbtn)
{
pbtn->MoveWindow(0,0,100,100);
}
调用者
abc(&m_button1);

zhongqiangyaming
zhongqiangyaming 谢谢,不知道怎么回事,又好了,小白感觉很无语!!
3 年多之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 回复zhongqiangyaming: 什么错误信息,什么代码,最好重新开一个问题
3 年多之前 回复
zhongqiangyaming
zhongqiangyaming 你好,再麻烦一下,我现在可以实现这个改变控件大小和位置的功能了,但是想在按钮的点击事件里面调用自定义的函数,在这个自定义的函数里面我选择隐藏了一些控件,但是运行一直报错,是怎么回事啊????
3 年多之前 回复
zhongqiangyaming
zhongqiangyaming 谢谢!!!问题解决了,非常感谢!!!
3 年多之前 回复

abc要定义成对话框的成员函数。

zhongqiangyaming
zhongqiangyaming 在什么地方定义呢?dlg.h?能说明一个具体位置吗?
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
求教mfc对话框插入ActiveX控件的问题
我用编译好的vlc .dll文件封装了vlc ActiveX控件,然后在mfc对话框里插入该控件并给其添加变量,添加变量后有了vlcpludin1.h和vlcplugin.cpp文件,接下来就该调用接口了。 首先,我想问一下 我理解的这两条是否正确: (1)通过 [控件变量名.成员函数] 来调用控件接口; (2)成员函数在vlcplugin1.h中的声明里都该调用InvokeHelper函数才可调用,如下: LPDISPATCH get_playlist() { LPDISPATCH result; InvokeHelper(0x60020015, DISPATCH_PROPERTYGET, VT_DISPATCH, (void*)&result, NULL); return result; } 然后就是,我要调用get_playlist()函数,可是在VlcPlayerDlg.cpp文件里添加处理程序代码时, 控件变量名.(点)自动出现的成员函数里没有get_playlist,为什么呢?
MFC添加的控件(ListControl),为什么没有调用create函数,导致m_dWnd为0
我在图形化编辑里面加入了空间,然后点右键添加了相应的变量(一个控件的对象),但是后面访问这个对象的时候,出现错误,错误的原因是它的句柄为0.据说是因为没有调用create函数才造成的?我的流程是什么地方错了吗?
MFC中 picture control控件获取不到句柄问题
MFC窗口 添加了picture control控件,在picture控件上添加了m_show变量,但是在使用 hwnd = m_show.GetSafeHwnd();时 hwnd 显示为 0x001105da{unused=???}。这里面的unused是什么意思呢, hwnd句柄不是NULL的。我在调用这个函数时候m_play.Play(szVideoPath,m_show.GetSafeHwnd()); 被调用的Play(char *szVideoPath,HWND hwnd);函数中 hwnd形参并没有被赋值,希望能得到帮助,谢谢
如何调用另一个类的源文件(cpp)中的某个函数的计算结果(变量)?
现有一个程序,可以根据地址读取两幅图像,可以处理像素,目的是计算两幅图像对应像素点的lab的差值,同时计算色差,并通过一个按钮显示到一个编辑框里面。目前大部分算法都已写完,就是点击按钮如何让计算结果显示到编辑框中那一步不太会。 先给出我的CGDALProcess累里的ColorAberration函数。 double CGDALProcess::ColorAberration(CString imgPath, CString imgRefPath) { GDALDataset* datasetsrc = (GDALDataset*)GDALOpen(imgPath, GA_ReadOnly); GDALDataset* datasetref = (GDALDataset*)GDALOpen(imgRefPath, GA_ReadOnly); if (nullptr == datasetsrc) { return 0; } if (nullptr == datasetref) { datasetref = datasetsrc; } int bandCount = datasetsrc->GetRasterCount(); int width = datasetsrc->GetRasterXSize(); int height = datasetsrc->GetRasterYSize(); int bandCountref = datasetref->GetRasterCount(); int widthref = datasetref->GetRasterXSize(); int heightref = datasetref->GetRasterYSize(); if (bandCount > 3) { bandCount = 3; } //设置仿射变换 double adfGeoTransform[6] = { 0 }; datasetsrc->GetGeoTransform(adfGeoTransform); unsigned char * imageRGB = new unsigned char[width * height * 3](); unsigned char * imageRefRGB = new unsigned char[widthref * heightref * 3](); int bandmap[3] = { 1, 2, 3 }; datasetsrc->RasterIO(GF_Read, 0, 0, width, height, imageRGB, width, height, GDT_Byte, bandCount, bandmap, bandCount, bandCount * width, 1); datasetref->RasterIO(GF_Read, 0, 0, widthref, heightref, imageRefRGB, widthref, heightref, GDT_Byte, bandCount, bandmap, bandCount, bandCount * widthref, 1); int src_Size = width * height;//原图大小 int ref_Size = widthref * heightref;//模版图像大小 //src RGB to Lab double *imgSrc_lab = new double[src_Size * 3]; for (int i = 0; i < src_Size * 3; i += 3) { Rgb2Lab(imageRGB[i + 0], imageRGB[i + 1], imageRGB[i + 2], imgSrc_lab[i + 0], imgSrc_lab[i + 1], imgSrc_lab[i + 2]); } //ref RGB to Lab double *imgRef_lab = new double[ref_Size * 3]; for (int i = 0; i < ref_Size * 3; i += 3) { Rgb2Lab(imageRefRGB[i + 0], imageRefRGB[i + 1], imageRefRGB[i + 2], imgRef_lab[i + 0], imgRef_lab[i + 1], imgRef_lab[i + 2]); } //求两幅图所有像素值lab三通道差值的和(模版图像lab-原始图像lab),再除以图像大小以求平均值 int i; int suml(0); int suma(0); int sumb(0); for (i = 0; i< src_Size; i++) { suml += imgRef_lab[i * 3 + 0] - imgSrc_lab[i * 3 + 0]; suma += imgRef_lab[i * 3 + 1] - imgSrc_lab[i * 3 + 1]; sumb += imgRef_lab[i * 3 + 1] - imgSrc_lab[i * 3 + 1]; } double deltal; double deltaa; double deltab; deltal = suml / src_Size; deltaa = suma / src_Size; deltab = sumb / src_Size; return deltal; delete[] imageRGB; imageRGB = nullptr; delete[] imageRefRGB; imageRefRGB = nullptr; GDALClose(datasetsrc); } 然后是我dlg里的按钮代码 void CColorTransferDlg::OnBnClickedButton2() { if (m_strSrcPath == "" || m_strRefPath == "" ) return; int t; CGDALProcess ca; t = ca.ColorAberration(m_strSrcPath, m_strRefPath); UpdateData(TRUE);//读取控件变量值 m_m = t; UpdateData(FALSE);//把改过的值更新到控件 } 这是我自己的方法,打算先把l提取并显示的,但貌似不能计算出来。不知道怎么解决
MFC中调用子对话框的editbox控件时得不到输入的值
我在子对话框里面加入了一个edit控件,绑定的变量是String类型的m_Team_no, 在父对话框里面写了一个函数SaveData(); void CSoccerLab2Dlg::SaveData() { if(!m_pRecordset->adoEOF && m_nCurrentSel >= 0 && m_bAutoSave) { CDIALOGTeamDlg *dlg; dlg=new CDIALOGTeamDlg(); dlg->Create(IDD_DIALOGTeam,this); dlg->GetDlgItem(IDC_EDITTeam_no); UpdateData(TRUE ); CString str; dlg->GetWindowText(str); v_Team_no = str; //v_Team_Cname = dlg->m_Team_name; //v_Team_coach = dlg->m_Team_coach; //v_Team_home = dlg->m_Team_home; m_pRecordset->PutCollect("Team_no",v_Team_no); //m_pRecordset->PutCollect("Team_Cname",v_Team_Cname); //m_pRecordset->PutCollect("Team_coach",v_Team_coach); //m_pRecordset->PutCollect("Team_home",v_Team_home); //m_pRecordset->Update();///保存到库中 m_userlist.SetItem(m_nCurrentSel,0,LVIF_TEXT,(_bstr_t)v_Team_no,NULL,0,0,0); //m_userlist.SetItem(m_nCurrentSel,1,LVIF_TEXT,(_bstr_t)v_Team_Cname,NULL,0,0,0); //m_userlist.SetItem(m_nCurrentSel,2,LVIF_TEXT,(_bstr_t)v_Team_coach,NULL,0,0,0); //m_userlist.SetItem(m_nCurrentSel,3,LVIF_TEXT,(_bstr_t)v_Team_home,NULL,0,0,0); } } 但是调试发现不管怎么样,str都不能得到在子对话框里面输入的值,一直都显示是0, 真正插入数据库过后,打开数据库发现值是插入进去了,不过都是空白值- - 求问怎么回事呀
MFC中使用Update(FALSE)后变量不更新显示新的值
各位大佬麻烦帮忙看一下,放了一个static text的控件,在对话框中添加了下拉框的消息的处理函数,想要调用UpdateData(FALSE)函数将变量m_DriveType的值更新到界面上,但是运行后什么都没有。。 ``` // File1Dlg.cpp : 实现文件 // #include "stdafx.h" #include "File1.h" #include "File1Dlg.h" #include "afxdialogex.h" #ifdef _DEBUG #define new DEBUG_NEW #endif // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 class CAboutDlg : public CDialogEx { public: CAboutDlg(); // 对话框数据 enum { IDD = IDD_ABOUTBOX }; protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现 protected: DECLARE_MESSAGE_MAP() }; CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD) { } void CAboutDlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); } BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx) END_MESSAGE_MAP() // CFile1Dlg 对话框 CFile1Dlg::CFile1Dlg(CWnd* pParent /*=NULL*/) : CDialogEx(CFile1Dlg::IDD, pParent) , m_DriverType(_T("")) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CFile1Dlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); DDX_Control(pDX, IDC_COMBO1, m_drive); DDX_Text(pDX, IDC_STATIC1, m_DriverType); } BEGIN_MESSAGE_MAP(CFile1Dlg, CDialogEx) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_BN_CLICKED(IDC_OK, &CFile1Dlg::OnBnClickedOk) ON_CBN_SELCHANGE(IDC_COMBO1, &CFile1Dlg::OnCbnSelchangeComboDrive) END_MESSAGE_MAP() // CFile1Dlg 消息处理程序 BOOL CFile1Dlg::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: 在此添加额外的初始化代码 //第一次调用 size_t alldrive=::GetLogicalDriveStrings(0,NULL); _TCHAR *driverstr; driverstr=new _TCHAR[alldrive+sizeof(_T(""))]; //printf("AllDrivesize is: %d\r\n",alldrive); //第二次调用 size_t twosize=GetLogicalDriveStrings(alldrive,driverstr); CString DriveLetter; for(int i=0;i<alldrive/4;i++) { DriveLetter=driverstr+i*4; m_drive.InsertString(i,DriveLetter.GetBuffer()); } m_drive.SetCurSel(0); return TRUE; // 除非将焦点设置到控件,否则返回 TRUE } void CFile1Dlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialogEx::OnSysCommand(nID, lParam); } } // 如果向对话框添加最小化按钮,则需要下面的代码 // 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序, // 这将由框架自动完成。 void CFile1Dlg::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 CFile1Dlg::OnQueryDragIcon() { return static_cast<HCURSOR>(m_hIcon); } void CFile1Dlg::OnBnClickedOk() { // TODO: 在此添加控件通知处理程序代码 CString strDrive; m_drive.GetWindowTextW(strDrive); this->MessageBox(strDrive.GetBuffer()); OnOK(); } void CFile1Dlg::OnCbnSelchangeComboDrive() { // TODO: 在此添加控件通知处理程序代码 CString m_DriveType; CString strDrive; int now=m_drive.GetCurSel(); m_drive.GetLBText(now,strDrive); // not // m_Drive.GetWindowText(strDrive); int retCode = ::GetDriveType(strDrive); switch (retCode) { case DRIVE_UNKNOWN: m_DriveType = "驱动器类型:未知"; break; case DRIVE_NO_ROOT_DIR: m_DriveType = "类型:驱动器根路径错误"; break; case DRIVE_REMOVABLE:// 2 m_DriveType = "类型:可移动磁盘驱动器"; break; case DRIVE_FIXED:// 3 m_DriveType = "类型:固定磁盘驱动器"; break; case DRIVE_REMOTE: m_DriveType = "类型:网络磁盘驱动器"; break; case DRIVE_CDROM: m_DriveType = "类型:CD-ROM"; break; case DRIVE_RAMDISK: m_DriveType = "类型:RAM"; break; default: m_DriveType = "类型:未知"; break; } UpdateData(FALSE); } ``` ![图片说明](https://img-ask.csdn.net/upload/201909/25/1569421005_977279.png) ![图片说明](https://img-ask.csdn.net/upload/201909/25/1569421041_644529.png) ps.变量类型是value还是control会影响UpdateData(FALSE)的调用吗??
vc6 c++ mfc想利用googlr map api,
vc6 c++,想利用googlr map api,用什么框架好?目前用的mfc、cdialog类界面,利用cwebbrowser2控件如何调用javascript中的函数,并将变量传递至js的函数中?另外用这个控件怎么打开相对路径下的html文件?
VS2017 MFC 如何调用其他类的ListCtrl信息?
因工作需要自学MFC,目前我在A类里建了一个ListCtrl控件,创建控件变量为m_ListCtrl,然后我需要在B类里获取这个控件的信息。第一次我想在B类里创建个实例对象,但是取不到信息。第二次想将m_ListCtrl这个变量作为参数传到B类,但是提示:“无法引用 函数 "CListCtrl::CListCtrl(const CListCtrl &)" (已隐式声明) -- 它是已删除的函数”。第三次我想在A类将控件里的内容放到CStringList里,但是返回值还是提示已被删除。看网上说用什么引用,但是没太搞懂。所以写了这段 ``` CStringList* CStuInfoManag::GetListInfo() { int iColumnNum, iRowCount, i, j; CString strText; CStringList cList; cList.RemoveAll(); cList. iColumnNum = m_ListCtrl.GetHeaderCtrl()->GetItemCount(); iRowCount = m_ListCtrl.GetItemCount(); for (i = 0; i < iColumnNum; i++) { for (j = 0; j < iRowCount; j++) { strText = m_ListCtrl.GetItemText(j,i); cList.AddTail(strText); } } return &cList; } ``` 这样提示错误为:class "CStringList" 没有成员 "iColumnNum"。 以上是我的尝试方法,我该如何在B类里取得A类ListCtrl的信息?
opencv窗口嵌入mfc图片控件后,鼠标滚轮事件无法响应,其他如左键点击事件却可以?
我已经把“view”窗口嵌入到mfc控件中(如下图代码),打算用opencv的鼠标事件来进行操作,然而我在用setMouseCallback("view", on_mouse, NULL)调用函数on_mouse时,on_mouse函数里的鼠标滚轮事件完全不响应,其他却可以响应,请问是什么原因?? ``` // TODO: 在此添加额外的初始化代码 CWnd *pWnd1 = GetDlgItem(IDC_abc);//CWnd是MFC窗口类的基类,提供了微软基础类库中所有窗口类的基本功能。 pWnd1->GetClientRect(&rect1);//GetClientRect为获得控件相自身的坐标大小 namedWindow("view", WINDOW_AUTOSIZE);//设置窗口名 HWND hWndl = (HWND)cvGetWindowHandle("view");//hWnd 表示窗口句柄,获取窗口句柄 HWND hParent1 = ::GetParent(hWndl);//GetParent函数一个指定子窗口的父窗口句柄 ::SetParent(hWndl, GetDlgItem(IDC_abc)->m_hWnd); ::ShowWindow(hParent1, SW_HIDE);//ShowWindow指定窗口中显示 ``` 按钮函数: ``` void CmouseDlg::OnBnClickedButton3() { int NewHeight = rect1.bottom; int NewWidth = rect1.right; cv::Size NewSize(NewWidth, NewHeight); cv::Mat cvImgScaled(NewSize, CV_8UC3); resize(cvImg, cvImgScaled, NewSize); cvImgScaled.copyTo(img); //图片接口 cvImgScaled.copyTo(tmp); //临时变量 namedWindow("view");//定义一个img窗口 setMouseCallback("view", on_mouse, NULL);//调用回调函数 imshow("view", cvImgScaled); } ```
一个在MFC对话框程序的PICTRUE控件中绘图的问题
本人目前正在做一个小程序,用于在数据库中读取某个字段,然后根据读取的结果在Pictrue控件中进行绘图(由一个按钮按下的事件驱动)。 原理为这般: bool型变量m_bIsDraw (默认为false) 用于判断是否为首次程序,如果是第一次打开则执行在OnPaint()函数中drawCircle(void)函数(用于生成直角坐标系和圆形的底图),然后将m_bIsDraw置为true,按键按下的函数中调用void CfindHistoryDlg::drawHistroy(void)(用于读取字段,并生成图形)代码如下: void CfindHistoryDlg::drawHistroy(void) { _variant_t time,varWD; double dWD; CPoint cpTemp; CRect rect; CWnd* pWnd = GetDlgItem(IDC_STATIC_PICTURE); pWnd->GetClientRect(&rect); CDC* pDC = pWnd->GetDC(); this->m_pRecordset.CreateInstance(_uuidof(Recordset)); try{ m_pRecordset->Open("SELECT * FROM aa", this->m_pConnection.GetInterfacePtr(), adOpenDynamic,adLockReadOnly,adCmdText); //读取数据库 if(!(m_pRecordset->BOF && m_pRecordset->adoEOF)){ //是否为空表 m_pRecordset->MoveFirst(); while(!m_pRecordset->adoEOF){ time = m_pRecordset->GetCollect("时间"); if( this->varToString(time) != "0"){ //时间字段不为0 if((m_pRecordset->GetCollect("温度")).vt != VT_NULL){ dWD = (double)m_pRecordset->GetCollect("温度"); //以下的两步用于计算数值在坐标中的位置 dWD = this->calcDistance (dWD,220); cpTemp = this->drawPosition(dZnw); pDC->SetPixelV(cpTemp,RGB(255,0,0)); //描点 } } m_pRecordset->MoveNext(); } else{ AfxMessageBox(L"数据表为空!"); } } catch(_com_error *e){ AfxMessageBox(e->ErrorMessage()); } m_pRecordset->Close(); m_pRecordset = NULL; this->ReleaseDC(pDC); } 将其放在OnPaint()的 m_bIsDraw == true 分支 在按钮事件中将 m_bIsDraw 置为true 并调用OnPaint() 函数,但没有任何反应,不知道怎么回事,还请各位大大指正!!!!
MFC编程遇到问题求助大神
求助各路大神。。 我在VC 6.0上编写MFC程序,我在一个dlg对话框里面加两个按钮控件,设置点击它们会弹出不同的模态对话框(用的dlg.DoModal())。新的对话框有自己的编辑框和按钮,我在编辑框输入数据后点击按钮后会在结果编辑框中输出数据,但是我发现一个问题。 我这里想要做的是,点击两个按钮分别弹出一个模逆运算和模幂运算的对话框,我先写模逆的,编译运行,点击按钮,弹出对话框,在编辑框输入数据(运算数和模数),点击按钮,输出数据,结果没问题。接着我写模幂的,但是发现死活就不行了,也不报错,编译能运行,点击按钮,弹出模幂对话框,不管输入什么数据,输出始终都是0,我直接把用于输出结果的那个编辑框嗦绑定的变量人为赋值为一个非0的数,它输出居然还是0。开始我以为是第二个对话框编写函数的时候出了问题,但是又始终检查不出来就全部重新做,这次然后先写模幂的,发现模幂的可以运行了,然后写模逆,但是这次模逆的却出现刚才那个问题了,始终输出为0,感觉它就好像根本没有调用我给按钮写的响应函数一样。 小弟实在很困惑,MFC学得比较肤浅,实在不知道怎么回事了,求助各路大神。
MFC对话框初始化时新建线程,调用OPENCV显示视频文件的问题。
我用VS2010新建一个MFC对话框。 新建3个全局变量:IplImage *img;CvCapture* capture; int m_flag=0。(m_flag用来退出线程。) 在对话框上插入一个图片控件IDC_PTC。 在对话框的初始化函数中插入如下代码 ``` capture=cvCreateCameraCapture(0); if(!capture) { MessageBox(_T("打开摄像头失败!")); } else { m_flag=1; cvSetCaptureProperty(capture, CV_CAP_PROP_FRAME_WIDTH, 800); cvSetCaptureProperty(capture, CV_CAP_PROP_FRAME_HEIGHT, 800); cvSetCaptureProperty(capture, CV_CAP_PROP_FPS, 5); HANDLE hThread; hThread=CreateThread(NULL,0,FunProc1,(LPVOID)this,0,NULL); CloseHandle(hThread); } ``` 线程函数如下: ``` DWORD WINAPI CtestDlg::FunProc1(LPVOID lp) { CtestDlg* dlg=(CtestDlg*)lp; CWnd* wnd=(CWnd*)lp; CClientDC dc(wnd&&m_flag); RECT rect; (wnd->GetDlgItem(IDC_PTC))->GetWindowRect(&rect); wnd->ScreenToClient(&rect); img=cvQueryFrame(capture); CvvImage cvImg; while(img&&m_flag) { cvImg.CopyOf(img); cvImg.DrawToHDC(dc,&rect); img=cvQueryFrame(capture); } cvImg.Destroy(); return 1; } ``` 那么问题来了: 这样在线程函数开头插入断点"调试运行"对话框显示时就可以看到相机实时采集图像显示在图片控件内。 但是如果直接点“开始执行(不调试)”,目前所知有2种情况: 1、用USB接口相机,图片控件上不显示相机采集的视频。 2、用笔记本自带相机,图片控件上显示相机采集的视频。 这是为什么?还有下面2个问题如下: 3、“调试运行”对话框按正常流程退出。“开始执行(不调试)”对话框时不时的不正常退出(任务管理器可以看到程序在后台运行)。 4、如果把创建线程的函数放入到一个按钮里面,那么2个相机采集的视频都可以正常显示在图片控件里面。 望大神解答一下上面的疑问,我是自己没事自学的,没什么水平。
mfc调用mysql数据库时,如何在listbox上逐行显示调用的数据库的表中的内容呢?
RT。 已经成功实现了在控件上按一下鼠标就能调用指定的数据库。 但是对于调用的数据库中的特定的表如何在listbox上逐行显示还是不知道怎么做。。。 其实已经查了博客园和CSDN等等了,但是没有讲的很清楚的。 唯一一个博客园给了代码,按照他的方法调试了下发现没声明两个变量(不知道啥意思啊) 博客园提供的代码经过我改进后如下,如果有人能看懂,希望能指出问题: (不知道ItemName和nCount分别代表什么,没有声明啊) ``` void CthirdstepDlg::OnBnClickedRealresearch() //按钮button的函数 { // TODO: 在此添加控件通知处理程序代码 //初始化数据库对象 pConn = mysql_init(NULL); //localhost:服务器地址,可以直接填入IP;root:账号; //123:密码;test:数据库名;3306:网络端口 if (!mysql_real_connect(pConn, "localhost", "root", "wtk123", "jeesite", 3306, NULL, 0)) { AfxMessageBox(_T("数据库连接失败!")); return; } else//连接成功则继续访问数据库,之后的相关操作代码基本是放在这里面的 { AfxMessageBox(_T("数据库连接成功!")); UpdateData(true); //设置数据库字符格式,解决中文乱码问题 mysql_query(pConn, "set names 'gb2312'"); int t; // 执行 sql 语句 char research_query[200]={0}; CString choose_name; m_researchname.GetWindowText(choose_name); //获取输入静态文本框的字符串 strcpy(research_query,select_head); strcat(research_query,"zd_resourse"); strcat(research_query," where name like '%"); strcat(research_query,choose_name); strcat(research_query,"%'"); strcat(research_query,""); t = mysql_query(pConn,research_query); res = mysql_store_result(pConn); while (res!=NULL) { if (NULL!=(row=mysql_fetch_row(res))) { if (row[0]!=NULL) { ItemName[nCount++]=row[0];//不知道ItemName和nCount分别代表什么,没有声明啊 m_Filelist.AddString(row[0]); } } else { break; } } // while(row = mysql_fetch_row(res)) // { // printf("%s %s\n",row[1],row[2]); // } mysql_free_result(res); mysql_close(pConn); } } UpdateData(false); mysql_close(pConn);//关闭Mysql连接 } ``` 我的大致思路就是先创建一个空表,然后用for循环从i=0开始,逐行调用AddString函数来显示,然而具体怎么操作就不知道了——希望懂的人能贴一下代码,感激不尽!!!
vs2010 MFC CWMPPlayer4类媒体播放
基于对话框的程序,在子对话框中添加media player控件手动绑定,绑定的变量调用CWMPPlayer4类函数如set_URL在执行时出现 ASSERT(m_pCtrlSite != NULL); // not an OLE control (not yet, at least) 求解 万分感谢
mfc VC 想请各位帮忙看下问题出在哪里 在list控件上显示不出我所想要的文件夹名称
void Cdm_01Dlg::TravelFolder(CString strDir, int nDepth) { CFileFind filefind; //声明CFileFind类型变量 CString strWildpath = strDir + _T("//*.*"); //所有文件都列出。 int i = 0; CListCtrl *pList = (CListCtrl*)GetDlgItem(IDC_LIST); pList -> InsertItem(0, _T("")); if(filefind.FindFile(strWildpath, 0)) //开始检索文件 { BOOL bRet = TRUE; while(bRet) { bRet = filefind.FindNextFile(); //枚举一个文件 if(filefind.IsDots()) //如果是. 或 .. 做下一个 continue; if(!filefind.IsDirectory()) //不是子目录,把文件名打印出来 { CString strTextOut = strDir + CString(_T("//")) + filefind.GetFileName(); pList->SetItemText(i, 0, strTextOut); i++; //m_StrOut += strTextOut; //m_StrOut += _T("\r\n"); } else //如果是子目录,递归调用该函数 { CString strTextOut = strDir + CString(_T("//")) + filefind.GetFileName(); pList->SetItemText(i, 0, strTextOut); i++; TravelFolder(strTextOut, nDepth + 1);//递归调用该函数打印子目录里的文件 } } filefind.Close(); } } ``` ``` ``` ``` ``` ``` ``` ```
MFC中加入DataTimePicker控件后,编译通过但运行出错。
# 问题描述 我使用MFC AppWizard创建了一个SDI应用‘test’,未勾选ActiveX控件,其它为默认设置。然后为CTestView类添加成员变量CString m_strName,创建对话框类CTestDialog,并使用向导为其添加成员变量CTime m_dataTime(自动添加DDX函数)。 之后,在CTestView::OnDraw(CDC* pDC)中创建CTestDialog对象dlg,使用DoModal生成窗口后,对m_strName重新赋值。编译通过,但运行出错。 在Debug的时候发现,调用了DoModal之后, **对话框出现之后,点击OK按钮后**,原本保存m_strName地址的那部分内存(4字节)内容会被修改,导致找不到m_strName的值(新地址越界了,原地址指向的内容没变)。 **而在我单独使用EditBox控件的时候则不会出现这样的问题,所以我想知道这中间发生了什么,有什么区别以及该如何正确使用DataTimePicker控件。** # 代码部分 ## testView.h![图片说明](https://img-ask.csdn.net/upload/201612/11/1481429627_441826.jpg) ``` // testView.h : interface of the CTestView class // ///////////////////////////////////////////////////////////////////////////// #if !defined(AFX_TESTVIEW_H__85D7C03F_39A6_4535_80A5_5E109333D12B__INCLUDED_) #define AFX_TESTVIEW_H__85D7C03F_39A6_4535_80A5_5E109333D12B__INCLUDED_ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 class CTestView : public CView { protected: // create from serialization only CTestView(); DECLARE_DYNCREATE(CTestView) // Attributes public: CTestDoc* GetDocument(); CString m_strName; // Operations public: // Overrides // ClassWizard generated virtual function overrides //{{AFX_VIRTUAL(CTestView) public: virtual void OnDraw(CDC* pDC); // overridden to draw this view virtual BOOL PreCreateWindow(CREATESTRUCT& cs); protected: virtual BOOL OnPreparePrinting(CPrintInfo* pInfo); virtual void OnBeginPrinting(CDC* pDC, CPrintInfo* pInfo); virtual void OnEndPrinting(CDC* pDC, CPrintInfo* pInfo); //}}AFX_VIRTUAL // Implementation public: virtual ~CTestView(); #ifdef _DEBUG virtual void AssertValid() const; virtual void Dump(CDumpContext& dc) const; #endif protected: // Generated message map functions protected: //{{AFX_MSG(CTestView) // NOTE - the ClassWizard will add and remove member functions here. // DO NOT EDIT what you see in these blocks of generated code ! //}}AFX_MSG DECLARE_MESSAGE_MAP() }; #ifndef _DEBUG // debug version in testView.cpp inline CTestDoc* CTestView::GetDocument() { return (CTestDoc*)m_pDocument; } #endif ///////////////////////////////////////////////////////////////////////////// //{{AFX_INSERT_LOCATION}} // Microsoft Visual C++ will insert additional declarations immediately before the previous line. #endif // !defined(AFX_TESTVIEW_H__85D7C03F_39A6_4535_80A5_5E109333D12B__INCLUDED_) ``` ## testView.cpp ``` // testView.cpp : implementation of the CTestView class // #include "stdafx.h" #include "test.h" #include "testDoc.h" #include "testView.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CTestView IMPLEMENT_DYNCREATE(CTestView, CView) BEGIN_MESSAGE_MAP(CTestView, CView) //{{AFX_MSG_MAP(CTestView) // NOTE - the ClassWizard will add and remove mapping macros here. // DO NOT EDIT what you see in these blocks of generated code! //}}AFX_MSG_MAP // Standard printing commands ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint) ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint) ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview) END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CTestView construction/destruction CTestView::CTestView() { // TODO: add construction code here m_strName="0000"; } CTestView::~CTestView() { } BOOL CTestView::PreCreateWindow(CREATESTRUCT& cs) { // TODO: Modify the Window class or styles here by modifying // the CREATESTRUCT cs return CView::PreCreateWindow(cs); } ///////////////////////////////////////////////////////////////////////////// // CTestView drawing void CTestView::OnDraw(CDC* pDC) { CTestDoc* pDoc = GetDocument(); ASSERT_VALID(pDoc); // TODO: add draw code for native data here CTestDialog dlg; dlg.DoModal(); m_strName="11111"; } ///////////////////////////////////////////////////////////////////////////// // CTestView printing BOOL CTestView::OnPreparePrinting(CPrintInfo* pInfo) { // default preparation return DoPreparePrinting(pInfo); } void CTestView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/) { // TODO: add extra initialization before printing } void CTestView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/) { // TODO: add cleanup after printing } ///////////////////////////////////////////////////////////////////////////// // CTestView diagnostics #ifdef _DEBUG void CTestView::AssertValid() const { CView::AssertValid(); } void CTestView::Dump(CDumpContext& dc) const { CView::Dump(dc); } CTestDoc* CTestView::GetDocument() // non-debug version is inline { ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CTestDoc))); return (CTestDoc*)m_pDocument; } #endif //_DEBUG ///////////////////////////////////////////////////////////////////////////// // CTestView message handlers ``` ## Dialogs.h ``` #if !defined(AFX_DIALOGS_H__32ACF32B_B56E_4CFB_A5AE_E6F2F343DF92__INCLUDED_) #define AFX_DIALOGS_H__32ACF32B_B56E_4CFB_A5AE_E6F2F343DF92__INCLUDED_ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 // Dialogs.h : header file // ///////////////////////////////////////////////////////////////////////////// // CTestDialog dialog class CTestDialog : public CDialog { // Construction public: CTestDialog(CWnd* pParent = NULL); // standard constructor // Dialog Data //{{AFX_DATA(CTestDialog) enum { IDD = IDD_DIALOG1 }; CTime m_dateTime; //}}AFX_DATA // Overrides // ClassWizard generated virtual function overrides //{{AFX_VIRTUAL(CTestDialog) protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support //}}AFX_VIRTUAL // Implementation protected: // Generated message map functions //{{AFX_MSG(CTestDialog) // NOTE: the ClassWizard will add member functions here //}}AFX_MSG DECLARE_MESSAGE_MAP() }; //{{AFX_INSERT_LOCATION}} // Microsoft Visual C++ will insert additional declarations immediately before the previous line. #endif // !defined(AFX_DIALOGS_H__32ACF32B_B56E_4CFB_A5AE_E6F2F343DF92__INCLUDED_) ``` ## Dialogs.cpp ``` // Dialogs.cpp : implementation file // #include "stdafx.h" #include "test.h" #include "Dialogs.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CTestDialog dialog CTestDialog::CTestDialog(CWnd* pParent /*=NULL*/) : CDialog(CTestDialog::IDD, pParent) { //{{AFX_DATA_INIT(CTestDialog) m_dateTime = 0; //}}AFX_DATA_INIT } void CTestDialog::DoDataExchange(CDataExchange* pDX) { CDialog::DoDataExchange(pDX); //{{AFX_DATA_MAP(CTestDialog) DDX_DateTimeCtrl(pDX, IDC_DATETIMEPICKER1, m_dateTime); //}}AFX_DATA_MAP } BEGIN_MESSAGE_MAP(CTestDialog, CDialog) //{{AFX_MSG_MAP(CTestDialog) // NOTE: the ClassWizard will add message map macros here //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CTestDialog message handlers ```
MFC 错误 LNK2001 无法解析的外部符号
// SerialTest3Dlg.h : 头文件 // #pragma once #include "afxwin.h" #include "mscomm2.h" #include "stdint.h" #include "stdafx.h" // CSerialTest3Dlg 对话框 class CSerialTest3Dlg : public CDialogEx { // 构造 public: CSerialTest3Dlg(CWnd* pParent = NULL); // 标准构造函数 // 对话框数据 #ifdef AFX_DESIGN_TIME enum { IDD = IDD_SERIALTEST3_DIALOG }; #endif protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现 protected: HICON m_hIcon; // 生成的消息映射函数 virtual BOOL OnInitDialog(); afx_msg void OnSysCommand(UINT nID, LPARAM lParam); afx_msg void OnPaint(); afx_msg HCURSOR OnQueryDragIcon(); DECLARE_MESSAGE_MAP() private: CString m_EditReceive;//接收框 CString m_Editsend;//发送框 CComboBox m_comb1;//COM口下拉框 public: CComboBox m_comb2;//波特率下拉框 CMscomm2 m_mscom;//串口控件 afx_msg void OnBnClickedButtonOpen();//打开按钮 afx_msg void OnBnClickedButtonCleanup();//清楚按钮 afx_msg void OnBnClickedButtonClose();//关闭按钮 DECLARE_EVENTSINK_MAP() void OnCommMscomm1();//串口按钮(隐形) CEdit m_Edit; CString m_interpretingdata;//解析数据 afx_msg void OnBnClickedButton5();//发送按钮 }; typedef struct FPGA_INFO_REPORT { uint8_t bWorkMode; //当前工作模式0x00表示初始模式0x01表示扫频模式0x02表示闭环驱动和检测模式0x03表示开环驱动和检测模式0x04表示连续Q值计算模式 uint8_t bCheckMode; //当前检测类型0x01表示开环检测0x02表示闭环检测调试0x03表示闭环检测0x04表示正交校正模式 uint8_t bADMagTimes; //检测信号放大倍数 uint32_t dwSweepTime; //扫频完成时间,毫秒 float fSweepFreq; //扫频得到的谐振频率 float fSweepFreqAmpl; //扫频谐振频率对应的驱动反馈信号幅值 float fDriSignalFreq; //驱动信号频率 float fDriSignalAmpl; //驱动信号幅度 float fDriveFbAmpl; //驱动反馈信号幅度 float fDriveFbPhase; //驱动反馈信号相位 float fBalSignalAmpl; //力平衡信号幅度 float fBalSignalPhase; //力平衡信号相位 float fCheckSignalAmpl; //检测信号幅度 float fCheckSignalPhase; //检测信号相位 float fCheckSignalPalst; //角速度 }FPGA_INFO_REPORT1; // SerialTest3Dlg.cpp : 实现文件 // #include "stdafx.h" #include "SerialTest3.h" #include "SerialTest3Dlg.h" #include "afxdialogex.h" #include <stdlib.h> #include "parser.h" #include <string.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() // CSerialTest3Dlg 对话框 CSerialTest3Dlg::CSerialTest3Dlg(CWnd* pParent /*=NULL*/) : CDialogEx(IDD_SERIALTEST3_DIALOG, pParent) , m_EditReceive(_T("")) , m_Editsend(_T("")) , m_interpretingdata(_T("")) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); } void CSerialTest3Dlg::DoDataExchange(CDataExchange* pDX) { CDialogEx::DoDataExchange(pDX); DDX_Text(pDX, IDC_EDIT_Rev, m_EditReceive); DDX_Text(pDX, IDC_EDIT_Tev, m_Editsend); DDX_Control(pDX, IDC_COMBO2, m_comb1); DDX_Control(pDX, IDC_COMBO3, m_comb2); DDX_Control(pDX, IDC_MSCOMM2, m_mscom); DDX_Control(pDX, IDC_EDIT_Rev, m_Edit); DDX_Text(pDX, IDC_EDIT16, m_interpretingdata); } BEGIN_MESSAGE_MAP(CSerialTest3Dlg, CDialogEx) ON_WM_SYSCOMMAND() ON_WM_PAINT() ON_WM_QUERYDRAGICON() ON_BN_CLICKED(IDC_BUTTON_OPEN, &CSerialTest3Dlg::OnBnClickedButtonOpen) ON_BN_CLICKED(IDC_BUTTON_CLEANUP, &CSerialTest3Dlg::OnBnClickedButtonCleanup) ON_BN_CLICKED(IDC_BUTTON_CLOSE, &CSerialTest3Dlg::OnBnClickedButtonClose) //ON_BN_CLICKED(IDC_BUTTON1, &CSerialTest3Dlg::OnBnClickedButton1) ON_BN_CLICKED(IDC_BUTTON5, &CSerialTest3Dlg::OnBnClickedButton5) END_MESSAGE_MAP() // CSerialTest3Dlg 消息处理程序 BOOL CSerialTest3Dlg::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: 在此添加额外的初始化代码 // 串口选择组合框 CString str; int i; for (i = 0; i < 5; i++) { str.Format(_T("com %d"), i + 1); m_comb1.InsertString(i, str); } m_comb1.SetCurSel(0);//预置COM口 // 波特率选择组合框 CString str1[] = { _T("4800"),_T("9600"),_T("19200"),_T("38400"),_T("43000"),_T("56000"),_T("57600"),_T("115200") }; for (int i = 0; i < 8; i++) { int judge_tf = m_comb2.AddString(str1[i]); if ((judge_tf == CB_ERR) || (judge_tf == CB_ERRSPACE)) MessageBox(_T("build baud error!")); } m_comb2.SetCurSel(7);//预置波特率为"115200" return TRUE; // 除非将焦点设置到控件,否则返回 TRUE } void CSerialTest3Dlg::OnSysCommand(UINT nID, LPARAM lParam) { if ((nID & 0xFFF0) == IDM_ABOUTBOX) { CAboutDlg dlgAbout; dlgAbout.DoModal(); } else { CDialogEx::OnSysCommand(nID, lParam); } } // 如果向对话框添加最小化按钮,则需要下面的代码 // 来绘制该图标。 对于使用文档/视图模型的 MFC 应用程序, // 这将由框架自动完成。 void CSerialTest3Dlg::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 CSerialTest3Dlg::OnQueryDragIcon() { return static_cast<HCURSOR>(m_hIcon); } void CSerialTest3Dlg::OnBnClickedButtonOpen()//打开串口 按钮程序 { // TODO: 在此添加控件通知处理程序代码 CString str, str1, n; //定义字符串 GetDlgItemText(IDC_BUTTON_OPEN, str); CWnd *h1; h1 = GetDlgItem(IDC_BUTTON_OPEN); //指向控件的caption if (!m_mscom.get_PortOpen()) { m_comb2.GetLBText(m_comb2.GetCurSel(), str1);//取得所选的字符串,并存放在str1里面 str1 = str1 + ',' + 'n' + ',' + '8' + ',' + '1'; //这句话很关键 m_mscom.put_CommPort((m_comb1.GetCurSel() + 1)); //选择串口 m_mscom.put_InputMode(1); //设置输入方式为二进制方式 m_mscom.put_Settings(str1); //波特率为(波特率组合框)无校验,8数据位,1个停止位 m_mscom.put_InputLen(1024); //设置当前接收区数据长度为1024 m_mscom.put_RThreshold(1); //缓冲区一个字符引发事件 m_mscom.put_RTSEnable(1); //设置RT允许 m_mscom.put_PortOpen(true); //打开串口 if (m_mscom.get_PortOpen()) { str = _T("关闭串口"); UpdateData(true); h1->SetWindowText(str); //改变按钮名称为“关闭串口” } } else { m_mscom.put_PortOpen(false); if (str != _T("打开串口")) { str = _T("打开串口"); UpdateData(true); h1->SetWindowText(str); //改变按钮名称为打开串口 } } } void CSerialTest3Dlg::OnBnClickedButtonCleanup()//清除数据按钮 { // TODO: 在此添加控件通知处理程序代码 m_EditReceive = _T(""); //给接收编辑框发送空格符 UpdateData(false); //更新数据 } void CSerialTest3Dlg::OnBnClickedButtonClose()//退出按钮 { // TODO: 在此添加控件通知处理程序代码 m_EditReceive = _T(""); //给接收编辑框发送空格符 UpdateData(false); //更新数据 } BEGIN_EVENTSINK_MAP(CSerialTest3Dlg, CDialogEx) ON_EVENT(CSerialTest3Dlg, IDC_MSCOMM2, 1, CSerialTest3Dlg::OnCommMscomm1, VTS_NONE) END_EVENTSINK_MAP() //CString temp; void CSerialTest3Dlg::OnCommMscomm1()//串口控件(按钮) { // TODO: 在此处添加消息处理程序代码 if (m_mscom.get_CommEvent() == 2) { char str[2048] = { 0 }; long k; CString temp; VARIANT InputData = m_mscom.get_Input(); //读缓冲区 COleSafeArray fs; fs = InputData; //VARIANT型变量转换为COleSafeArray型变量 for (k = 0; k < fs.GetOneDimSize(); k++) { fs.GetElement(&k, str + k); //转换为BYTE型数组 temp.Format(L"%02X",(char*)(str + k));//输出显示16进制 m_EditReceive += temp; // 接收到数据显示在编辑框里面 } SetTimer(1,10,NULL); //延时10ms UpdateData(false); m_Edit.SetSel(-1, 1); this->SetDlgItemTextW(IDC_EDIT_Rev, m_EditReceive);//将接收框内容显示到最后位置 m_Edit.LineScroll(m_Edit.GetLineCount() - 1, 0);//将垂直滚动条滚动到最后一行 FPGA_INFO_REPORT1 info; memcpy(&info, str, sizeof(str)); CString str2; str2.Format(L"当前工作模式:%c\n", info.bWorkMode, "当前检测类型:%c\n", info.bCheckMode, "检测信号放大倍数:%c\n", info.bADMagTimes, "扫频完成时间:%c\n", info.dwSweepTime, "扫频得到的谐振频率:%f\n", info.fSweepFreq, "扫频谐振频率对应的驱动反馈信号幅值:%f\n", info.fSweepFreqAmpl, "驱动信号频率:%f\n", info.fDriSignalFreq, "驱动信号幅度:%f\n", info.fDriSignalAmpl, "驱动反馈信号幅度:%f\n", info.fDriveFbAmpl, "力平衡信号幅度:%f\n", info.fBalSignalAmpl, "力平衡信号相位:%f\n", info.fBalSignalPhase, "检测信号幅度:%f\n", info.fCheckSignalAmpl, "检测信号相位:%f\n", info.fCheckSignalPhase, "角速度:%f\n", info.fCheckSignalPalst); m_interpretingdata =str2; } } void CSerialTest3Dlg::OnBnClickedButton5() { // TODO: 在此添加控件通知处理程序代码 UpdateData(true); //更新控件数据 m_mscom.put_Output(COleVariant(m_Editsend));//把发送编辑框的数据发送出去 } 以上代码报错 :错误 LNK2001 无法解析的外部符号 "public: virtual struct CRuntimeClass * __thiscall CMscomm2::GetRuntimeClass(void)const " (?GetRuntimeClass@CMscomm2@@UBEPAUCRuntimeClass@@XZ) SerialTest3 C:\Users\LFY\Desktop\SerialTest3\SerialTest3\SerialTest3Dlg.obj 1 是什么原因
MFC中视频流内存泄漏问题
void CHLDlg::OnBnClickedOpen() { // TODO: 在此添加控件通知处理程序代码 CFileDialog dlg(TRUE,NULL,NULL,NULL,NULL); pCapture = NULL; if(dlg.DoModal()==IDOK)// { PathName = dlg.GetPathName(); FileName = dlg.GetFileName(); } else { return; } c=(LPCSTR)PathName; pCapture = cvCaptureFromFile(c); video_fps=(int)cvGetCaptureProperty(pCapture,CV_CAP_PROP_FPS); hThread2 = CreateThread(NULL,0,Wavedisplay,(LPVOID)this,0,NULL); } DWORD WINAPI CHLDlg::Wavedisplay(LPVOID lpParam) { CHLDlg *p=(CHLDlg *)lpParam; p->SetTimer(1,(int)(1000/p->video_fps),NULL); return 0; } void CHLDlg::OnTimer(UINT_PTR nIDEvent) { // TODO: 在此添加消息处理程序代码和/或调用默认值 CDialogEx::OnTimer(nIDEvent); if(1==nIDEvent) { Frame_Img = cvQueryFrame( pCapture ); } } 程序如上,变量都封装在CHLDlg类里面,析构函数里将它们一一释放,为什么程序运行后内存一直以每秒8kb的速度上升?
无法从“CString”转换为“LPCSTR
目的是利用文件对话框,在MFC对话框中加载一副图片。代码从别的项目拷贝 过来的,原项目可以编译通过,但是在我新建的项目中就提示出错,提示mPath无法从CString转换为LPCSTR,这个要怎么解决呀? void CMat_openimgDlg::OnBnClickedopen() { // TODO: 在此添加控件通知处理程序代码 // TODO: 在此添加控件通知处理程序代码 CFileDialog dlg(TRUE, _T("*.jpg"), NULL, OFN_FILEMUSTEXIST | OFN_PATHMUSTEXIST | OFN_HIDEREADONLY, NULL, NULL); // 选项图片的约定 dlg.m_ofn.lpstrTitle = _T("打开实时图"); // 打开文件对话框的标题名 dlg.m_ofn.lpstrFilter=_T("image files (*.jpg) \0*.jpg\0image files (*.bmp)\0*.bmp\0All Files (*.*) \0*.*"); if( dlg.DoModal() != IDOK ) // 判断是否获得图片 return; CString mPath = dlg.GetPathName(); // 获取图片路径 # m_mat1 = cv::imread( LPCSTR(mPath), 1 ); // 读取图片、缓存到一个局部变量 ipl 中 if( !m_mat1.data ) // 判断是否成功载入图片 return; DrawMatToHDC( m_mat1, IDC_Showing ); // 调用显示图片函数 } void CMat_openimgDlg::DrawMatToHDC(cv::Mat img, UINT ID)//------对应新版Mat 的显示函数 { CDC *pDC = GetDlgItem(ID)->GetDC(); HDC hDC= pDC->GetSafeHdc(); CRect rect; GetDlgItem(ID)->GetClientRect(&rect); CvvImage cimg; IplImage ipm = img; cimg.CopyOf(&ipm); cimg.DrawToHDC_SCALE(hDC,&rect); ReleaseDC(pDC); }
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!
本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star!【Java学习 面试指南】 一份涵盖大部分Java程序员所需要掌握的核心知识。欢迎 Star!)。 另外推荐一篇原创:终极推荐!可能是最适合你的Java学习路线 方法 网站 书籍推荐! Java 并发基础常见面试题总结 1. 什么是线程和进程? 1.1. 何为进程? 进程是程...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
iOS Bug 太多,苹果终于坐不住了!
开源的 Android 和闭源的 iOS,作为用户的你,更偏向哪一个呢? 整理 | 屠敏 出品 | CSDN(ID:CSDNnews) 毋庸置疑,当前移动设备操作系统市场中,Android 和 iOS 作为两大阵营,在相互竞争的同时不断演进。不过一直以来,开源的 Android 吸引了无数的手机厂商涌入其中,为其生态带来了百花齐放的盛景,但和神秘且闭源的 iOS 系统相比,不少网友...
神经⽹络可以计算任何函数的可视化证明
《Neural Networks and Deep Learning》读书笔记第四篇本章其实和前面章节的关联性不大,所以大可将本章作为小短文来阅读,当然基本的深度学习基础还是要有的。主要介绍了神经⽹络拥有的⼀种普遍性,比如说不管目标函数是怎样的,神经网络总是能够对任何可能的输入,其值(或者说近似值)是网络的输出,哪怕是多输入和多输出也是如此,我们大可直接得出一个结论:不论我们想要计算什么样的函数,...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
关于裁员几点看法及建议
最近网易裁员事件引起广泛关注,昨天网易针对此事,也发了声明,到底谁对谁错,孰是孰非?我们作为吃瓜观众实在是知之甚少,所以不敢妄下定论。身处软件开发这个行业,近一两年来,对...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
相关热词 c# 时间比天数 c# oracle查询 c# 主动推送 事件 c# java 属性 c# 控制台 窗体 c# 静态类存值 c#矢量作图 c#窗体调用外部程式 c# enum是否合法 c# 如何卸载引用
立即提问