亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? advanced_checkbox.shtml

?? mfc資源大全包含MFC編程各個方面的源碼
?? SHTML
字號:
<HTML>
<HEAD>
   <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
   <META NAME="Author" CONTENT="Zafir Anjum">
   <META NAME="GENERATOR" CONTENT="Mozilla/4.0 [en] (WinNT; I) [Netscape]">
   <TITLE>CTreeCtrl: Adding Advanced Checkbox</TITLE>
</HEAD>
<body background="../fancyhome/back.gif" bgcolor="#FFFFFF" link="#B50029" vlink="#8E2323" alink="#FF0000" bgproperties="fixed">
<table WIDTH="100%">
<tr WIDTH="100%">
<td align=center><!--#exec cgi="/cgi/ads.cgi"--><td>
</tr>
</table>


<CENTER>
<H3>
<FONT COLOR="#AOAO99">Adding Advanced Checkbox</FONT></H3></CENTER>

<CENTER>
<H3>

<HR></H3></CENTER>
In the previous topic we covered how to implement a simple checkbox for each item in the tree control. In this topic we cover a slightly different implementation. The checkbox for each item will indicate whether the item is checked or not and it will also indicate whether any of its descendant is checked or not. The main reason for visually indicating whether a descendant is checked is that it is easier for the user to determine if there are checked items in the outline and if there is a checked item, it is easy to navigate to it.
<p><img src="advanced_check.gif" border="1" width="213" height="131"></p>

<H4>Step 1: Create bitmap with checkbox images</H4>
Create a bitmap that will provide the images needed for the checkbox. The images in the bitmap below are 13x13 pixels. The first image is blank since this bitmap is going to be used for the state image list. The next image indicates an unchecked item. The third image indicates a checked item. The fourth image indicates an unchecked item but conveys that at least one of the descendant item is checked. The fifth image indicates a checked item and also indicates that at least one of the descendant item is checked.
<P><IMG SRC="state_images.gif" HEIGHT=15 WIDTH=75>
<BR>

<H4>Step 2: Initialize the state image list</H4>
Setting up state images has been covered in a previous topic. If the tree control class has a member variable m_imageState then here's how to set the image list.
<PRE><TT><FONT COLOR="#990000">
	m_tree.m_imageState.Create( IDB_STATE, 13, 1, RGB(255,255,255) );
	m_tree.SetImageList( &(m_tree.m_imageState), TVSIL_STATE );
</FONT></TT></PRE>
<BR>
<H4>Step 3: Insert items with the checkbox as a state image</H4>
If you are using TV_INSERTSTRUCT to insert an item into the tree control, then specify the state and the stateMask in the TV_ITEM member. The index of the state image is specified by using the macro INDEXTOSTATEIMAGEMASK. You can also use the SetItemState() function.

<P><PRE><TT><FONT COLOR="#990000">
SetItemState( hItem, INDEXTOSTATEIMAGEMASK(1), TVIS_STATEIMAGEMASK );
</FONT></TT></PRE>
<BR>

<H4>Step 4: Add enumeration for check operation and state</H4>
Since we are dealing with four different check states, it makes the code more readable if we define an enumeration for the different states. We also define an enumeration to list the different operations on the check state.

<PRE><TT><FONT COLOR="#990000">
// Attributes
public:
	enum CheckState{ NOSTATE = 0, UNCHECKED, CHECKED, CHILD_CHECKED, 
		SELF_AND_CHILD_CHECKED };
	enum CheckType{ CHECK, UNCHECK, TOGGLE, REFRESH };
</FONT></TT></PRE>
<BR>

<H4>Step 5: Define SetCheck() function</H4>
When we check an item, the parent items are also updated to indicate that a descendant is checked. Similarly, when we uncheck an item, the parents item have to be updated again. We may also need to update the parents state if an item is moved.

<P>Depending on the value of nCheck, the function determines what the new state of the item should be. If nCheck is REFRESH, only the immediate children items are scanned to determine if the checkbox should be red ( to indicate that a child is checked ). The function then updates the parent items.

<PRE><TT><FONT COLOR="#990000">
// SetCheck	- Check, uncheck, toggle or refresh an item
// hItem	- Item that is to be updated
// nCheck	- CHECK, UNCHECK, TOGGLE OR REFRESH 
BOOL CTreeCtrlX::SetCheck( HTREEITEM hItem, CheckType nCheck )
{
	if( hItem == NULL ) 
		return FALSE;

	UINT nState = GetItemState( hItem, TVIS_STATEIMAGEMASK ) >> 12;

	// Determine the new check state
	if ( nCheck == CHECK )
	{
		if( nState == CHECKED || nState == SELF_AND_CHILD_CHECKED )
			return TRUE;
		switch( nState )
		{
		case UNCHECKED:		nState = CHECKED; break;
		case CHILD_CHECKED:		nState = SELF_AND_CHILD_CHECKED; break;
		}
	}
	else if( nCheck == UNCHECK )
	{
		if( nState == UNCHECKED || nState == CHILD_CHECKED )
			return TRUE;
		switch( nState )
		{
		case CHECKED:			nState = UNCHECKED; break;
		case SELF_AND_CHILD_CHECKED:	nState = CHILD_CHECKED; break;
		}
	}
	else if( nCheck == TOGGLE )
	{
		switch( nState )
		{
		case UNCHECKED:		nState = CHECKED; break;
		case CHECKED:			nState = UNCHECKED; break;
		case CHILD_CHECKED:		nState = SELF_AND_CHILD_CHECKED; break;
		case SELF_AND_CHILD_CHECKED:	nState = CHILD_CHECKED; break;
		}
	}
	else if( nCheck == REFRESH )
	{
		// Scan children to determine new state
		BOOL bChildSelected = FALSE;
		HTREEITEM htiChild = GetChildItem( hItem );

		// Scan children
		while( htiChild )
		{
			UINT nChildState = GetItemState( htiChild, 
						TVIS_STATEIMAGEMASK ) >> 12;
			if( nChildState != UNCHECKED && nChildState != NOSTATE )
			{
				bChildSelected = TRUE;
				break;
			}
			htiChild = GetNextItem( htiChild, TVGN_NEXT );
		}
		if( bChildSelected )
		{
			if( nState == CHECKED ) nState = SELF_AND_CHILD_CHECKED;
			else if( nState == UNCHECKED ) nState = CHILD_CHECKED;
		}
		else
		{
			if( nState == SELF_AND_CHILD_CHECKED ) nState = CHECKED;
			else if( nState == CHILD_CHECKED ) nState = UNCHECKED;
		}
	}

	SetItemState( hItem, INDEXTOSTATEIMAGEMASK(nState), 
					TVIS_STATEIMAGEMASK );

	if( nState == CHECKED 
		|| ( REFRESH 
			&& (nState == SELF_AND_CHILD_CHECKED 
				|| nState == CHILD_CHECKED)
			)
		)
	{
		// Mark the parents to indicate that a child item is selected.
		// Use checkbox with red border.
		while( (hItem = GetParentItem( hItem )) != NULL )
		{
			nState = GetItemState( hItem, TVIS_STATEIMAGEMASK ) >> 12;
			if( nState == UNCHECKED )
				SetItemState( hItem, INDEXTOSTATEIMAGEMASK(CHILD_CHECKED), 
						TVIS_STATEIMAGEMASK );
			else if ( nState == CHECKED )
				SetItemState( hItem,
					INDEXTOSTATEIMAGEMASK(SELF_AND_CHILD_CHECKED), 
					TVIS_STATEIMAGEMASK );
		}
	}
	else if( nState == UNCHECKED )
	{
		// Maybe the parent ( ancestors ) state needs to be adjusted if
		// no more children selected.
		while( (hItem = GetParentItem( hItem )) != NULL )
		{
			BOOL bChildSelected = FALSE;
			HTREEITEM htiChild = GetChildItem( hItem );

			// Scan children
			while( htiChild )
			{
				UINT nChildState = GetItemState( htiChild, 
							TVIS_STATEIMAGEMASK ) >> 12;
				if( nChildState != UNCHECKED && nChildState != NOSTATE )
				{
					bChildSelected = TRUE;
					break;
				}
				htiChild = GetNextItem( htiChild, TVGN_NEXT );
			}
			if( bChildSelected )
			{
				// The parent does not need to be updated
				// since there are other children still selected
				break;
			}
			else
			{
				// The parent item has no more children selected. 
				// Mark accordingly
				UINT nParentState = GetItemState( hItem, 
							TVIS_STATEIMAGEMASK ) >> 12;
				if( nParentState == CHILD_CHECKED )
					SetItemState( hItem, 
							INDEXTOSTATEIMAGEMASK(UNCHECKED), 
							TVIS_STATEIMAGEMASK );
				else if ( nParentState == SELF_AND_CHILD_CHECKED )
					SetItemState( hItem, INDEXTOSTATEIMAGEMASK(CHECKED), 
							TVIS_STATEIMAGEMASK );
			}
		}
 	}                                                                                                              
	return TRUE;
}
</FONT></TT></PRE>
<BR>

<H4>Step 6: Add code to OnLButtonDown to toggle checkbox</H4>
When the user clicks on the checkbox, then the checkbox state has to be toggled. We use the HitTest() function to determine if the click was on the checkbox. 

<PRE><TT><FONT COLOR="#990000">
void CTreeCtrlX::OnLButtonDown(UINT nFlags, CPoint point) 
{
	UINT uFlags=0;
	HTREEITEM hItem = HitTest(point,&uFlags);

	if( uFlags & TVHT_ONITEMSTATEICON )
	{
		SetCheck( hItem, TOGGLE );
		return;
	}
}
</FONT></TT></PRE>
<BR>

<H4>Step 7: Add code to OnKeyDown to toggle checkbox</H4>
This step provides the keyboard interface for checking and unchecking an item. The key used is usually the space key, so we will use the space key. The code is nearly the same as in the previous step. Instead of using HitTest() to determine the item handle, we use the function GetSelectedItem().

<PRE><TT><FONT COLOR="#990000">
void CTreeCtrlX::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags) 
{
	if( nChar == VK_SPACE )
	{
		HTREEITEM hItem = GetSelectedItem();
		SetCheck( hItem, TOGGLE );
		return;
	}
}
</FONT></TT></PRE>
<BR>

<H4>Step 8: Define helper functions</H4>
Define helper functions to determine whether an item is checked or not and to iterate through the checked items. The purpose of the functions is very clear from the function names. The GetFirstCheckedItem() and the GetNextCheckedItem() are optimized. They look at the item state before deciding whether it should search the children items. The GetPrevCheckedItem() function searches sequentially through all items. I leave it as an exercise to optimize this function.

<PRE><TT><FONT COLOR="#990000">
BOOL CTreeCtrlX::IsItemChecked(HTREEITEM hItem)
{
	int iImage = GetItemState( hItem, TVIS_STATEIMAGEMASK )>>12;
	return iImage == CHECKED || iImage == SELF_AND_CHILD_CHECKED;
}

HTREEITEM CTreeCtrlX::GetFirstCheckedItem()
{
	for ( HTREEITEM hItem = GetRootItem(); hItem!=NULL;  )
	{
		int iImage = GetItemState( hItem, TVIS_STATEIMAGEMASK )>>12;
		if ( iImage == CHECKED || iImage == SELF_AND_CHILD_CHECKED )
			return hItem;
		
		if( iImage != CHILD_CHECKED )
		{
			HTREEITEM hti = GetNextItem( hItem, TVGN_NEXT );
			if( hti == NULL )
				hItem = GetNextItem( hItem );
			else 
				hItem = hti;
		}
		else
			hItem = GetNextItem( hItem );
	}

	return NULL;
}

HTREEITEM CTreeCtrlX::GetNextCheckedItem( HTREEITEM hItem )
{
	hItem = GetNextItem( hItem );
	while( hItem!=NULL )
	{
		int iImage = GetItemState( hItem, TVIS_STATEIMAGEMASK )>>12;
		if ( iImage == CHECKED || iImage == SELF_AND_CHILD_CHECKED )
			return hItem;
		
		if( iImage != CHILD_CHECKED )
		{
			HTREEITEM hti = GetNextItem( hItem, TVGN_NEXT );
			if( hti == NULL )
				hItem = GetNextItem( hItem );
			else 
				hItem = hti;
		}
		else
			hItem = GetNextItem( hItem );
	}

	return NULL;
}

HTREEITEM CTreeCtrlX::GetPrevCheckedItem( HTREEITEM hItem )
{
	for ( hItem = GetPrevItem( hItem ); hItem!=NULL; hItem = GetPrevItem( hItem ) )
		if ( IsItemChecked(hItem) )
			return hItem;

	return NULL;
}

</FONT></TT></PRE>
<BR>

<P>The GetNextItem() function with single argument and the GetPrevItem() function have been 
defined earlier in the <A HREF="get_next.shtml">Get next item in outline</A> and the <A HREF="get_prev.shtml">Get previous item in outline</A> topics.

<P>
<HR>
<TABLE BORDER=0 WIDTH="100%" >
<TR>
<TD WIDTH="33%"><FONT SIZE=-1><A HREF="http://www.codeguru.com">Goto HomePage</A></FONT></TD>

<TD WIDTH="33%">
<CENTER><FONT SIZE=-2>&copy; 1998 Zafir Anjum</FONT>&nbsp;</CENTER>
</TD>

<TD WIDTH="34%">
<DIV ALIGN=right><FONT SIZE=-1>Contact me: <A HREF="mailto:zafir@home.com">zafir@home.com</A>&nbsp;</FONT></DIV>
</TD>
</TR>
</TABLE>
</BODY>
</HTML>

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区在线免费观看| 在线欧美日韩国产| 午夜欧美2019年伦理| 亚洲日本va在线观看| 国产女主播视频一区二区| www成人在线观看| 欧美大片在线观看一区二区| 日韩精品最新网址| 久久蜜桃av一区精品变态类天堂 | 丝袜诱惑亚洲看片| 婷婷六月综合亚洲| 久久99精品久久只有精品| 久久精品国产99久久6| 国产一区二区三区高清播放| 国产盗摄精品一区二区三区在线 | 91在线视频观看| 色欲综合视频天天天| 欧美色精品在线视频| 欧美一区二区高清| 国产视频一区不卡| 亚洲最新在线观看| 免费成人在线观看视频| 国产999精品久久久久久| 97久久精品人人做人人爽| 欧美三级视频在线观看| 久久先锋影音av| 亚洲天堂免费在线观看视频| 天天色综合成人网| 国产精品一二三四| 日本久久一区二区三区| 日韩欧美激情一区| 亚洲色图.com| 美腿丝袜亚洲综合| 91在线免费看| 日韩精品一区在线| 亚洲精品乱码久久久久久日本蜜臀| 亚洲国产成人高清精品| 国产美女精品人人做人人爽| 91久久精品日日躁夜夜躁欧美| 日韩欧美一二区| 日韩久久一区二区| 国产永久精品大片wwwapp| 色94色欧美sute亚洲线路二| 亚洲精品在线网站| 午夜免费久久看| 国产不卡视频在线观看| 欧美另类z0zxhd电影| 中文字幕成人av| 天堂久久一区二区三区| 91免费版pro下载短视频| 久久综合狠狠综合久久综合88 | 色婷婷国产精品| 久久综合给合久久狠狠狠97色69| 亚洲精品写真福利| 国产传媒欧美日韩成人| 日韩视频中午一区| 一二三四社区欧美黄| 丰满亚洲少妇av| 91精品国产aⅴ一区二区| 亚洲色图欧美偷拍| 成人美女视频在线观看| 欧美r级在线观看| 天堂一区二区在线免费观看| 欧美性大战久久| 亚洲日本一区二区三区| caoporn国产精品| 久久久久九九视频| 国内精品写真在线观看| 日韩欧美国产一二三区| 日本伊人色综合网| 欧美丰满美乳xxx高潮www| 亚洲综合图片区| 色婷婷综合激情| 亚洲美女免费视频| 色先锋aa成人| 亚洲激情网站免费观看| 欧美在线观看禁18| 亚洲国产综合91精品麻豆| 欧美唯美清纯偷拍| 午夜久久久久久电影| 欧美日韩大陆在线| 日韩高清不卡一区二区| 欧美一二三区在线| 精品一区二区三区不卡| 久久久久久久久久电影| proumb性欧美在线观看| 日韩伦理电影网| 欧美视频一区二区在线观看| 午夜视频在线观看一区| 欧美日韩国产首页| 美美哒免费高清在线观看视频一区二区 | 91精品国产综合久久福利| 日韩av中文字幕一区二区三区| 91精品国产一区二区三区香蕉| 蜜桃视频在线一区| 国产欧美一区二区三区网站| 成人一二三区视频| 亚洲免费观看高清完整版在线| 欧美在线观看视频在线| 久久精品国产亚洲一区二区三区| 久久毛片高清国产| 94-欧美-setu| 日韩激情一二三区| 欧美激情综合五月色丁香| 色诱亚洲精品久久久久久| 偷拍日韩校园综合在线| 久久青草国产手机看片福利盒子| eeuss鲁片一区二区三区| 亚洲成人一区在线| 久久一区二区视频| 欧美综合久久久| 久久99国产精品尤物| 亚洲色图丝袜美腿| 欧美电影免费观看高清完整版在线观看| 国产在线播放一区三区四| 亚洲乱码中文字幕| 337p粉嫩大胆色噜噜噜噜亚洲| caoporn国产一区二区| 蜜臀久久99精品久久久画质超高清| 久久久久国产精品免费免费搜索| 91黄视频在线| 国产美女一区二区| 日韩专区中文字幕一区二区| 中文字幕一区二区三区不卡| 欧美一级日韩一级| 色婷婷激情一区二区三区| 国产精品一区不卡| 免费黄网站欧美| 亚洲精品久久7777| 国产精品无遮挡| 欧美xxxxxxxx| 欧美丝袜自拍制服另类| 成人永久aaa| 国产精品亚洲视频| 美女网站在线免费欧美精品| 一区二区在线观看视频| 国产精品毛片大码女人| 日韩美女一区二区三区四区| 欧美午夜在线一二页| 91网址在线看| 不卡的av中国片| 国产福利不卡视频| 黄页网站大全一区二区| 蜜桃视频一区二区三区| 亚洲午夜精品久久久久久久久| 国产精品麻豆久久久| 国产视频911| 久久精品视频网| 精品国产网站在线观看| 91精品国产乱| 日韩午夜在线播放| 欧美不卡一区二区三区| 欧美一区日韩一区| 91精品国产高清一区二区三区 | 激情文学综合插| 蜜桃一区二区三区四区| 蜜臀久久久久久久| 精品无人区卡一卡二卡三乱码免费卡 | 日韩一区二区在线观看| 日韩欧美一二三区| 久久久99精品久久| 国产精品久久毛片a| 亚洲欧美自拍偷拍色图| 亚洲精品日韩一| 亚洲一区二区偷拍精品| 日日骚欧美日韩| 蜜乳av一区二区| 国产成人av电影免费在线观看| av中文字幕一区| 欧美在线影院一区二区| 国产蜜臀av在线一区二区三区| 久久久久久麻豆| 最新不卡av在线| 香港成人在线视频| 狠狠色狠狠色综合| 99久久国产免费看| 欧美日韩国产免费| 2欧美一区二区三区在线观看视频| 国产日韩欧美麻豆| 亚洲一区二区在线观看视频| 久久精品国产亚洲a| 波多野结衣精品在线| 欧美精品日韩精品| 日本一区二区三区四区| 亚洲国产欧美另类丝袜| 国产在线麻豆精品观看| 色呦呦国产精品| 精品免费国产二区三区| 亚洲婷婷国产精品电影人久久| 三级不卡在线观看| 94-欧美-setu| 精品少妇一区二区三区视频免付费| 中文字幕一区二区视频| 青娱乐精品视频| 99久久99久久免费精品蜜臀| 日韩一区二区三区精品视频| 国产精品成人免费精品自在线观看 | 国产精品天干天干在线综合| 三级一区在线视频先锋 | 亚洲精品乱码久久久久久|