LoginSignup
6
6

More than 5 years have passed since last update.

FontAwesome で動的にアイコン化 in Qt

Last updated at Posted at 2014-05-11

自分含めて FontAwesome などのアイコンフォントを使ってアイコンを書き出したいという需要があると思うので。

// iconSize と fontPointSize は適当に設定している
const QChar iconType = 0xf000; // css/font-awesome.css に定義がある。ここでは .icon-glass と同じ
const int iconSize = 52;
const int fontPointSize = 42;

// フォントをインストールする
int fontID = QFontDatabase::addApplicationFont("/path/to/font-awesome.ttf");

// QPixmap を生成して透明にしておく
QPixmap pixmap(iconSize, iconSize);
pixmap.fill(Qt::transparent);

// QFont で FontAwesome を指定し、QPainter 使って QPixmap にアイコンを書き出す
QPainter painter(&pixmap);
QFont font("FontAwesome", fontPointSize);
painter.setFont(font);
painter.setRenderingHint(QPainter::AntiAliasing);
painter.drawText(pixmap.rect(), iconType, QTextOption(Qt::AlignVCenter|Qt::AlignHCenter));

// QPixmap から QIcon に変換
QIcon icon(pixmap);

// ... icon を使ってゴニョゴニョする

// 終わったら removeApplicationFont で削除
QFontDatabase::removeApplicationFont(fontID)

FontAwesome を使用していてより柔軟性を求めるなら QtAwesome を使ったほうが良いかもしれません。

6
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
6