swift

Swift でフォトライブラリに UIImage を保存する

検証環境: Xcode 11.4 Swift 5.2 Photos.framework を使って フォトライブラリに UIImage 画像を jpeg または png で保存する方法です。 まず Info.plist に使用目的を追加します。 <key>NSPhotoLibraryUsageDescription</key> <string>フォトライブラリの写真を利用します。</string> <key>NS</key>…

IBDesignable を使ったカスタムビュー使用時に発生するエラー原因を調べる

検証環境: Xcode 11.3.1 Swift 5.1.3 Storyboard上で IBDesignable を使ったカスタムビューを貼り付けたところ、 error: IB Designables: Failed to render and update auto layout status for UIViewController (nyp-0u-XJD): The agent crashed というエラ…

IBDesignable を使ったカスタムビューのプレビュー時に呼ばれるメソッドについて

検証環境: Xcode 11.3.1 Swift 5.1.3 IBDesignable や IBInspectable を使うことで Storyboard や Xib 上でカスタムの属性の設定ができ、変更がリアルタイムに反映されてプレビューできるようになります。 ところで、IBOutlet で接続したビューに対して初期…

Xcode の Swift Package Manager で Repository を追加しようとしたらエラーになる

検証環境: Xcode 11.3.1 Swift 5.1.3 Swift Package Manager でリポジトリを追加しようとしたところ以下のようなエラーが出た。 Couldn’t communicate with a helper application. Try your operation again. If that fails, quit and relaunch the applicat…

【Swift5】UITextViewの任意の文字列をタップ可能なリンクにする

検証環境: Xcode 11.3 Swift 5.1.3 UITextView の任意の文字列のタップ可能なリンクにする方法についてです。 リンク化する文字列のみ、色を変えてアンダーラインを追加します。 UITextView のサブクラスして実装し、IBDesignable と IBInspectable を使って…

UIStackView に背景色を設定する

検証環境: Xcode 11.3 Swift 5.1.3 UIStackView の backgroundColor プロパティに色を設定しても描画されません。 そこで UIStackView の layer に CAShapeLayer を追加してそこに色を設定します。 UIStackView のサブクラスとして実装します。 IBInspectabl…

UIRefreshControl のプルダウンの距離を短くする

検証環境: Xcode 11.3 Swift 5.1.3 標準 の UIRefreshControl ですがアクションを開始させるためのプルダウンの距離が長いので短くする方法について調べました。 いくつかやり方はあるようですが今回は非推奨なやり方になりますが UIRefreshControl のプライ…

UITextView にプレースホルダーを設定できるようにする

検証環境: Xcode 11.3 Swift 5.1.3 たまに必要になるのでメモ。 import UIKit @IBDesignable open class PlaceHolderTextView: UITextView, UITextViewDelegate { @IBInspectable open var placeHolderText: String = "" { didSet { placeHolderLabel.text =…

Swift で端末の低電力モード、Appのバックグラウンド更新の状態を取得する

検証環境: Xcode 11.3 Swift 5.1.3 「低電力モード」になっているかを取得 if ProcessInfo.processInfo.isLowPowerModeEnabled { // Low Power Mode is enabled. Start reducing activity to conserve energy. } else { // Low Power Mode is not enabled. }…

UITableViewCell のタップした位置の IndexPath を取得する

検証環境: Xcode 11.3 Swift 5.1.3 UITableViewCell 上に置いたボタンをタップしたときにそのセルをアニメーション削除したい。 UITableViewDataSource プロトコルの cellForRowAt メソッドにセルのコールバックプロパティに引数の indexPath を渡す実装にし…

プログラムから iPhone 画面の明るさを取得、変更する

検証環境: Xcode 11.2.1 Swift 5.1.2 iPhone 画面の明るさは UIScreen.main.brightness プロパティから取得できます。 また、UIScreen.main.brightness プロパティに 0.0 から 1.0 の値を設定することで明るさをプログラムから変更できます。 1.0 が最も明る…

iOS13 で UITableViewCell をタップしても背景色がハイライトしなくなった

検証環境: Xcode 11.1 Swift 5.1 iOS13 で UITableViewCell をタップしてもハイライトしなくなったケースがあった。 原因はこちらの UIKit の仕様変更だった。 https://developer.apple.com/documentation/ios_ipados_release_notes/ios_13_release_notes Th…

Swift で 画像ビューワを実装する その3 - 複数画像を並べて表示

検証環境: Xcode 11.1 Swift 5.1 前回の続き。 後ほど。

Swift で 画像ビューワを実装する その2 - ダブルタップで拡大縮小

検証環境: Xcode 11.1 Swift 5.1 前回の続き。 今回は画像をダブルタップしたときに拡大・縮小するように実装を追加する。 ScrollView のタップ箇所をズームさせる方法は Apple のプログラミングガイドを参考に実装する。 developer.apple.com まず、画像が…

Swift で 画像ビューワを実装する その1

検証環境: Xcode 11.1 Swift 5.1 画像1枚を表示するシンプルな画像ビューワを実装してみる。 画像はピンチで拡大縮小ができるようにする。 実装方法としては UIScrollView 上に UIImageView を配置して実現する。 ただ乗せるだけだと画像の起点が左上になる…

Swift で for-in ループ時にキャストする

環境: Swift5.1 例えば、あるビューに追加されている複数のサブビューの中から UIButton にキャストできるものだけ処理する場合 for case let button as UIButton in view.subviews { // ボタンに対する処理。ボタン以外はスキップされる。 // 例えばボタン…

UITableView に行追加すると contentOffset がズレる時の対応

環境: Xcode10.3、Swift 5.0.1 UITableView で行の一番下までスクロールして、データの追加読み込み行い、行追加後の reloadData 時にカクっと画面位置がズレる場合がある。 セルの高さはすべて固定値の場合の話。 UITableView の rowHeight と estimatedRow…

iPhone のマイクから拾った音の音程を判定する

環境: Xcode10.3、Swift 5.0.1 iPhone のマイクから拾ったオーディオ情報から音程を判定する方法について調べた。 ちゃんとやるには、離散フーリエ変換 (discrete Fourier transform) を使って周波数を算出するらしいのだけれども、今回はAudioKitというOSS…

Firebase Cloud Messaging による通知をバックグラウンドでも受け取る

Swift version 5.0.1 iOS11 Firebase Cloud Messaging でアプリがバックグラウンドでも通知を受け取る方法について。 APNs ペイロードに content-available: 1を含める必要あり。 これが含まれることでアプリがバックグラウンドであっても application(_:did…

CGAffineTransform を使い View を180度回転、元に戻す

環境: Swift 5.0.1 ある View (ここではUIImageView)を180度回転させる、そして元の状態に戻すアニメーションをさせたい。 こういう場合、 CGAffineTransform の rotation を使えば実現できる。 こんなかんじの動きにしたかったのだが少しハマってしまった。…

UILabelのattributedTextのテキストを他の属性は変更せずに別の文字列に置き換える

環境: Swift5.0 UILabelのattributedTextのテキストを他の属性は変更せずに別の文字列に置き換える例。 @IBOutlet weak var textLabel: UILabel! private func setupUI() { if let attrStr = textLabel.attributedText?.mutableCopy() as? NSMutableAttribut…

UISegmentedControl を未選択状態にする

selectedSegmentIndex に UISegmentedControlNoSegment (-1) を設定する。 この定数を忘れるのでメモ。 segmentedControl.selectedSegmentIndex = UISegmentedControlNoSegment Swift4 から segmentedControl.selectedSegmentIndex = UISegmentedControl.noS…

UIColorの色を暗くする

Swift 4.2.1 現在の色から暗めの色に明度(brightness/lightness)を変更するための UIColor Extension。 extension UIColor { func dark(brightnessRatio: CGFloat = 0.8) -> UIColor { var hue: CGFloat = 0 var saturation: CGFloat = 0 var brightness: CG…

複数の CLLocationManager を使う

Swift 4.2.1 Deployment Target: 9.0 CoreLocation で位置情報を取得する際に、複数のCLLocationManagerインスタンスを同時に立ち上げて動かしたときにどうなるか気になったので試してみた。 結論としては、それぞれのインスタンスが影響し合うことなく別々…

UITextField, UITextView がキーボードで隠れないようにする - Swift 版

環境: Swift 4.2.1 Deployment Target: 11.0 以前にも同じ内容の記事を書いたが久しぶりに Swift でも同じような実装をしたのでメモ。 前提として - UIViewController.view に UIScrollView を貼り付け - UIScrollView 上に UITextField, UITextView を貼り…

ある UIColor から別の UIColor に徐々に色を変化させる

環境: Swift 4.2.1 ある UIColor から別の UIColor に徐々に色を変化させるヘルパーメソッド。 extension UIColor { static func colorLerp(from: UIColor, to: UIColor, progress: CGFloat) -> UIColor { let t = max(0, min(1, progress)) var redA: CGFlo…

Swift カスタムビュー実装方法の記事まとめ

以前書いたカスタムビューの実装方法の記事一覧メモ xyk.hatenablog.com xyk.hatenablog.com xyk.hatenablog.com xyk.hatenablog.com

Swift で NSAttributedString 内の部分文字列を別の文字列に置換する方法

環境: Swift3 StroyBoard 上で UILabel の文字列を Plain ではなく Attributed で設定し、その文字列内の PlaceHolder を後から別の文字列に置き換えたいケースがあり必要になった。 NSMutableAttributedString#replaceCharacters(in:with:)メソッドを使用す…

UITextView を使ってテキストの一部をハイパーリンク化する

環境: Swift3 iOS10 UILabel ではなく UITextView の attributedText に NSLinkAttributeName をセットすることで簡単にできた。 クリック時にデフォルトでは Safari が起動して設定したURLのページが表示された。 クリック時の挙動を変更したい場合は UITex…

View の Auto Layout によるアニメーションを無効にする

環境: Swift3 あるViewのSubviewのレイアウトをAuto Layoutで行った時にアニメーションしながら配置された。 この時のアニメーションは不要なので無効にする。 やり方はSubviewの配置が行われるlayoutSubviewsメソッドをオーバーライドして以下のようにアニ…