码迷,mamicode.com
首页 > 其他好文 > 详细

QMenu自绘处理 菜单自绘 定制菜单处理

时间:2020-07-03 01:15:28      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:方法   图片   qss   遍历   开发工具   get   效果   inter   src   

QMenu中我们可以通过QSS完成菜单的外观定制,但是有些时候qss无法达到我们想要的自定效果,这个时候就需要使用自绘菜单技术了。

处理方法如下:

1、首选需要重载菜单的paintevent方法

const QList<QAction*>& actions = pMenu->actions();
for (int i = 0; i < actions.size(); ++i)
{
QAction* pAction = actions.at(i);
QRect rect = pMenu->actionGeometry(pAction);

if (i == _hotItemIdx && !pAction->isSeparator())
{
drawFillStyle(*pPainter, _itemStyle[UIG_HOT], rect);
drawText(*pPainter, pAction->text(), _textStyle[UIG_HOT], rect);
}
else
{
drawFillStyle(*pPainter, _itemStyle[UIG_NORMAL], rect);
drawText(*pPainter, pAction->text(), _textStyle[UIG_NORMAL], rect);
}

}

通过遍历actions和actionGeometry得到每一项的位置,然后进行自绘处理

 

2、重载mouseMoveEvent,获取高亮项

void UIGQMenu::mouseMoveEvent(QMouseEvent *event)
{
QMenu::mouseMoveEvent(event);

const QList<QAction*>& actions = this->actions();
for (int i = 0; i < actions.size(); ++i)
{
QAction* pAction = actions.at(i);
QRect rect = actionGeometry(pAction);

if (rect.contains(event->pos()))
{
if (_ctrlImpl->_hotItemIdx != i)
{
update();
}
_ctrlImpl->_hotItemIdx = i;
break;
}
}
}

在高亮的时候update触发重绘

从而达到自绘菜单的目的

 

 

 

 技术图片

更多详情请浏览

www.qt-ui.com

 

QMenu自绘处理 菜单自绘 定制菜单处理

标签:方法   图片   qss   遍历   开发工具   get   效果   inter   src   

原文地址:https://www.cnblogs.com/Qt-UI/p/13227832.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!