Flat UI是基于Bootstrap之上进行二次开拓的扁平化前端框架,他供应了动感、时尚的风格色调搭配,简洁、炫丽的功能组件,同时还供应了更为平滑的js交互动画,可以称得上前端扁平化设计框架的精良代表之一。
既然是扁平化设计框架的精良代表,当然须要在自己项目中运用运用,本人最早利用VB开拓,而后转为C#开拓,末了转为Qt开拓,都是由于公司项目须要,根据须要不断学习新的编程框架,措辞都是相通的,举一反三,以前用C#写的vista时钟控件和vista日历控件,轻微改改就转移成了Qt写的对应控件,非常方便,只要节制了思想,闇练了一门措辞和框架之后,其他的学起来特殊快。
Qt中的qss机制,和css极为相似,觉得便是脱胎于css,用qss来实现Qt界面样式不是一样平常的方便,而是相称的爽,在看到FlatUI这样的精美的扁平化设计样式后,难以抑制手痒痒,就想用qss实现类似的风格。
开源地址:[https://gitee.com/feiyangqingyun/QWidgetDemo](https://gitee.com/feiyangqingyun/QWidgetDemo) [https://github.com/feiyangqingyun/QWidgetDemo](https://github.com/feiyangqingyun/QWidgetDemo)
二、实现的功能1:按钮样式设置
2:文本框样式设置
3:进度条样式
4:滑块条样式
5:单选框样式
6:滚动条样式
7:可自由设置工具的高度宽度大小等
8:自带默认参数值
三、效果图五、核心代码#pragma execution_character_set(\"大众utf-8\公众)#include \公众flatui.h\"大众#include \"大众qmutex.h\"大众#include \公众qpushbutton.h\"大众#include \"大众qlineedit.h\"大众#include \公众qprogressbar.h\"大众#include \公众qslider.h\"大众#include \"大众qradiobutton.h\"大众#include \"大众qcheckbox.h\"大众#include \"大众qscrollbar.h\公众#include \公众qdebug.h\公众QScopedPointer<FlatUI> FlatUI::self;FlatUI FlatUI::Instance(){ if (self.isNull()) { static QMutex mutex; QMutexLocker locker(&mutex); if (self.isNull()) { self.reset(new FlatUI); } } return self.data();}FlatUI::FlatUI(QObject parent) : QObject(parent){}QString FlatUI::setPushButtonQss(QPushButton btn, int radius, int padding, const QString &normalColor, const QString &normalTextColor, const QString &hoverColor, const QString &hoverTextColor, const QString &pressedColor, const QString &pressedTextColor){ QStringList list; list.append(QString(\"大众QPushButton{border-style:none;padding:%1px;border-radius:%2px;color:%3;background:%4;}\"大众) .arg(padding).arg(radius).arg(normalTextColor).arg(normalColor)); list.append(QString(\"大众QPushButton:hover{color:%1;background:%2;}\公众) .arg(hoverTextColor).arg(hoverColor)); list.append(QString(\"大众QPushButton:pressed{color:%1;background:%2;}\"大众) .arg(pressedTextColor).arg(pressedColor)); QString qss = list.join(\公众\公众); btn->setStyleSheet(qss); return qss;}QString FlatUI::setLineEditQss(QLineEdit txt, int radius, int borderWidth, const QString &normalColor, const QString &focusColor){ QStringList list; list.append(QString(\"大众QLineEdit{border-style:none;padding:3px;border-radius:%1px;border:%2px solid %3;}\"大众) .arg(radius).arg(borderWidth).arg(normalColor)); list.append(QString(\"大众QLineEdit:focus{border:%1px solid %2;}\"大众) .arg(borderWidth).arg(focusColor)); QString qss = list.join(\"大众\公众); txt->setStyleSheet(qss); return qss;}QString FlatUI::setProgressQss(QProgressBar bar, int barHeight, int barRadius, int fontSize, const QString &normalColor, const QString &chunkColor){ QStringList list; list.append(QString(\公众QProgressBar{font:%1pt;background:%2;max-height:%3px;border-radius:%4px;text-align:center;border:1px solid %2;}\"大众) .arg(fontSize).arg(normalColor).arg(barHeight).arg(barRadius)); list.append(QString(\公众QProgressBar:chunk{border-radius:%2px;background-color:%1;}\"大众) .arg(chunkColor).arg(barRadius)); QString qss = list.join(\"大众\公众); bar->setStyleSheet(qss); return qss;}QString FlatUI::setSliderQss(QSlider slider, int sliderHeight, const QString &normalColor, const QString &grooveColor, const QString &handleBorderColor, const QString &handleColor){ int sliderRadius = sliderHeight / 2; int handleWidth = (sliderHeight 3) / 2 + (sliderHeight / 5); int handleRadius = handleWidth / 2; int handleOffset = handleRadius / 2; QStringList list; list.append(QString(\"大众QSlider::horizontal{min-height:%1px;}\公众).arg(sliderHeight 2)); list.append(QString(\"大众QSlider::groove:horizontal{background:%1;height:%2px;border-radius:%3px;}\"大众) .arg(normalColor).arg(sliderHeight).arg(sliderRadius)); list.append(QString(\公众QSlider::add-page:horizontal{background:%1;height:%2px;border-radius:%3px;}\"大众) .arg(normalColor).arg(sliderHeight).arg(sliderRadius)); list.append(QString(\公众QSlider::sub-page:horizontal{background:%1;height:%2px;border-radius:%3px;}\"大众) .arg(grooveColor).arg(sliderHeight).arg(sliderRadius)); list.append(QString(\"大众QSlider::handle:horizontal{width:%3px;margin-top:-%4px;margin-bottom:-%4px;border-radius:%5px;\"大众 \公众background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,stop:0.6 %1,stop:0.8 %2);}\公众) .arg(handleColor).arg(handleBorderColor).arg(handleWidth).arg(handleOffset).arg(handleRadius)); //偏移一个像素 handleWidth = handleWidth + 1; list.append(QString(\公众QSlider::vertical{min-width:%1px;}\"大众).arg(sliderHeight 2)); list.append(QString(\"大众QSlider::groove:vertical{background:%1;width:%2px;border-radius:%3px;}\"大众) .arg(normalColor).arg(sliderHeight).arg(sliderRadius)); list.append(QString(\"大众QSlider::add-page:vertical{background:%1;width:%2px;border-radius:%3px;}\"大众) .arg(grooveColor).arg(sliderHeight).arg(sliderRadius)); list.append(QString(\"大众QSlider::sub-page:vertical{background:%1;width:%2px;border-radius:%3px;}\"大众) .arg(normalColor).arg(sliderHeight).arg(sliderRadius)); list.append(QString(\"大众QSlider::handle:vertical{height:%3px;margin-left:-%4px;margin-right:-%4px;border-radius:%5px;\"大众 \"大众background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,stop:0.6 %1,stop:0.8 %2);}\公众) .arg(handleColor).arg(handleBorderColor).arg(handleWidth).arg(handleOffset).arg(handleRadius)); QString qss = list.join(\公众\公众); slider->setStyleSheet(qss); return qss;}QString FlatUI::setRadioButtonQss(QRadioButton rbtn, int indicatorRadius, const QString &normalColor, const QString &checkColor){ int indicatorWidth = indicatorRadius 2; QStringList list; list.append(QString(\"大众QRadioButton::indicator{border-radius:%1px;width:%2px;height:%2px;}\公众) .arg(indicatorRadius).arg(indicatorWidth)); list.append(QString(\"大众QRadioButton::indicator::unchecked{background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,\公众 \"大众stop:0.6 #FFFFFF,stop:0.7 %1);}\"大众).arg(normalColor)); list.append(QString(\"大众QRadioButton::indicator::checked{background:qradialgradient(spread:pad,cx:0.5,cy:0.5,radius:0.5,fx:0.5,fy:0.5,\"大众 \公众stop:0 %1,stop:0.3 %1,stop:0.4 #FFFFFF,stop:0.6 #FFFFFF,stop:0.7 %1);}\"大众).arg(checkColor)); QString qss = list.join(\"大众\"大众); rbtn->setStyleSheet(qss); return qss;}QString FlatUI::setScrollBarQss(QWidget scroll, int radius, int min, int max, const QString &bgColor, const QString &handleNormalColor, const QString &handleHoverColor, const QString &handlePressedColor){ //滚动条离背景间隔 int padding = 0; QStringList list; //handle:指示器,滚动条拉动部分 add-page:滚动条拉动时增加的部分 sub-page:滚动条拉动时减少的部分 add-line:递增按钮 sub-line:递减按钮 //横向滚动条部分 list.append(QString(\"大众QScrollBar:horizontal{background:%1;padding:%2px;border-radius:%3px;min-height:%4px;max-height:%4px;}\公众) .arg(bgColor).arg(padding).arg(radius).arg(max)); list.append(QString(\"大众QScrollBar::handle:horizontal{background:%1;min-width:%2px;border-radius:%3px;}\"大众) .arg(handleNormalColor).arg(min).arg(radius)); list.append(QString(\"大众QScrollBar::handle:horizontal:hover{background:%1;}\"大众) .arg(handleHoverColor)); list.append(QString(\公众QScrollBar::handle:horizontal:pressed{background:%1;}\公众) .arg(handlePressedColor)); list.append(QString(\公众QScrollBar::add-page:horizontal{background:none;}\公众)); list.append(QString(\"大众QScrollBar::sub-page:horizontal{background:none;}\"大众)); list.append(QString(\"大众QScrollBar::add-line:horizontal{background:none;}\公众)); list.append(QString(\"大众QScrollBar::sub-line:horizontal{background:none;}\"大众)); //纵向滚动条部分 list.append(QString(\公众QScrollBar:vertical{background:%1;padding:%2px;border-radius:%3px;min-width:%4px;max-width:%4px;}\公众) .arg(bgColor).arg(padding).arg(radius).arg(max)); list.append(QString(\公众QScrollBar::handle:vertical{background:%1;min-height:%2px;border-radius:%3px;}\"大众) .arg(handleNormalColor).arg(min).arg(radius)); list.append(QString(\公众QScrollBar::handle:vertical:hover{background:%1;}\"大众) .arg(handleHoverColor)); list.append(QString(\"大众QScrollBar::handle:vertical:pressed{background:%1;}\"大众) .arg(handlePressedColor)); list.append(QString(\公众QScrollBar::add-page:vertical{background:none;}\"大众)); list.append(QString(\"大众QScrollBar::sub-page:vertical{background:none;}\公众)); list.append(QString(\"大众QScrollBar::add-line:vertical{background:none;}\"大众)); list.append(QString(\公众QScrollBar::sub-line:vertical{background:none;}\"大众)); QString qss = list.join(\公众\"大众); scroll->setStyleSheet(qss); return qss;}六、控件先容
1. 超过160个精美控件,涵盖了各种仪表盘、进度条、进度球、指南针、曲线图、标尺、温度计、导航条、导航栏,flatui、高亮按钮、滑动选择器、农历等。远超qwt集成的控件数量。
2. 每个类都可以独立成一个单独的控件,零耦合,每个控件一个头文件和一个实现文件,不依赖其他文件,方便单个控件以源码形式集成到项目中,较少代码量。qwt的控件类环环相扣,高度耦合,想要利用个中一个控件,必须包含所有的代码。
3. 全部纯Qt编写,QWidget+QPainter绘制,支持Qt4.6到Qt5.13的任何Qt版本,支持mingw、msvc、gcc等编译器,支持任意操作系统比如windows+linux+mac+嵌入式linux等,不乱码,可直接集成到Qt Creator中,和自带的控件一样利用,大部分效果只要设置几个属性即可,极为方便。
4. 每个控件都有一个对应的单独的包含该控件源码的DEMO,方便参考利用。同时还供应一个所有控件利用的集成的DEMO。
5. 每个控件的源代码都有详细中文注释,都按照统一设计规范编写,方便学习自定义控件的编写。
6. 每个控件默认配色和demo对应的配色都非常精美。
7. 超过130个可见控件,6个不可见控件。
8. 部分控件供应多种样式风格选择,多种指示器样式选择。
9. 所有控件自适应窗体拉伸变革。
10. 集成自定义控件属性设计器,支持拖曳设计,所见即所得,支持导入导出xml格式。
11. 自带activex控件demo,所有控件可以直接运行在ie浏览器中。
12. 集成fontawesome图形字体+阿里巴巴iconfont收藏的几百个图形字体,享受图形字体带来的乐趣。
13. 所有控件末了天生一个动态库文件(dll或者so等),可以直接集成到qtcreator中拖曳设计利用。
14. 目前已经有qml版本,后期会考虑出pyqt版本,如果用户需求量很大的话。
15. 自定义控件插件开放动态库利用(永久免费),无任何后门和限定,请放心利用。
16. 目前已供应32个版本的dll,个中qt_5_7_0_mingw530_32这个版本会一贯担保最新的完全的。
17. 不定期增加控件和完善控件,不定期更新SDK,欢迎各位提出建议,感激!
18. Qt入门书本推举霍亚飞的《Qt Creator快速入门》《Qt5编程入门》,Qt进阶书本推举官方的《C++ GUI Qt4编程》。
19. 强烈推举程序员自我教化和方案系列书《大话程序员》《程序员的发展课》《解忧程序员》,受益匪浅,受益终生!
20. SDK地址:[https://gitee.com/feiyangqingyun/QUCSDK](https://gitee.com/feiyangqingyun/QUCSDK) [https://github.com/feiyangqingyun/qucsdk](https://github.com/feiyangqingyun/qucsdk)