<Windows> MFC重绘系统ComboBox

软件环境

  • Windows 10 1809 64bit
  • VS2017 Enterprise
  • MFC

实现功能

  1. 重绘ComboBox
  2. 添加删除按钮
  3. 自适应下拉List的宽度
  4. 记录最后一次ComboBox的窗口文本

实现原理

ComboBox属性设置

  • 重载ComboBox CompareItem/DrawItem
  • Owner Draw 设置为 Fixed
  • Has Strings 设置为 True
  • Type 设置为 DropDown/DropList

技术要点

  • PreSubclassWindow: 设置ListBox的GWLP_WNDPROC
    获取ListBox上的鼠标信息
  • OnCbnDropdown: 自适度下拉宽度
  • OnPaint: ComboBox自绘
  • DrawItem: 绘制下拉选项,删除图标

效果

DropDown

在这里插入图片描述

DropList

在这里插入图片描述

Disable Window

在这里插入图片描述

代码:
https://github.com/Lulixue/RedrawSystemComboBox

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
<?xml version="1.0" encoding="UTF-8"?> <ui version="4.0"> <widget name="__qt_fake_top_level"> <widget class="QWidget" name=""> <layout class="QVBoxLayout" name="verticalLayout"> <item> <widget class="QTextEdit" name="textEdit"> <property name="minimumSize"> <size> <width>200</width> <height>0</height> </size> </property> <property name="maximumSize"> <size> <width>200</width> <height>16777215</height> </size> </property> <property name="font"> <font> <pointsize>14</pointsize> </font> </property> </widget> </item> <item> <widget class="QTextBrowser" name="textBrowserResult"> <property name="minimumSize"> <size> <width>100</width> <height>0</height> </size> </property> <property name="maximumSize"> <size> <width>200</width> <height>16777215</height> </size> </property> <property name="font"> <font> <pointsize>28</pointsize> </font> </property> </widget> </item> <item> <widget class="QPushButton" name="pushButton_2"> <property name="text"> <string>暂停</string> </property> </widget> </item> <item> <widget class="QPushButton" name="pushButton"> <property name="text"> <string>开始</string> </property> </widget> </item> <item> <widget class="QComboBox" name="comboBox"> <property name="sizePolicy"> <sizepolicy hsizetype="Expanding" vsizetype="Maximum"> <horstretch>0</horstretch> <verstretch>0</verstretch> </sizepolicy> </property> <property name="minimumSize"> <size> <width>200</width> <height>30</height> </size> </property> <property name="maximumSize"> <size> <width>100</width> <height>30</height> </size> </property> <property name="font"> <font> <pointsize>14</pointsize> </font> </property> </widget> </item> </layout> </widget> </widget> <resources/> </ui>
最新发布
06-13

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值