当前位置: 首页 > 图文教程 > 开发语言 > VC++ > Outlook风格的单列使用不同的颜色显示新邮件数

VC++
面试题目:猫吃老鼠问题的求解
一个最基本的有限元计算程序
简单的表达式求值
C程序移植到VC开发环境下
一个小语言的词法分析程序
A/B 向上取整的方法
马走日棋盘算法
一种随机抽题的简单算法
clone模式在平衡排序二叉树实现中的应用
递归的应用 -- 最简单分形图形实现
比较数据排序前后的查找次数
根据前序和中序序列生成二叉树
如何用CZip/CUnzip类压缩/解压缩文件
使用 random_shuffle() 算法随机化序列元素
Ceb解除打印屏蔽实战
基于SHA-256的HMAC文件校验器
模拟信息加密流程图简介
关于数据校验
浅谈利用RSA算法防止非法注册机的制作
加密它:用新的高级加密标准(AES)保持你的数据安全

VC++ 中的 Outlook风格的单列使用不同的颜色显示新邮件数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 101 ::
收藏到网摘: n/a

Outlook风格的单列使用不同的颜色显示新邮件数

作者 Lazen


下载源代码

当利用业余时间开发完成纷飞(Outplay...)一个类似Outlook的客户端的邮件程序后 , 发现Outlook的新邮件的显示使用单列不同的颜色,酷酷的,于是决定,也该让我的 Outplay如此...

说做就做,就立刻查找了codeguru里的关于CTreeView的文章,找到了一些合适的信息,大概花了30分钟的时间,终于让我的纷飞(Outplay...)也酷了一把。
Follow me,你会发现它是如此的简单和便捷,仅仅需要在你的CTreeView中添加几行代码而已。

该怎么做呢?(as below)

首先假定你的CTreeView派生类CTreeViewEx,然后你需要在TreeViewEx.h中,添加如下行:

afx_msg void OnCustomDraw(NMHDR* pNMHDR, LRESULT* pResult); 
然后你需要在消息映射中添加:
ON_NOTIFY_REFLECT(NM_CUSTOMDRAW, OnCustomDraw) 
在OnCusteomDraw消息处理例程中添加如下代码:
void CLeftView::OnCustomDraw(LPNMHDR pNmhdr, LRESULT* pResult){	static CRect	rcItem;	static int	nItemState;	LPNMTVCUSTOMDRAW pCustomDraw = (LPNMTVCUSTOMDRAW)pNmhdr;	switch (pCustomDraw->nmcd.dwDrawStage)	{	case CDDS_PREPAINT:	// 这种情况必须处理,且必须将pResult设置为 CDRF_NOTIFYITEMDRAW,	// 否则父窗口怎么也收不到 CDDS_ITEMPREPAINT 通知消息 (GGH)	*pResult = CDRF_NOTIFYITEMDRAW;	// 重新定位视图窗口,这样 TreeCtrl 的 DefWindowProc 不会重画	//::SetViewportOrgEx(pCustomDraw->nmcd.hdc, /*m_nOffset*/0, 0, NULL);	break;	case CDDS_ITEMPREPAINT:	// 设置背景和前景颜色	nItemState = pCustomDraw->nmcd.uItemState;	pCustomDraw->nmcd.uItemState &= ~CDIS_FOCUS;	pCustomDraw->clrText = m_colHilightText;	// 记住绘制项目的矩形	m_pTree->GetItemRect((HTREEITEM) pCustomDraw->nmcd.dwItemSpec, &rcItem, TRUE);	*pResult = CDRF_NOTIFYPOSTPAINT;	break;	case CDDS_ITEMPOSTPAINT:	DrawTreeItem(nItemState, rcItem, pCustomDraw->nmcd.hdc, (HTREEITEM) pCustomDraw->nmcd.dwItemSpec);	break;	default:	*pResult = CDRF_DODEFAULT;	}} 
最后你需要做的只是在DrawTreeItem中自绘你想要的得效果就是了如下:
void CLeftView::DrawTreeItem(int nItemState, CRect rcItem, HDC hdc, HTREEITEM hItem){	// 如果此项获得输入焦点,则绘制外围矩形并用蓝色填充矩形区域	COLORREF colText = m_colText;	if(nItemState & CDIS_FOCUS)	{	::FillRect(hdc, &rcItem, (HBRUSH)m_BackBrush.m_hObject);	// 新的焦点矩形代码......	::DrawFocusRect( hdc, &rcItem);	colText = m_colHilightText;	}	else if(nItemState & CDIS_SELECTED)	{	::FillRect(hdc, &rcItem, (HBRUSH)m_GrayBrush.m_hObject);	}	else	{	TRACE("CLEAR HIGH\n");	// 清除剩余的高亮条	::FillRect(hdc, &rcItem, (HBRUSH)m_BackBrushNormal.m_hObject);	}	// 总是要写没有背景的文本	::SetBkMode(hdc, TRANSPARENT);	::SetTextColor(hdc,colText);	CString str = m_pTree->GetItemText(hItem);	::DrawText(hdc, str, -1, &rcItem, DT_VCENTER | DT_SINGLELINE | DT_WORD_ELLIPSIS);	int nNew = 20;	CString strNew = _T("");	strNew.Format(_T("(%d)"),nNew);	::SetTextColor(hdc,RGB(0,0,255));	RECT rc = rcItem;	rc.left = rcItem.right+2;	rc.right = rc.left + 100;	::FillRect(hdc, &rc, (HBRUSH)m_BackBrushNormal.m_hObject);	::DrawText(hdc,strNew, -1, &rc, DT_VCENTER | DT_SINGLELINE | DT_WORD_ELLIPSIS);} 
需要说明的是如果你想支持拖放,那么你必需要做一些修改......