打开一个普通的资源管理器后,我想用程序取得该资源管理器中所列出的所有文件名。我先使用FindWindow一级级找下去,找到了列文件的那个窗口的句柄hWnd.然后我用这样几句代码:CListCtrl* pCtrl = (CListCtrl*)FromHandle(hWnd);//得到该句柄窗口的指针int iHeaderCount = pCtrl->GetHeaderCtrl()->GetItemCount();//取得列的数目.可以得到正确的列数.int iItemCount = pCtrl->GetItemCount();//取得所有文件的总个数。可以得到正确的文件个数。但是取文件名的时候却总是得到空值:
CString strResult = pCtrl->GetItemText(0,0);
这里得到的strResult始终都是空值。不知道是为什么,请教各位高手,如何才能取到文件名呢?
CString strResult = pCtrl->GetItemText(0,0);
这里得到的strResult始终都是空值。不知道是为什么,请教各位高手,如何才能取到文件名呢?
解决方案 »
- 动态生成的CStatic控件,设置其父窗口为桌面后无法相应消息
- windows消息机制的问题
- ado 如何查询access中的数据
- 关于Jpeg文件头的问题
- vc60和vcnet的MFC各是什么版本,.net与60相比较有什么具体区别?
- 请给我推荐几本关于用VC写动态库的书或网站,要求介绍的比较详细,从基础开始
- 能不能改变自定义消息处理函数的参数
- MFC activex web控件显示的网页部分电脑点击链接无效
- 加密解密程序为何在Debug和Release版本下效果不一样?Keywords:encrypt decrypt
- 瞧一瞧 看一看 有关模板类的大疑问
- 如何利用ole删除excel中的整行数据?
- GetAdaptersInfo返回0x57如何解决?
0,0是根,试试
CString strResult = pCtrl->GetItemText(1,0);
CString strResult = pCtrl->GetItemText(0,1);
等看看
for(int j=0; j<iHeaderCount; j++)
strResult = pCtrl->GetItemText(i,j);
TCHAR lpBuffer[256];
bool fFound = false; hdi.mask = HDI_TEXT;
hdi.pszText = lpBuffer;
hdi.cchTextMax = 256;
pmyHeaderCtrl->GetItem(iCol, &hdi);
CString strResult =hdi.pszText;
CHeaderCtrl *pmyHeaderCtrl;
pmyHeaderCtrl=pCtrl->GetHeaderCtrl();//此句取得CListCtrl控件的列表頭
iCol代表第几列。这是获得CListCtrl控件的列表頭标题的代码。不知道不是要这个
LVITEM item;
item.mask = LVIF_TEXT;
item.item = 0;
item.subitem = 0;
ListView_GetItem(窗口句柄,&item);
来取值,但是取到的 item.pzsText 仍然是空值.继续求教~~
刚才找到了一篇文件刚好就是讲这个的,还是自己先去看看算了。结帖,谢谢以上各位。
作者:unknown 更新时间: 2005-05-13
//---------------------------------------------------------------------------
// 读取ListView中的Item
// hWindow为目标ListView的句柄
// strlist用来存放ListView的Item字符串
// 来自http://www.ccrun.com
// by ccrun(老妖)
//---------------------------------------------------------------------------
void MyGetListViewItem(HWND hWindow,TStrings *strlist)
{
const nMaxLen=1023;
char szBuf[nMaxLen+1]; int nLVItemCount;
DWORD dwProcessID;
HANDLE hProcess;
LVITEM lvItemLocal;
DWORD dwBytesRead, dwBytesWrite;
bool bSuccess,bWriteOK; //注意:本文来自www.ccrun.com,by ccrun(老妖),转载请注明出处。
//为防止某些不负责任的转载者,故出此下策,在代码中加入声明,请大家原谅。 GetWindowThreadProcessId(hWindow,&dwProcessID);
hProcess=OpenProcess(PROCESS_ALL_ACCESS,FALSE,dwProcessID);
if(!hProcess) //得不到指定进程的句柄
return;
//在指定进程内分配存储空间
LPVOID lpTextRemote=VirtualAllocEx(hProcess,NULL,nMaxLen+1,MEM_COMMIT,PAGE_READWRITE);
LPVOID lpListItemRemote=VirtualAllocEx(hProcess,NULL,sizeof(LVITEM),MEM_COMMIT,PAGE_READWRITE);
if((!lpTextRemote) || (!lpListItemRemote)) //不能在指定进程内分配存储空间
return; nLVItemCount=ListView_GetItemCount(hWindow);
strlist->Add("Welcome to www.ccrun.com");
strlist->Add("ListView的Item总数: " + String(nLVItemCount));
strlist->Add("---------------------------"); for(int i=0;i<nLVItemCount;i++)
{
ZeroMemory(szBuf,nMaxLen+1);
bWriteOK= WriteProcessMemory(hProcess,lpTextRemote,(LPVOID)szBuf,nMaxLen+1,(LPDWORD)&dwBytesWrite);
if(!bWriteOK) //写内存错误
return;
lvItemLocal.iItem=i;
lvItemLocal.iSubItem=0;
lvItemLocal.mask=LVIF_TEXT;
lvItemLocal.cchTextMax=nMaxLen;
lvItemLocal.pszText=(LPTSTR)lpTextRemote;
dwBytesWrite=0;
bWriteOK=WriteProcessMemory(hProcess,lpListItemRemote,(LPVOID)&lvItemLocal,sizeof(LVITEM),(LPDWORD)&dwBytesWrite);
if(!bWriteOK) //写内存错误
return; SendMessage(hWindow,LVM_GETITEMTEXT,(WPARAM)i,(LPARAM)lpListItemRemote);
bSuccess=ReadProcessMemory(hProcess,lpTextRemote,szBuf,nMaxLen+1,&dwBytesRead);
//从指定进程存储空间读取文本
if(!bSuccess) //不能在指定进程内读取文本
return;
strlist->Add(AnsiString(szBuf));
}//end of for(i)
//在指定进程内释放存储空间
VirtualFreeEx(hProcess,lpListItemRemote,0,MEM_RELEASE);
VirtualFreeEx(hProcess,lpTextRemote,0,MEM_RELEASE);
//关闭指定进程句柄
CloseHandle(hProcess);
}调用的时候这样:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
MyGetListViewItem((void *)0x000100DC,Memo1->Lines);
}上面的((void *)0x000100DC是我用MiniSpy取得的桌面的名柄(win2000下的桌面是个ListView),在实际调用时换成你取得的ListView的句柄即可。并且在上面的这段代码只是获取ListView的Item的Caption的。
如
HWND hListView;
//....获取ListView的句柄
MyGetListViewItem(hListView,Memo1->Lines); 如果其ViewStyle为vsReport,就要考虑读取ListView的HeadItem了。呵呵。GoodLuck.