xyk blog

最近は iOS 開発の記事が多めです。

UITextField, UITextView 編集時にキーボードで隠れないようにする - Swift Protocol Extension 版

検証環境: Xcode 11.6 Swift 5.2.4 以前にも同様の記事を書いていますが、UITextField, UITextView を UIScrollView (やそのサブクラス、UICollectionView ・UITableView など)上に配置して、contentInset を変化させることでキーボードで隠れないようにしま…

Swift の Protocol Extension 内で Selector を呼び出す

検証環境: Xcode 11.6 Swift 5.2.4 Swift の Protocol Extension 内では @objc をつけたメソッドを実装しても #selector で呼び出しすることはできません。 例えば以下のコードでは NotificationCenter の引数で selector を指定しています。 protocol Keybo…

Swift - UIBezierPath で吹き出しのパスを描く

検証環境: Xcode 11.6 Swift 5.2.4 こんな吹き出しを UIBezierPath を使って描画してみます。 パスの描画順は以下図の流れになっています。 吹き出し部分は addQuadCurve メソッドを使い、曲線上の終点とコントロールポイント1つを指定します。 この時の終…

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】数値を3桁毎にカンマ区切りにした文字列にする

検証環境: Xcode 11.3 Swift 5.1.3 数値や金額の表記で3桁毎にカンマ区切りにした文字列に変換する方法についてです。 String.localizedStringWithFormatメソッドを使う、またはNumberFormatterを使うと言った方法があります。 let million: Int = 1_000_00…

はてなブログのMarkdownエディタで画像のサイズを変更する

ブログに挿入した画像のサイズを小さくする方法について。 div style で囲んで width を指定する。 <div style="width: 200px;"> [f:id:xyk:20200203150754p:plain] </div>

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

検証環境: Xcode 11.3 Swift 5.1.3 UITextView の任意の文字列のタップ可能なリンクにする方法についてです。 まず NSAttributedString.link 属性を使用してリンク化する text と range を設定します。 そして UITextViewDelegate の textView(_:shouldInter…

CGRect 構造体で使える便利なメソッド

offsetBy origin の移動 // 右下に移動 let newRect = rect.offsetBy(dx: 10, dy: 10) insetBy center は変えずに size の変更 let rect = CGRect(x: 20, y: 20, width: 100, height: 100) // 縮小する -> (x: 40, y: 40, width: 60, height: 60) let smalle…

UIStackView に背景色を設定する

検証環境: Xcode 11.3 Swift 5.1.3 UIStackView の backgroundColor プロパティに色を設定しても描画されません。 (※追記: iOS 14 から UIStackView の backgroundColor で背景色を付けられるようになりました。) そこで UIStackView の layer に CAShapeLay…

UIColor の2色間の中間色を表示する

検証環境: Xcode 11.3 Swift 5.1.3 2色間の中間色を補完する leap メソッドを UIColor の Extension として追加。 progress で割合を調整します。 import UIKit extension UIColor { func lerp(to: UIColor, progress: CGFloat) -> UIColor { return .lerp(f…

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

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

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

検証環境: Xcode 11.3 Swift 5.1.3 UITextView にプレースホルダーを設定できるカスタムビューを作成した。 import UIKit @IBDesignable open class PlaceHolderTextView: UITextView { @IBInspectable open var placeHolderText: String = "" { didSet { pl…

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 の仕様変更だった。 Apple Developer Documentation The UITableViewCell class no longer changes the backgroundCo…

Swift で Dictionary をマージする

検証環境: Xcode 11.1 Swift 5.1 Dictionary の mergeまたはmergingメソッドを使う。 // merging do { let a = ["a": 100] let b = ["a": 200, "b": 300] // 重複したKeyは a を優先させる場合 let result1 = a.merging(b) { (a, b) in a } print(result1) /…

Swift で 画像ビューワを実装する その4 - ネットワーク経由で取得する

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

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

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

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

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

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

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

UINavigationController を使って深い階層の ViewController に一気に遷移する方法

検証環境: Xcode 11.1 Swift 5.1 例えば Universal Links などの機能を使ってディープリンクで深い階層に一気に遷移させたい場合などに使える。 UINavigationController の setViewControllers(_:animated:) というメソッドがあるので、この引数に複数の Vie…

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

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

Finder のコンテキストメニューに「Visual Studio Code で開く」を追加する

環境: macOS Mojave 10.14.6 Finder の右クリックで表示されるコンテキストメニューからVisual Studio Codeでファイルをすぐに開きたい。 Automator を使用することで Finder のコンテキストメニューに新たなメニューが追加できる。 Automator を起動し、フ…

AdMob の app-ads.txt を設定する

iOS アプリの場合の話。 現在の設定状態は AdMob 管理画面のアプリ->すべてのアプリを表示->APP-ADS.TXT タブから確認できる。 以下は設定方法についての記述部分。 これを読んで最初わからなかったのが、「デベロッパー ウェブサイト」の設定はどこにするん…

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…