合并两个 QIcon

Merge two QIcon

本文关键字:两个 QIcon 合并      更新时间:2023-10-16

QIcon有一个状态的概念,例如,当从QIcon请求pixmap时,可以要求它提供On状态(如按下按钮(或Off状态的pixmap。

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

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

因此,考虑我从主题中创建两个不同的图标,onIconoffIcon,如何将它们合并到一个QIcon中以涵盖各自的State

诀窍

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

下面是一个仅包含打开和关闭状态的基本示例。

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;
}

然后只需加载源图标并合并它们:

const QIcon on_icon("on.ico");
const QIcon off_icon("off.ico");
ui->pushButton->setIcon(mergeIcons(on_icon, off_icon));