ListCtrl使用指南

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      {           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      {           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;} 16. item切换焦点时(包括用键盘和鼠标切换item时),状态的一些变化顺序       添加listctrl控件的LVN_ITEMCHANGED消息相应函数      void CTest6Dlg::OnItemchangedList1(NMHDR* pNMHDR, LRESULT* pResult)      {           NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;           // TODO: Add your control notification handler code here               CString sTemp;           if((pNMListView->uOldState & LVIS_FOCUSED) == LVIS_FOCUSED &&             (pNMListView->uNewState & LVIS_FOCUSED) == 0)           {                sTemp.Format("%d losted focus",pNMListView->iItem);           }           else if((pNMListView->uOldState & LVIS_FOCUSED) == 0 &&               (pNMListView->uNewState & LVIS_FOCUSED) == LVIS_FOCUSED)           {                sTemp.Format("%d got focus",pNMListView->iItem);           }            if((pNMListView->uOldState & LVIS_SELECTED) == LVIS_SELECTED &&            (pNMListView->uNewState & LVIS_SELECTED) == 0)           {                sTemp.Format("%d losted selected",pNMListView->iItem);           }           else if((pNMListView->uOldState & LVIS_SELECTED) == 0 &&            (pNMListView->uNewState & LVIS_SELECTED) == LVIS_SELECTED)           {                sTemp.Format("%d got selected",pNMListView->iItem);           }               *pResult = 0;      } 17. 得到另一个进程里的listctrl控件的item内容 http://www.codeproject.com/threads/int64_memsteal.asp 18. 选中listview中的itemQ131284: How To Select a Listview Item Programmaticallyhttp://support.microsoft.com/kb/131284/en-us 19. 如何在CListView中使用CListCtrl的派生类 http://www.codeguru.com/cpp/controls/listview/introduction/article.php/c919/ 20. listctrl的subitem添加图标       m_list.SetExtendedStyle(LVS_EX_SUBITEMIMAGES);      m_list.SetItem(..); //具体参数请参考msdn
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1 目标检测的定义 目标检测(Object Detection)的任务是找出图像中所有感兴趣的目标(物体),确定它们的类别和位置,是计算机视觉领域的核心问题之一。由于各类物体有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具有挑战性的问题。 目标检测任务可分为两个关键的子任务,目标定位和目标分类。首先检测图像中目标的位置(目标定位),然后给出每个目标的具体类别(目标分类)。输出结果是一个边界框(称为Bounding-box,一般形式为(x1,y1,x2,y2),表示框的左上角坐标和右下角坐标),一个置信度分数(Confidence Score),表示边界框中是否包含检测对象的概率和各个类别的概率(首先得到类别概率,经过Softmax可得到类别标签)。 1.1 Two stage方法 目前主流的基于深度学习的目标检测算法主要分为两类:Two stage和One stage。Two stage方法将目标检测过程分为两个阶段。第一个阶段是 Region Proposal 生成阶段,主要用于生成潜在的目标候选框(Bounding-box proposals)。这个阶段通常使用卷积神经网络(CNN)从输入图像中提取特征,然后通过一些技巧(如选择性搜索)来生成候选框。第二个阶段是分类和位置精修阶段,将第一个阶段生成的候选框输入到另一个 CNN 中进行分类,并根据分类结果对候选框的位置进行微调。Two stage 方法的优点是准确度较高,缺点是速度相对较慢。 常见Tow stage目标检测算法有:R-CNN系列、SPPNet等。 1.2 One stage方法 One stage方法直接利用模型提取特征值,并利用这些特征值进行目标的分类和定位,不需要生成Region Proposal。这种方法的优点是速度快,因为省略了Region Proposal生成的过程。One stage方法的缺点是准确度相对较低,因为它没有对潜在的目标进行预先筛选。 常见的One stage目标检测算法有:YOLO系列、SSD系列和RetinaNet等。 2 常见名词解释 2.1 NMS(Non-Maximum Suppression) 目标检测模型一般会给出目标的多个预测边界框,对成百上千的预测边界框都进行调整肯定是不可行的,需要对这些结果先进行一个大体的挑选。NMS称为非极大值抑制,作用是从众多预测边界框中挑选出最具代表性的结果,这样可以加快算法效率,其主要流程如下: 设定一个置信度分数阈值,将置信度分数小于阈值的直接过滤掉 将剩下框的置信度分数从大到小排序,选中值最大的框 遍历其余的框,如果和当前框的重叠面积(IOU)大于设定的阈值(一般为0.7),就将框删除(超过设定阈值,认为两个框的里面的物体属于同一个类别) 从未处理的框中继续选一个置信度分数最大的,重复上述过程,直至所有框处理完毕 2.2 IoU(Intersection over Union) 定义了两个边界框的重叠度,当预测边界框和真实边界框差异很小时,或重叠度很大时,表示模型产生的预测边界框很准确。边界框A、B的IOU计算公式为: 2.3 mAP(mean Average Precision) mAP即均值平均精度,是评估目标检测模型效果的最重要指标,这个值介于0到1之间,且越大越好。mAP是AP(Average Precision)的平均值,那么首先需要了解AP的概念。想要了解AP的概念,还要首先了解目标检测中Precision和Recall的概念。 首先我们设置置信度阈值(Confidence Threshold)和IoU阈值(一般设置为0.5,也会衡量0.75以及0.9的mAP值): 当一个预测边界框被认为是True Positive(TP)时,需要同时满足下面三个条件: Confidence Score > Confidence Threshold 预测类别匹配真实值(Ground truth)的类别 预测边界框的IoU大于设定的IoU阈值 不满足条件2或条件3,则认为是False Positive(FP)。当对应同一个真值有多个预测结果时,只有最高置信度分数的预测结果被认为是True Positive,其余被认为是False Positive。 Precision和Recall的概念如下图所示: Precision表示TP与预测边界框数量的比值 Recall表示TP与真实边界框数量的比值 改变不同的置信度阈值,可以获得多组Precision和Recall,Recall放X轴,Precision放Y轴,可以画出一个Precision-Recall曲线,简称P-R
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值