在VC中直接调用系统对话框

(这是我第一次发贴,用以前写的一篇文章,用作测试吧)
 昨天我一个同学问我怎么在程序中调用系统的运行对话框,开始觉得应该不难,应该有API函数可用的吧,可是在msdn上找了半天没找到。后来想想可能是MS没公开的函数吧,于是上网搜索一下,看到关于在VB下实现的例子,他是调用shell32.dll的一个没有公开的函数RunFileDlg,不是系统没有公开的函数。如是就把它改到在VC中实现了!编程开始的时候想通过
  GetProcAddress(hLib, "RunFileDlg")
就可以得到这个函数的地址吧!可是跟踪后发现,得到结果总是NULL,后来用W32dsm看了一下发现shell32.dll中没有这个函数,觉得很是奇怪了。后来发现对于系统中没有公开的函数不能直接找到地址,而应该这样调用:
  GetProcAddress(hLib, (char *)"61");  //61 是 RunFileDlg 在 Shell32.dll 中导出位置,这样的话就可以得到函数的地址了!       
代码的实现很简单,代码如下:
 
 //
 CString pszDllName="shell32.dll";
 HINSTANCE hLib = ::LoadLibrary(pszDllName);
 char p[256];
 HICON ico;
 
 //这儿我感觉参数应该是LPCWSTR, 但是网上说得是LPCTSTR
 typedef void (__stdcall *pRunFileDlg)(HWND,HICON, LPCTSTR,    LPCTSTR, LPCTSTR, UINT);
 
 pRunFileDlg RunFileDlg;
 
 if (hLib==NULL)
 {
     return ;
 }
 
 RunFileDlg = (pRunFileDlg)GetProcAddress(hLib, (char *)61);
 
 CString name ="wolfbaby的运行";
 CString sss = "输入程序路径";
 
 LPWSTR wname=new WCHAR[100];
 LPWSTR wsss=new WCHAR[100]; 
 
 memset(wname,0,sizeof(WCHAR)*100);
 memset(wsss,0,sizeof(WCHAR)*100);
 
 MultiByteToWideChar(CP_ACP,
                     MB_PRECOMPOSED,        // character-type options
                     name,                  // address of string to map
                     name.GetLength(),      // number of bytes in string
                     wname,                 // address of wide-character buffer
                     100
  );                                        //必须先转换到宽字符,否则后面调用的时候,结果会不对!
 
 MultiByteToWideChar(CP_ACP,
                     MB_PRECOMPOSED,        // character-type options
                     sss,                   // address of string to map
                     sss.GetLength(),       // number of bytes in string
                     wsss,                  // address of wide-character buffer
                     100
  );
  
 if(RunFileDlg!=NULL)
 {
  RunFileDlg(this->GetSafeHwnd(),
             NULL,
             NULL,
             (LPCTSTR)wname,
             (LPCTSTR)wsss,0x02);       
 }
 ::FreeLibrary(hLib);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值