duilib 如果获取listui 当前选择的项GetCursel

原创 2015年11月17日 22:41:26
<pre name="code" class="cpp">class CDuiFrameWnd : public WindowImplBase
{
public:
	virtual LPCTSTR    GetWindowClassName() const   {   return _T("DUIMainFrame");  }
	virtual CDuiString GetSkinFile()                {   return _T("duilib1.xml");  }
	virtual CDuiString GetSkinFolder()              {   return _T("");  }

	virtual void  InitWindow()
	{

		CDuiString str;
		CListUI* pList = static_cast<CListUI*>(m_PaintManager.FindControl(_T("ListDemo1")));

		// 添加List列表内容,必须先Add(pListElement),再SetText
		for (int i = 0; i < 5; i++)
		{
			CListTextElementUI* pListElement = new CListTextElementUI;
			pListElement->SetTag(i);
			pList->Add(pListElement);

			str.Format(_T("%d"), i);
			pListElement->SetText(0, str);
			pListElement->SetText(1, _T("haha"));
		}
	}

	void Notify(TNotifyUI& msg)
	{
		if (msg.sType == _T("itemclick"))
		{
				CListUI* pList = static_cast<CListUI*>(m_PaintManager.FindControl(_T("ListDemo1")));
				if (pList != NULL)
				{
					int nIndex  = pList->GetCurSel();
					//对于列表框大于2列的情况 用以下方式进行获取两列的值 和进行设置
					//切记 列表框初始化的时候 一定要两列都初始化,否则SetText函数会执行失败
					//如果有大于2列的列表框,xml资源里面切记不要
					/*
					<List name="ListDemo1" float="true" pos="30,314,0,0" width="139" height="218" bkcolor="#FFFFFFFF" itemtextcolor="#FF000000" itembkcolor="#FFE2DDDF" itemselectedtextcolor="#FF000000" itemselectedbkcolor="#FFC1E3FF" itemhottextcolor="#FF000000" itemhotbkcolor="#FFE9F5FF" itemdisabledtextcolor="#FFCCCCCC" itemdisabledbkcolor="#FFFFFFFF" >
					<ListHeader name="domain" bkimage="List/list_header_bg.png">
					<ListHeaderItem text="序号" width="40" height="23" minwidth="16"  sepwidth="1" align="center" hotimage="List/list_header_hot.png" pushedimage="List/list_header_pushed.png" sepimage="List/list_header_sep.png" />
					<ListHeaderItem text="文件名称" width="84" height="23" minwidth="16"  sepwidth="1" align="center" hotimage="List/list_header_hot.png" pushedimage="List/list_header_pushed.png" sepimage="List/list_header_sep.png" />
					</ListHeader>
					<ListLabelElement text="张三1" selected="true" />
					<ListLabelElement text="李四2" />不要这样写 
					否则会导致 pListElement->SetText(0,_T("test1"));pListElement->SetText(1,_T("test2"));执行失败 切记!!!!!
					正确的做法是 将ListLabelElement 初始化去掉 在InitWindow 里面初始化 
					</List>
					*/
					CListTextElementUI* pListElement = static_cast<CListTextElementUI*>(pList->GetItemAt(nIndex));
					if (pListElement != NULL)
					{
						LPCTSTR pstr1 = pListElement->GetText(0);
						LPCTSTR pstr2 = pListElement->GetText(1);

						pListElement->SetText(0,_T("test1"));
						pListElement->SetText(1,_T("test2"));
					}
				}
		}
		return __super::Notify(msg);
	}

 };

int APIENTRY _tWinMain(HINSTANCE hInstance,
	HINSTANCE hPrevInstance,
	LPTSTR    lpCmdLine,
	int       nCmdShow)
{
	HRESULT Hr = ::CoInitialize(NULL);
	if( FAILED(Hr) ) return 0;


	CPaintManagerUI::SetInstance(hInstance);

	CDuiFrameWnd duiFrame;
	duiFrame.Create(NULL, _T("DUIWnd"), UI_WNDSTYLE_FRAME, WS_EX_WINDOWEDGE);
	duiFrame.CenterWindow();
	duiFrame.ShowModal();
	CPaintManagerUI::MessageLoop();
	::CoUninitialize();
	return 0;
}


//xml配置如下:
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<Window size="700,400" caption="0,0,0,30">
    <HorizontalLayout width="400" height="400" bkcolor="#FF0000FF" bkcolor2="#00FF00FF" bordercolor="#00808000" focusbordercolor="#00008080">
      <List name="ListDemo1" float="true" pos="30,314,0,0" width="139" height="218" bkcolor="#FFFFFFFF" itemtextcolor="#FF000000" itembkcolor="#FFE2DDDF" itemselectedtextcolor="#FF000000" itemselectedbkcolor="#FFC1E3FF" itemhottextcolor="#FF000000" itemhotbkcolor="#FFE9F5FF" itemdisabledtextcolor="#FFCCCCCC" itemdisabledbkcolor="#FFFFFFFF" >
        <ListHeader name="domain" bkimage="List/list_header_bg.png">
          <ListHeaderItem text="序号" width="40" height="23" minwidth="16"  sepwidth="1" align="center" hotimage="List/list_header_hot.png" pushedimage="List/list_header_pushed.png" sepimage="List/list_header_sep.png" />
          <ListHeaderItem text="文件名称" width="84" height="23" minwidth="16"  sepwidth="1" align="center" hotimage="List/list_header_hot.png" pushedimage="List/list_header_pushed.png" sepimage="List/list_header_sep.png" />
        </ListHeader>
      </List>
      
    </HorizontalLayout>
</Window>



                    

相关文章推荐

duilib CListUI控件插入内容注意地方

article from lixiangxiang@ajb              公司最近项目由于MFC界面出现无法解决的bug(部分edit自绘导致复选框背景填充失效问题),所以将部分mfc界面...

duilib响应列表双击事件

 if (_tcsicmp(msg.sType, _T("itemactivate")) == 0)  {   MessageBoxA(m_hWnd,0,0,0);  }...

关于duilib中的list的扩展探索

今天在做一个程序的界面时,需要在一个列表中显示除文字以外的其他控件,如:Edit、Button、Combo等;我做界面使用的是duilib,其自带的CListUI并不能满足此向功能,需要进行扩展,在此...

ListCtrl改变选中一行选择的处理

CListCtrl,CListView与LVN_ITEMCHANGED消息 若要在CListCtrl中行发生改变时得到通知,可以映射LVN_ITEMCHANGED消息。   ON_NOTI...

CListUI的改造--支持checkbox

参考:http://blog.csdn.net/tragicguy/article/details/21893065 注意: 此处需要将内嵌控件的ListHeaderItem ...
  • asmcvc
  • asmcvc
  • 2015年11月02日 16:38
  • 1103

duilib 自定义控件TeamList 继承与CListUI

XML 以下是duilib demo加自己的改动 //节点 struct NodeData { int level_;//层数 bool child_visible...

Duilib界面库学习笔记

1.Duilib的下载编译 由于一些事件google无法访问,托管在其上的项目也无法检出也基本无人更新,因此从第三方代码仓库同步下载代码, 地址如下: 1.https://github.com/Co...
  • whatday
  • whatday
  • 2014年12月29日 22:51
  • 9909

duilib list控件扩展

对于简单的list控件已经有前辈分析了自带demo的ListRes全过程,duilib DirectUI库里面的一个简单的例子ListDemo, 他分析了listdemo的来龙去脉,这里我只...

duilib DirectUI库里面的一个简单的例子ListDemo

duilib里面的一个简单的例子ListDemo

duilib list控件扩展

对于简单的list控件已经有前辈分析了自带demo的ListRes全过程,duilib DirectUI库里面的一个简单的例子ListDemo, 他分析了listdemo的来龙去脉,这里我只是将个人...
  • midle110
  • midle110
  • 2014年09月07日 11:48
  • 11101
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:duilib 如果获取listui 当前选择的项GetCursel
举报原因:
原因补充:

(最多只允许输入30个字)