学习2

来源:互联网 发布:钉钉saas的数据架构 编辑:程序博客网 时间:2024/05/16 10:23

该函数获得有关指定窗口的信息,
函数也获得在额外窗口内存中指定偏移地址的32位长整型值。
LONG   GetWindowLong(HWND   hWnd,int   nindex);
hwnd:
窗口句柄及间接给出的窗口所属的窗口类。

函数功能:该函数获得有关指定窗口的信息,函数也获得在额外窗口内存中指定偏移位地址的32位度整型值。

       
函数原型:LONG   GetWindowLongHWND   hWndint   nlndex);

       
参数:

        hWnd:
窗口句柄及间接给出的窗口所属的窗口类。

        nlndex
:指定要获得值的大于等于0的值的偏移量。有效值的范围从0到额外窗口内存空间的字节数一4例如,若指定了12位或多于12位的额外类存储空间,则应设为第三个32位整数的索引位8。要获得任意其他值,指定下列值之一:

        GWL_EXSTYLE
;获得扩展窗日风格。

        GWL_STYLE
:获得窗口风格。

        GWL_WNDPROC
:获得窗口过程的地址,或代表窗口过程的地址的句柄。必须使用GWL_WNDPROC函数调用窗口过程。

        GWL_HINSTANCE
:获得应用事例的句柄。

        GWL_HWNDPAAENT
:如果父窗口存在,获得父窗口句柄。

        GWL_ID:
获得窗口标识。

        GWL_USERDATA
:获得与窗口有关的32位值。每一个窗口均有一个由创建该窗口的应用程序使用的32位值。

       
hWnd参数标识了一个对话框时也可用下列值:

        DWL_DLGPROC
:获得对话框过程的地址,或一个代表对话框过程的地址的句柄。必须使用函数CallWindowProc来调用对话框过程。

        DWL_MSGRESULT
:获得在对话框过程中一个消息处理的返回值。

        DWL_USER
:获得应用程序私有的额外信息,例如一个句柄或指针。

       
返回值:如果函数成功,返回值是所需的32位值;如果函数失败,返回值是0。若想获得更多错误信息请调用   GetLastError函数。

       
备注:通过使用函数RegisterClassEx将结构WNDCLASSEX中的cbWndExtra单元指定为一个非0值来保留额外类的存储空间。

 

 

1. CListCtrl 样式及设置

2. 扩展样式设置

3. 数据插入

4. 一直选中Item

5. 选中和取消选中Item

6. 得到CListCtrl中所有行的checkbox的状态

7. 得到CListCtrl中所有选中行的序号

8. 得到item的信息

9. 得到CListCtrl的所有列的header字符串内容

10. 使CListCtrl中一项可见,即滚动滚动条

11. 得到CListCtrl列数

12. 删除所有列

13. 得到单击的CListCtrl的行列号

14. 判断是否点击在CListCtrlcheckbox

15. 右键点击CListCtrlitem弹出菜单

16. CListCtrl进行大数据量更新时,避免闪烁

!时间仓促,此播客内容大多为网上整理,特向原作者表示感谢!


--------------------------------------------------------------------------------

1. CListCtrl 样式及设置
 LVS_ICON:
每个item显示大图标
 LVS_SMALLICON:
每个item显示小图标
 LVS_LIST:
显示一列带有小图标的item
 LVS_REPORT:
显示item详细资料

 windows资源管理器,查看标签下的大图标,小图标,列表,详细资料

 LONG lStyle;
 lStyle=GetWindowLong(m_ListCtrl.m_hWnd, GWL_STYLE); //
获取当前窗口style
 lStyle &= ~LVS_TYPEMASK; //
清除显示方式位
 lStyle |= LVS_REPORT; //
设置style
 SetWindowLong(m_ListCtrl.m_hWnd, GWL_STYLE, lStyle); //
设置style


--------------------------------------------------------------------------------

2. 扩展样式设置


 DWORD dwStyle = m_ListCtrl.GetExtendedStyle(); //
获取当前扩展样式
 dwStyle |= LVS_EX_FULLROWSELECT; //
选中某行使整行高亮(report风格时)
 dwStyle |= LVS_EX_GRIDLINES; //
网格线(report风格时)
 dwStyle |= LVS_EX_CHECKBOXES; //item
前生成checkbox控件
 m_ListCtrl.SetExtendedStyle(dwStyle); //
设置扩展风格


--------------------------------------------------------------------------------

3. 数据插入

 m_ListCtrl.InsertColumn(0,"名称",LVCFMT_LEFT,50); //插入列
 m_ListCtrl.InsertColumn(1,"
备注",LVCFMT_LEFT,50);

//直接插入:

 int nRow=m_ListCtrl.InsertItem(0,"VC++");        //插入行
 m_ListCtrl.SetItemText(nRow,1,"Visual C++ 6.0");  //
设置数据

//LVITEM 结构插入:

 LVITEM item={0};
 item.iItem=0;  //
行号
 item.mask=LVIF_TEXT; ;
 item.cchTextMax=15
//插入字符串长度
 item.pszText="Visual C++ 6.0";

 int nRow=m_ListCtrl.InsertItem(&item);

 m_ListCtrl.SetItemText(nRow,1,"Visual C++6.0");


--------------------------------------------------------------------------------

4. 一直选中Item

 选中style中的 Show selection always,

 或者添加扩展样式 LVS_SHOWSELALWAYS


--------------------------------------------------------------------------------

5. 选中和取消选中Item
 int nIndex = 0;
 //
选中
  m_ListCtrl.SetItemState(nIndex,LVIS_SELECTED

 LVIS_FOCUSED,LVIS_SELECTED|LVIS_FOCUSED);
 //
取消选中
  m_ListCtrl.SetItemState(nIndex,0,LVIS_SELECTED|LVIS_FOCUSED);


--------------------------------------------------------------------------------

6. 得到CListCtrl中所有行的checkbox的状态
 CString str;
 for(int i=0; i<m_ListCtrl.GetItemCount(); i++)

{
   if(m_ListCtrl.GetItemState(i, LVIS_SELECTED)==

   LVIS_SELECTED || m_ListCtrl.GetCheck(i))
   {
     str.Format(_T("
%d行的checkbox为选中状态"), i);
     AfxMessageBox(str);
    }

}


--------------------------------------------------------------------------------

7. 得到CListCtrl中所有选中行的序号

//方法一:
  CString str;
  for(int i=0; i<m_ListCtrl.GetItemCount(); i++)
  {
    if(m_ListCtrl.GetItemState(i, LVIS_SELECTED) ==LVIS_SELECTED )
    {
      str.Format(_T("
选中了第%d"), i);
      AfxMessageBox(str);
     }
   }

//方法二:
  POSITION pos=m_ListCtrl.GetFirstSelectedItemPosition();
  if(pos==NULL)
   TRACE0("No items were selected!/n");
  else
  {
   while(pos)
    {
      int nItem=m_ListCtrl.GetNextSelectedItem(pos);
      TRACE1("Item %d was selected!/n",nItem);
      //
添加其他操作

}
   }


--------------------------------------------------------------------------------

8. 得到item的信息
 TCHAR szBuf[1024];
 LVITEM lvi;
 lvi.iItem = nItemIndex;
 lvi.iSubItem = 0;
 lvi.mask = LVIF_TEXT;
 lvi.pszText = szBuf;
 lvi.cchTextMax = 1024;
 m_ListCtrl.GetItem(&lvi);

关于得到设置item的状态,还可以参考msdn文章
 Q173242: Use Masks to Set/Get Item States in CListCtrl
 http://support.microsoft.com/kb/173242/en-us


--------------------------------------------------------------------------------

9. 得到CListCtrl的所有列的header字符串内容
 LVCOLUMN lvcol;
 char  str[256];
 int   nColNum;
 CString strColumnName[3];//
假如有3

 nColNum = 0;
 lvcol.mask = LVCF_TEXT;
 lvcol.pszText = str;
 lvcol.cchTextMax = 256;
 while(m_list.GetColumn(nColNum, &lvcol))
 {
   strColumnName[nColNum] = lvcol.pszText;
   nColNum++;
  }


--------------------------------------------------------------------------------

10. 使CListCtrl中一项可见,即滚动滚动条
  m_ListCtrl.EnsureVisible(i, FALSE);


--------------------------------------------------------------------------------

11. 得到CListCtrl列数
 int nHeadNum=m_ListCtrl.GetHeaderCtrl()->GetItemCount();


--------------------------------------------------------------------------------

12. 删除所有列
 
方法一:
  while(m_ListCtrl.DeleteColumn(0))
  //
因为你删除了第一列后,后面的列会依次向上移动。

方法二:
  int nColumns = 3; //
列数
  for(int i=nColumns-1; i>=0; i--)

  m_ListCtrl.DeleteColumn(i);


--------------------------------------------------------------------------------

13. 得到单击的CListCtrl的行列号
 
添加listctrl控件的NM_CLICK消息相应函数
 void CMyDlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
 {
  //
方法一:

  DWORD dwPos=GetMessagePos();
  CPoint point( LOWORD(dwPos), HIWORD(dwPos));

  m_ListCtrl.ScreenToClient(&point);

  LVHITTESTINFO lvinfo;
  lvinfo.pt=point;
  lvinfo.flags=LVHT_ABOVE;

  int nItem=m_ListCtrl.SubItemHitTest(&lvinfo);
  if(nItem!=-1)
  {
    CString strtemp;
    strtemp.Format("
单击的是第%d行第%d",

    lvinfo.iItem, lvinfo.iSubItem);
    AfxMessageBox(strtemp);
   }

// 方法二:
    NM_LISTVIEW* pNMListView=(NM_LISTVIEW*)pNMHDR;
    if(pNMListView->iItem!=-1)
  {

    CString strtemp;
    strtemp.Format("
单击的是第%d行第%d",
    pNMListView->iItem, pNMListView->iSubItem);
    AfxMessageBox(strtemp);
   }

    *pResult = 0;

}


--------------------------------------------------------------------------------

14. 判断是否点击在CListCtrlcheckbox
 
添加listctrl控件的NM_CLICK消息相应函数
 void CMyDlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
 {

DWORD dwPos=GetMessagePos();
   CPoint point(LOWORD(dwPos), HIWORD(dwPos));

m_ListCtrl.ScreenToClient(&point);

LVHITTESTINFO lvinfo;
   lvinfo.pt=point;
   lvinfo.flags=LVHT_ABOVE;
    
   UINT nFlag;
   int nItem=m_ListCtrl.HitTest(point, &nFlag);
   //
判断是否点在checkbox
   if(nFlag==LVHT_ONITEMSTATEICON)
   {
     AfxMessageBox("
点在listctrlcheckbox");
   }
   *pResult = 0;
 }


--------------------------------------------------------------------------------

15. 右键点击CListCtrlitem弹出菜单
 
添加CListCtrl控件的NM_RCLICK消息相应函数
 void CMyDlg::OnRclickList1(NMHDR* pNMHDR, LRESULT* pResult)
 {
   NM_LISTVIEW* pNMListView=(NM_LISTVIEW*)pNMHDR;
   if(pNMListView->iItem!=-1)
   {
     DWORD dwPos = GetMessagePos();
     CPoint point( LOWORD(dwPos), HIWORD(dwPos) );

 

CMenu menu;
     VERIFY( menu.LoadMenu( IDR_MENU1 ) );
     CMenu* popup = menu.GetSubMenu(0);
     ASSERT( popup != NULL );
     popup->TrackPopupMenu(TPM_LEFTALIGN |TPM_RIGHTBUTTON,

point.x, point.y, this );

}
    *pResult = 0;

}


--------------------------------------------------------------------------------

16. CListCtrl进行大数据量更新时,避免闪烁
 m_ListCtrl.SetRedraw(FALSE);
 //
更新内容
 m_ListCtrl.SetRedraw(TRUE);
 m_ListCtrl.Invalidate();
 m_ListCtrl.UpdateWindow();

LVS_TYPEMASK LVS_ICON+LVS_SMALLICON+LVS_LIST+LVS_REPORT四种风格的集合。这样当我们用当前的风格”“not LVS_TYPEMASK”就等于清除了当前的显示风格。