mfc之ListControl控件的使用

以下未经说明,listctrl默认view 风格为report

1. CListCtrl 风格

LVS_ICON: 为每个item显示大图标     

LVS_SMALLICON: 为每个item显示小图标      

LVS_LIST: 显示一列带有小图标的item      

LVS_REPORT: 显示item详细资料

直观的理解:windows资源管理器,“查看”标签下的“大图标,小图标,列表,详细资料”

2. 设置listctrl 风格及扩展风格

LONG lStyle;      

lStyle = GetWindowLong(m_list.m_hWnd, GWL_STYLE);//获取当前窗口style      

lStyle &= ~LVS_TYPEMASK; //清除显示方式位     

 lStyle |= LVS_REPORT; //设置style     

SetWindowLong(m_list.m_hWnd, GWL_STYLE, lStyle);//设置style   

 DWORD dwStyle = m_list.GetExtendedStyle();    

 dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)

 dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)  

 dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件     

  m_list.SetExtendedStyle(dwStyle); //设置扩展风格         注:listview的style请查阅msdn    

   http://msdn.microsoft.com/library/default.asp?url=/library/en-us/wceshellui5/html/wce50lrflistviewstyles.asp

3. 插入数据

    m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列   

    m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 );   

    int nRow = m_list.InsertItem(0, “11”);//插入行  

     m_list.SetItemText(nRow, 1, “jacky”);//设置数据

4. 一直选中item

    选中style中的Show selection always,或者在上面第2点中设置LVS_SHOWSELALWAYS

5. 选中和取消选中一行

int nIndex = 0;     //选中   

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

m_list.SetItemState(nIndex, 0, LVIS_SELECTED|LVIS_FOCUSED);


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

      m_list.SetExtendedStyle(LVS_EX_CHECKBOXES);     

  CString str;   

    for(int i=0; i<m_list.GetItemCount(); i++)   

    {         

   if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED || m_list.GetCheck(i))    

        {              

   str.Format(_T("第%d行的checkbox为选中状态"), i);         

        AfxMessageBox(str);         

   }      

}

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

      方法一:     

  CString str;     

  for(int i=0; i<m_list.GetItemCount(); i++)    

   {         

   if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED )       

     {                

str.Format(_T("选中了第%d行"), i);          

       AfxMessageBox(str);      

      }    

   }

      方法二:     

  POSITION pos = m_list.GetFirstSelectedItemPosition();

      if (pos == NULL)      

      TRACE0("No items were selected!/n");      

else       {          

  while (pos)         

   {             

    int nItem = m_list.GetNextSelectedItem(pos);           

      TRACE1("Item %d was selected!/n", nItem);                 // you could do your own processing on nItem here       

     }    

   }

 

8. 得到item的信息

      TCHAR szBuf[1024];    

   LVITEM lvi;      

lvi.iItem = nItemIndex;   

    lvi.iSubItem = 0;    

   lvi.mask = LVIF_TEXT;   

    lvi.pszText = szBuf;   

    lvi.cchTextMax = 1024;

      m_list.GetItem(&lvi);

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

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

      LVCOLUMN lvcol;  

     char  str[256];    

   int   nColNum;      

CString  strColumnName[4];//假如有4列

      nColNum = 0;   

    lvcol.mask = LVCF_TEXT;      

lvcol.pszText = str;    

   lvcol.cchTextMax = 256;      

while(m_list.GetColumn(nColNum, &lvcol))    

   {           

strColumnName[nColNum] = lvcol.pszText;     

       nColNum++;    

   }

 

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

    m_list.EnsureVisible(i, FALSE);

11. 得到listctrl列数

    int nHeadNum = m_list.GetHeaderCtrl()->GetItemCount();

12. 删除所有列

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

      方法二:       int nColumns = 4;       for (int i=nColumns-1; i>=0; i--)           m_list.DeleteColumn (i);

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

      添加listctrl控件的NM_CLICK消息相应函数    

   void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)   

    {           

// 方法一:           

/*            DWORD dwPos = GetMessagePos();    

        CPoint point( LOWORD(dwPos), HIWORD(dwPos) );         

      m_list.ScreenToClient(&point);          

     LVHITTESTINFO lvinfo;         

   lvinfo.pt = point;        

    lvinfo.flags = LVHT_ABOVE;        

         int nItem = m_list.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. 判断是否点击在listctrl的checkbox上

      添加listctrl控件的NM_CLICK消息相应函数      

void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)      

{          

  DWORD dwPos = GetMessagePos();       

     CPoint point( LOWORD(dwPos), HIWORD(dwPos) );      

         m_list.ScreenToClient(&point);        

       LVHITTESTINFO lvinfo;      

      lvinfo.pt = point;        

    lvinfo.flags = LVHT_ABOVE;       

          UINT nFlag;          

  int nItem = m_list.HitTest(point, &nFlag);           //判断是否点在checkbox上    

        if(nFlag == LVHT_ONITEMSTATEICON)      

      {             

    AfxMessageBox("点在listctrl的checkbox上");   

         }         

   *pResult = 0;     

  }

 

15. 右键点击listctrl的item弹出菜单

      添加listctrl控件的NM_RCLICK消息相应函数     

  void CTest6Dlg::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;

  }

 

  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在MFC中,可以通过List Control控件来显示大小不同的图片。 首先,我们需要添加一个List Control控件到对话框中,并设置它的属性为"Report",这样可以显示多列的数据。接下来,我们需要添加一个列来显示图片,使用InsertColumn函数来添加列并设置其属性。 然后,将图片添加到List Control控件中。可以通过List Control控件的InsertItem函数来插入一个Item,并通过SetItem函数来设置Item的属性,包括图片。对于不同大小的图片,可以使用CImageList类来创建多个不同大小的Image List,并通过List Control控件SetImageList函数来设置不同大小的Image List。 最后,在绘制时,可以通过OnCustomDraw消息来自定义绘制每个Item的内容。在OnCustomDraw事件中,可以获取当前绘制的Item的相关信息,包括图片的位置和大小,然后根据需要来绘制不同大小的图片。 总结起来,使用MFCList Control控件显示大小不同的图片,需要添加List Control控件并设置相关属性,创建不同大小的Image List,并在绘制时根据Item的信息来绘制不同大小的图片。 ### 回答2: 在MFC中,可以使用List Control来显示大小不同的图片。一种常见的方法是将图片绘制在List Control的子项中。 首先,我们需要在List Control中设置图标视图,这样才能显示图片。可以通过调用List Control的`SetView`方法,将视图模式设置为`LV_VIEW_ICON`。 然后,需要为每个子项分配一个图标。可以使用ToolBar控件中的图片资源,或者通过加载指定路径的图片文件来创建图标对象(CImageList类可以实现这一操作)。 接下来,将每个子项的图标插入到List Control中。可以通过调用`InsertItem`方法,并将图标的索引作为参数传递给该方法。 最后,在绘制每个子项时,需要使用自定义的绘制方法来处理不同大小的图片。可以通过继承自CListCtrl类,并重写其OnCustomDraw方法来实现。 在OnCustomDraw方法中,可以获取子项的位置信息,然后使用图标的索引来获取相应的图标对象。根据子项的大小,可以将图标绘制在合适的位置上,从而实现显示不同大小的图片。 总的来说,要在MFCList Control中显示大小不同的图片,我们需要设置图标视图模式、为每个子项分配图标、插入图标,并使用自定义的绘制方法来实现。 ### 回答3: 在MFCList Control中显示不同大小的图片可以通过自定义绘制来实现。以下是一种实现方法: 首先,在List Control中设置合适的列数和行数,并确保每个单元格都有足够的空间来显示图片。 然后,为每个需要显示图片的单元格创建一个自定义绘制子类。该自定义绘制子类继承自CWnd,并重写其中的绘制函数。 在绘制函数中,可以使用MFC中的绘图函数和图像处理功能来绘制和调整图片的大小。例如,可以使用CDC::DrawIconEx()函数来绘制图标,使用CDC::StretchBlt()函数来调整图片的大小。 接下来,在List Control的MeasureItem函数中,为每个单元格设置合适的高度。可以根据图片的大小来设置高度,确保图片能够完整显示。 在List Control的DrawItem函数中,根据需要显示图片的单元格的位置和大小,在对应的位置上使用自定义绘制子类来绘制图片。 最后,通过调用List Control的RedrawItems函数,以触发绘制过程,并在合适的时机更新图片的显示。 需要注意的是,在处理大量图片时,可能会导致性能问题。为了提高性能,可以考虑使用缓存来保存已绘制的图片,避免重复的绘制操作。 总而言之,通过以上的方法,我们可以在MFCList Control中显示不同大小的图片。需要注意的是,这只是一种实现方法,具体的实现方式可能会因具体的需求而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值