首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >合并两个QIcon

合并两个QIcon
EN

Stack Overflow用户
提问于 2017-11-13 18:54:04
回答 1查看 825关注 0票数 3

QIcon有状态的概念,例如,当从QIcon请求像素映射时,人们可以要求它为On状态(如按下按钮)或在Off状态下请求像素映射。

创建一个状态感知的QIcon很简单:只需使用modestate参数的适当组合调用QIcon::addPixmap()成员函数,将所需的像素映射组合到QIcon中即可。

然而,在使用Qt的主题机制时,可以使用QIcon静态成员函数创建QIcon::fromTheme()。此函数返回的图标不具有状态感知。事实上,从Qt的来源中,我了解到只有QIcon::Mode是动态应用的,例如,将Disabled模式的图标灰色化。

因此,假设我从主题创建了两个不同的图标,onIconoffIcon,我如何将它们合并成一个QIcon来覆盖各自的State

EN

回答 1

Stack Overflow用户

发布于 2019-09-24 11:15:51

诀窍是使用QIcon::availableSizes从每个图标中提取所有单独的像素映射,然后为每个集合分配一个角色(模式+状态)。

这里是一个基本的例子,只有开和关状态。

代码语言:javascript
复制
QIcon mergeIcons(const QIcon& on_icon, const QIcon& off_icon) {
  QIcon new_icon;
  const auto fn_add = [&new_icon](const QIcon& src, QIcon::Mode mode, QIcon::State state) {
    const auto sizes = src.availableSizes();
    for (const auto& size : sizes) {
      new_icon.addPixmap(src.pixmap(size), mode, state);
    }      
  };

  fn_add(on_icon, QIcon::Normal, QIcon::On);
  fn_add(off_icon, QIcon::Normal, QIcon::Off);

  return new_icon;
}

然后简单地加载源图标并合并它们:

代码语言:javascript
复制
const QIcon on_icon("on.ico");
const QIcon off_icon("off.ico");
ui->pushButton->setIcon(mergeIcons(on_icon, off_icon));
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47271531

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档