【Swift UIKit】SF Symbolsのサイズやカラーのカスタマイズ方法!UIImage

この記事からわかること

  • SwiftUIKitSF Symbolsサイズカラー変更する方法
  • UIImageイニシャライザ使い方
  • withConfigurationに指定するSymbolConfiguration型とは?
  • withTintColorメソッド

index

[open]

\ アプリをリリースしました /

みんなの誕生日

友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-

posted withアプリーチ

SwiftのUIKitを使用している場合のSF Symbolsアイコンのカスタマイズ方法をまとめていきます。「SF Symbolsとは?」や「Swift UIでの使い方」については以下記事を参考にしてください。

UIKit:SF Symbolsの実装方法

公式リファレンス:UIImage

UIKitフレームワークではSF Symbolsのアイコンを表示する際はUIImage(systemName:)形式のイニシャライザを使用します。

let img = UIImage(systemName: "swift")

画面にビューとして追加したい場合はUIImageView型に変換してaddSubviewメソッドを使って表示させることができます。

let img = UIImage(systemName: "swift")

let imageView = UIImageView(image: img)
imageView.center = .init(x: 100, y: 100)
view.addSubview(imageView)

SF Symbolsのカスタマイズ方法

インスタンス化したSF SymbolsアイコンのUIImageをカスタマイズするには init(systemName:withConfiguration:)形式のイニシャライザを使用します。

init?(
    systemName name: String,
    withConfiguration configuration: UIImage.Configuration?
)

引数withConfigurationにはUIImage.SymbolConfiguration型でカスタマイズしたい要素を指定します。

UIImage.SymbolConfiguration

公式リファレンス:UIImage.SymbolConfiguration

UIImage.SymbolConfigurationUIImage.Configurationクラスを継承したシンボル画像をカスタマイズするための設定指定するクラスです。

様々なイニシャライザを使用することでサイズやフォント、スケールなどの値を変更することができます。

システムサイズを変更する

サイズはinit(textStyle:)で変更できます。値にはUIFont.TextStyle型のcaption1largeTitleなどシステム指定のものを指定できます。

let img = UIImage(systemName: "swift", withConfiguration: UIImage.SymbolConfiguration(textStyle: .title1))

カスタムサイズに変更する

サイズをカスタムに変更するにははinit(font: )を使用します。.systemFont(ofSize: 40)とすることで任意の値にサイズを変更することができます。

 let img = UIImage(systemName: "swift", withConfiguration: UIImage.SymbolConfiguration(font: .systemFont(ofSize: 40)))

init(pointSize:)でもサイズをカスタムに変更することが可能です。

 let img = UIImage(systemName: "swift", withConfiguration: UIImage.SymbolConfiguration(pointSize:40))

withTintColorでカラーを変更する

カラーを変更するにはinit(systemName:withConfiguration:)ではなくwithTintColorメソッドを使用します。

let img = UIImage(systemName: "swift")?.withTintColor(.orange)

まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。

ご覧いただきありがとうございました。

searchbox

スポンサー

ProFile

ame

趣味:読書,プログラミング学習,サイト制作,ブログ

IT嫌いを克服するためにITパスを取得しようと勉強してからサイト制作が趣味に変わりました笑
今はCMSを使わずこのサイトを完全自作でサイト運営中〜

自作iOSアプリ

\ アプリをリリースしました /

mapping

自分だけの地図を作ろう!-mapping-

無料posted withアプリーチ

割り勘アプリ-bill-

旅行におすすめ!
割り勘アプリ-bill-

無料posted withアプリーチ

Imakoko

現在地を取得するアプリ!Imakoko

無料posted withアプリーチ

ふるログ

ふるさと納税管理アプリ-ふるログ-

無料posted withアプリーチ

Remind-シンプル通知アプリ-

シンプル通知アプリ-Remind-

無料posted withアプリーチ

CLIPURL

好きな記事をクリップしよう!-CLIPURL-

無料posted withアプリーチ

記録カレンダー

続けたを可視化できるアプリ!記録カレンダー

無料posted withアプリーチ

CART-共有できるお買い物リスト-

CART-共有できるお買い物リスト-

無料posted withアプリーチ

QuickPressPanel

早押しゲーム-QuickPressPanel-

無料posted withアプリーチ

貸し借り管理アプリ

友達とのお金の管理-貸し借り管理アプリ-

無料posted withアプリーチ

みんなの誕生日

友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-

posted withアプリーチ

Githubにて
iOSアプリのソースコードを公開中!

自作Webアプリ

子育て知識共有サイト-mikata-

子育て知識共有サイト-mikata-

New Article

index