QIcon有状态的概念,例如,当从QIcon请求像素映射时,人们可以要求它为On状态(如按下按钮)或在Off状态下请求像素映射。
创建一个状态感知的QIcon很简单:只需使用mode和state参数的适当组合调用QIcon::addPixmap()成员函数,将所需的像素映射组合到QIcon中即可。
然而,在使用Qt的主题机制时,可以使用QIcon静态成员函数创建QIcon::fromTheme()。此函数返回的图标不具有状态感知。事实上,从Qt的来源中,我了解到只有QIcon::Mode是动态应用的,例如,将Disabled模式的图标灰色化。
因此,假设我从主题创建了两个不同的图标,onIcon和offIcon,我如何将它们合并成一个QIcon来覆盖各自的State?
发布于 2019-09-24 11:15:51
诀窍是使用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));https://stackoverflow.com/questions/47271531
复制相似问题