效果如下:

原创-转载请著名来源

1,新建颜色属性类“CNColor”:

class CNColor
{
public:
COLORREF m_crColor; //颜色RGB值
WCHAR m_cColor[]; //颜色名
CNColor(COLORREF cr, WCHAR * crStr);
~CNColor();
}; CNColor::CNColor(COLORREF cr, WCHAR * crStr)
{
this->m_crColor = cr;
lstrcpyn(m_cColor, crStr, );
} CNColor::~CNColor()
{
}

2,新建颜色列表控件类“CNColorList”:

class CNColorList
{
public:
HWND m_mHwnd;
list<CNColor*> m_mColors;  //颜色列表
private:
  //初始化颜色列表
void InitalColorArray();
public:
CNColorList();
~CNColorList();
//创建控件
int Creat(
HWND hwnd, //父窗口句柄
HINSTANCE hinst, //程序全局句柄
UINT uid, //控件号
RECT rec //控件外框大小
);
//控件消息处理
static LRESULT CALLBACK NColorListProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam);
//绘制子项
void DrawItem(HDC hdc, int itmId, RECT rec);
//获取字符串
CNColor* GetColorById(int nid);
};

3,新建类指针类“CNColorListPtr”

// 保存类指针
class CNColorListPtr
{
public:
UINT mUid; //ID号
CNColorList *pColorList = NULL; //颜色列表指针
WNDPROC mProc; //应用程序句柄
public:
CNColorListPtr(UINT uid,CNColorList* ptr, WNDPROC proc);
~CNColorListPtr();
}; CNColorListPtr::CNColorListPtr(UINT uid, CNColorList* ptr, WNDPROC proc)
{
mUid = uid;
pColorList = ptr;
mProc = proc;
}

4,初始化颜色列表

//初始化颜色列表
void CNColorList::InitalColorArray()
{
m_mColors.push_back(new CNColor(RGB(0xF0, 0xF8, 0xFF), L"AliceBlue"));
m_mColors.push_back(new CNColor(RGB(0xFA, 0xEB, 0xD7), L"AntiqueWhite"));
m_mColors.push_back(new CNColor(RGB(0x00, 0xFF, 0xFF), L"Aqua"));
m_mColors.push_back(new CNColor(RGB(0x7F, 0xFF, 0xD4), L"Aquamarine"));
m_mColors.push_back(new CNColor(RGB(0xF0, 0xFF, 0xFF), L"Azure"));
m_mColors.push_back(new CNColor(RGB(0xF5, 0xF5, 0xDC), L"Beige"));
m_mColors.push_back(new CNColor(RGB(0xFF, 0xE4, 0xC4), L"Bisque"));
m_mColors.push_back(new CNColor(RGB(0x00, 0x00, 0x00), L"Black"));
}

5,创建控件窗口

// 创建ColorList
int CNColorList::Creat(HWND hwnd, HINSTANCE hinst, UINT uid, RECT rec)
{
if (m_mColors.size() == )
InitalColorArray();
m_mHwnd = CreateWindow(L"combobox", NULL, WS_CHILD | WS_VISIBLE | WS_VSCROLL | CBS_DROPDOWNLIST | CBS_HASSTRINGS | CBS_OWNERDRAWFIXED,
rec.left, rec.top, rec.right-rec.left, rec.bottom-rec.top, hwnd, (HMENU)uid, hinst, NULL);
WNDPROC nProc = (WNDPROC)SetWindowLong(hwnd, GWL_WNDPROC, (LONG)NColorListProc); // 绑定控件事件处理程序
CNColorListPtr *mptr = new CNColorListPtr(uid, this, nProc);
SetWindowLong(hwnd, GWL_USERDATA, (LONG)mptr); // 保存当前窗口指针
list<CNColor*>::iterator ite;
for (ite = m_mColors.begin(); ite != m_mColors.end(); ite++)
{
//add string
ComboBox_AddString(
m_mHwnd,
(LPARAM)((CNColor*)(*ite))->m_cColor
);
}
return ;
}

6,定义消息处理:

// 消息处理
LRESULT CALLBACK CNColorList::NColorListProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
CNColorListPtr* ptr = (CNColorListPtr*)GetWindowLong(hwnd, GWL_USERDATA); //获取窗口指针
WNDPROC nProc = ptr->mProc;
int idx;
WCHAR str[];
switch (msg)
{
case WM_DRAWITEM:
{
if (wParam == ptr->mUid)
{
ptr->pColorList->DrawItem(
((LPDRAWITEMSTRUCT)lParam)->hDC,
((LPDRAWITEMSTRUCT)lParam)->itemID,
((LPDRAWITEMSTRUCT)lParam)->rcItem
);
}
break;
}
default:
break;
}
return CallWindowProc(nProc, hwnd, msg, wParam, lParam); //传递消息给主窗口
}

7,绘制下拉表ITEM

// 绘制子项
void CNColorList::DrawItem(HDC hdc, int itmId, RECT rec)
{
if (itmId == -) return;
CNColor *mc = GetColorById(itmId);
// 创建钢笔
HPEN pen = CreatePen(PS_SOLID, , RGB(, , ));
HBRUSH brush = CreateSolidBrush(mc->m_crColor);
SelectObject(hdc, pen);
SelectObject(hdc, brush);
RECT nrec = {
rec.left + ,
rec.top + ,
(rec.right + rec.left)*0.3,
rec.bottom -
};
FillRect(hdc, &nrec, brush);
Rectangle(hdc, nrec.left, nrec.top, nrec.right, nrec.bottom);
RECT trec = {
(rec.right + rec.left)*0.3 + ,
rec.top,
rec.right - ,
rec.bottom
};
SetTextColor(hdc, RGB(, , ));
DrawText(hdc, mc->m_cColor, -, &trec, DT_LEFT);
DeleteObject(pen);
DeleteObject(brush);
}

8,在主程序中调用控件

  8.1 定义控件ID   

  #define IDB_CRLIST 8000

  8.2 新建控件对象  

CNColorList nCr = CNColorList();

  8.3 在消息WM_CREAT中创建控件

case WM_CREATE:
nCr.Creat(
hwnd,
(HINSTANCE)GetWindowLong(hwnd, GWL_HINSTANCE),
IDB_CRLIST,
{ ,,, }
);
break;

原创-转载请著名来源

WIN32API 自定义颜色下拉列表控件的更多相关文章

  1. FineUI第八天----下拉列表控件

    下拉列表控件 3.模拟树的下拉列表: 其他的控件都跟Asp.net的差不多.

  2. python通过win32api轻松获取控件的属性值

    1.如何利用句柄操作windows窗体 首先,获得窗体的句柄  win32api.FindWindows() 第二,获得窗体中控件的id号,spy++ 第三,根据控件的ID获得控件的句柄(hwnd)  ...

  3. 安卓开发16:Spinner 下拉列表控件

    Spinner 下拉列表控件 创建一个activity_main.xml文件: <RelativeLayout xmlns:android="http://schemas.androi ...

  4. 下拉列表控件实例 ComboBoxControl

    下拉列表控件实例 书:151页 <?xml version="1.0" encoding="utf-8"?> <s:Application x ...

  5. ASP.NET自定义Web服务器控件-DropDownList/Select下拉列表控件

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; usin ...

  6. 如何在BCGControlBar工程的工具栏里面新增下拉列表控件

    通常情况下,工具栏里面都是一些按钮和图片,很少可以看到下拉列表控件,但是在某些应用场合,也需要用到下拉列表控件.今天在这里就简单讲解下如何在工具栏里添加下拉列表控件.   添加的过程也比较简单,在CM ...

  7. webdynpro 下拉列表控件

    现在界面上添加下拉列表的控件DropDownByKey 在context中创建新的node,和属性DP 返回界面,绑定DP到控件DropDownByKey的SelectedKey 初始方法中代码如下: ...

  8. Android下拉列表控件spinner-andoid学习之旅(十一)

    废话不多说,下拉列表常用的就是spinner控件. 直接上代码: package peng.liu.testview; import android.app.Activity; import andr ...

  9. 基于Jquery的下拉列表控件(个人觉得实用)

    Selectize.js Selectize 是一个基于 jQuery 的 <select> UI 控件,对于标签选择和下拉列表功能非常有用. Selectize 的目标是通过简单而强大的 ...

随机推荐

  1. queue

    http://www.codeforces.com/contest/625/problem/E

  2. linux中的进程和线程

    应用程序:可以被操作系统执行的一组指令和参数的集合,是静态的,并存储在磁盘空间中: 进程:在操作系统中在运行程序后,处于运行状态的程序,是应用程序的一个执行过程,同时也是操作系统分配内存,cpu等系统 ...

  3. 14,SFDC 管理员篇 - 外部数据集成

    1,Connect an External Data Source, 添加新的数据源,填写如下 2, 点击Validate and Sync 按钮 3,添加Orders和Orders Details ...

  4. 12,SFDC 管理员篇 - 页面配置

    1, 添加Tab Setup | Create | Tab 通过Tab我们可以为我们新建的表对象添加访问路径   2,创建自定义按钮 我们想在Account 中添加一个自定义按钮,去链接外部页面,也可 ...

  5. 从request获取远程IP地址

    public static String getIpAddr(HttpServletRequest request) { String ip = request.getHeader("X-F ...

  6. ORCLE基本语句(二)

    select语句的基本语法: [ORDER BY < COLUMN1, COLUMN2, COLUMN3...> [ASC 或 DESC]]

  7. LCC

    LCC: super vector:

  8. 通过innobackupex实现对MySQL的完整备份与还原

    备份 新建一个用于存放备份的目录 mkdir /backup 执行以下命令: innobackupex --password=test /backup/ 执行完后你会看到“completed OK!” ...

  9. 线程+IO流

    第十八天知识点总结 线程的停止: 1.停止一个线程,一般是通过一个变量来控制. 2.如果需要停止一个处于一个等待状态的线程,那么需要配合interrupt方法来完成 守护线程(后台线程):在一个进程中 ...

  10. Nginx开启GZIP来压缩网页

    HTTP协议上的GZIP编码是一种用来改进web应 用程序性能的技术.大流量的WEB站点常常使用GZIP压缩技术来让用户感受更快的速度.这一般是指WWW服务器中安装的一个功能,当有人来访问这个服务器中 ...