MFC操作

[MFC]选择目录对话框和选择文件对话框 - My C++ - C++博客

在MFC编程中经常会需要用到选择目录和选择文件的界面,以下总结一下本人常用的这两种对话框的生成方法:

选择目录对话框

//选择目录按钮
void CDcPackerDlg::OnBnClickedDecgen()    
{
    char szPath[MAX_PATH];     //存放选择的目录路径 
    CString str;

    ZeroMemory(szPath, sizeof(szPath));   

    BROWSEINFO bi;   
    bi.hwndOwner = m_hWnd;   
    bi.pidlRoot = NULL;   
    bi.pszDisplayName = szPath;   
    bi.lpszTitle = "请选择需要打包的目录:";   
    bi.ulFlags = 0;   
    bi.lpfn = NULL;   
    bi.lParam = 0;   
    bi.iImage = 0;   
    //弹出选择目录对话框
    LPITEMIDLIST lp = SHBrowseForFolder(&bi);   

    if(lp && SHGetPathFromIDList(lp, szPath))   
    {
        str.Format("选择的目录为 %s",  szPath);
        AfxMessageBox(str); 

        
    }
    else   
        AfxMessageBox("无效的目录,请重新选择");   
}

选择文件对话框

CString CDcPackerDlg::BootOpenDialog()   //返回选择的文件名称
{
    CString strFile = _T("");

    CFileDialog    dlgFile(TRUE, NULL, NULL, OFN_HIDEREADONLY, _T("Describe Files (*.cfg)|*.cfg|All Files (*.*)|*.*||"), NULL);

    if (dlgFile.DoModal())
    {
        strFile = dlgFile.GetPathName();
    }

    return strFile;
}

//加载文件按钮
void CDcPackerDlg::OnBnClickedSelectdec()
{
    // TODO: Add your control notification handler code here
    m_strDescPath = "";        //类的成员变量

    //"打开文件"对话框,选择文件,返回其路径
    m_strDescPath = BootOpenDialog();

    
}

posted on 2009-08-27 17:28 

Bluesea

 阅读(24297) 

评论(2) 编辑 收藏 引用

 所属分类: 

MFC
 

转载于:https://www.cnblogs.com/Dennis-mi/articles/4588256.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MFC(Microsoft Foundation Classes)是一个用于开发 Windows 应用程序的 C++ 类库。要操作 SQLite 数据库,可以使用 MFC 提供的数据库类和 SQLite 提供的 API。下面是一个简单的示例代码,演示了如何使用 MFC 操作 SQLite 数据库: ```cpp #include <afxdb.h> // 创建数据库连接 CDatabase db; CString sDriver = _T("SQLite3 ODBC Driver"); CString sDsn; sDsn.Format(_T("ODBC;DRIVER={%s};DSN='';"), sDriver); db.Open(NULL, false, false, sDsn); // 执行 SQL 查询 CString strSql = _T("SELECT * FROM your_table"); CRecordset rs(&db); rs.Open(CRecordset::forwardOnly, strSql); // 遍历结果集 while (!rs.IsEOF()) { // 获取字段值 CString fieldValue; rs.GetFieldValue(_T("your_field_name"), fieldValue); // 处理数据... rs.MoveNext(); } // 关闭结果集和数据库连接 rs.Close(); db.Close(); ``` 在上述代码中,我们首先创建了一个数据库连接 `db`,然后使用 `Open` 方法打开数据库。接下来,使用 `Open` 方法执行 SQL 查询,并将结果保存在一个 `CRecordset` 对象 `rs` 中。然后,我们可以通过 `GetFieldValue` 方法获取每个字段的值,并进行相应的处理。最后,记得关闭结果集和数据库连接。 需要注意的是,上述示例代码仅仅是一个简单的演示,实际开发中可能需要根据具体需求进行适当的修改和扩展。同时,还需要确保已经正确配置了 SQLite ODBC 驱动,以便 MFC 可以正确连接和操作 SQLite 数据库。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值