- 1. 画面の向きを固定する方法
- 2. iOSのLaunchScreen(スプラッシュ)が更新されない
- 3. building could produce unreliable results. This usually can be resolved by moving the target’s Headers build phase before Compile Sources. が Expoで出たときは
- 4. 音ゲー中の通知を防ぐ簡単な方法
- 5. ライブラリを分解して組み合わせて、車輪の再発明をするーードキュメントスキャナ
- 6. Flutterでダークモード時に画像を切り替える【Dart】
- 7. エラーが出て、 CocoaPods をインストールできない。「You don’t have write permissions for the /System/Library/Frameworks/Ruby.framework/Versions/2.6/usr/lib/ruby/gems/2.6.0 directory.」
- 8. [Swift]Delegateについて 初級編
- 9. URLProtocolでURLSessionの通信をハンドリングする
- 10. AIが文章の表現や文体をチェックしてくれるアプリを作った?
- 11. 斜めに置かれた書類をまっすぐにしたい。画像変形する技術がすごい
- 12. ショートカット+CoinGecko API+Subscan APIでDOT保有分を日本円換算した結果を確認する
- 13. iOSのNSTimeZoneのUTCってnameがGMTなんだ..
- 14. 【Swift】Combine ✕ Firestore ✕ Codableで通信処理を書く(取得・追加・削除の処理)
- 15. 【iOS】アーキテクチャ MVVM 解説してみた!
- 16. GitHub Actions から Autify for Mobile (iOS) テストを実行する
- 17. Fast-Neural-Style-TransferをiOS、MacOSで使えるようにする CoreML変換
- 18. [iOS/Android]FirebaseAuthの電話番号認証(SMS)にてボット判定(reCAPTCHA 検証)をなくす方法
- 19. WidgetKitで天気予報アプリ作ってみた〜記事まとめ〜
- 20. 2022年のiOS/Androidの技術をざっくりキャッチアップ
画面の向きを固定する方法
# 開発環境
Swift version 5.5.2
Xcode Version 13.2.1
Interface SwiftUI# 問題
SwiftUIを使用しアプリを開発しているが、
画面を横向きに固定できず回転してしまう。# 結論
xcodeprojで修正する
Xcode13だと効かないことがあるようですが、以下の手順全てを試したところ横向きのみに固定できました。
# 手順
1, Navigator areaのプロジェクト名をクリックし、.xcodeprojを開く。
2, TARGETS>`General`の`Device Orientation`で固定したい項目にチェックを入れる。|項目|内容|
|-|-|
|.portrait|通常|
|.portraitUpsideDown|逆さ|
|.landscapeLeft|左向き|
|.landscapeRight|右向き|上記だけだと解決できなかったため以下の手順も試しました。
3, 手順2の`General`ではなく`Info`を開く。
4, `Supported interfa
iOSのLaunchScreen(スプラッシュ)が更新されない
スプラッシュ画像を変更しようとしたところ、Xcodeの`LaunchScreen.storyboard`上は更新が反映しているが、Runしたりipa配布すると古いスプラッシュ画像のままという現象に遭遇してドハマリしたので解決方法を共有します。
10年以上iOSアプリ開発してるけど、今まではハマった記憶がない。。### 解決方法
* xcassetsの外に、元の画像名と異なる名前で画像を作成する
* LaunchScreen.storyboardからは↑で作成した画像を参照する### 原因
iOSのSpringBoardのキャッシュのせいみたいです。
デバイスを再起動すれば反映されるけど、開発者はそれでよくてもエンドユーザーには頼めないよね。ということで上記の方法をとりました。### 参考
http://arsenkin.com/launch_screen_image_cache.html
building could produce unreliable results. This usually can be resolved by moving the target’s Headers build phase before Compile Sources. が Expoで出たときは
Expoで開発しているとたまにこんなエラーが出ることがあります。
主に `expo build:ios` を実行したときです。
“`
Cycle inside “YOUR_APPS”; building could produce unreliable results. This usually can be resolved by moving the target’s Headers build phase before Compile Sources.
“`裏ではNativeBuildが走っているのですが、この記事の通り、何らかのビルドサイクルが狂ったときに起きるようです。
https://qiita.com/keisukeYamagishi/items/60aa5cf9d00ac6cf3b86
今回私が遭遇したパターンだと、ビルド中、もしくはiOS Simulatorで実行中に(ローカルサーバーが動いている状態)マシンを再起動したときです。
## 解決方法
上記の記事ではXCodeを使った開発の場合です。我々のようにExpoで開発しているプロジェクトの場
音ゲー中の通知を防ぐ簡単な方法
# はじめに
音ゲーや何かしらのアプリで楽しんでいる時に通知が来たらイラッとしたり邪魔だったりしますよね。
そんなストレスを簡単に解消できる設定をご紹介します。:::note warn
この記事はiOS限定です。
:::# ショートカットApp
iOSにはApple純正のショートカットというAppがあります。
[ショートカット on AppStore](https://apps.apple.com/jp/app/%E3%82%B7%E3%83%A7%E3%83%BC%E3%83%88%E3%82%AB%E3%83%83%E3%83%88/id1462947752)
![d230a25cb974f8908871af04caad89a1.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/588777/a5cef692-d129-75c5-cf4a-4df5f217019b.png)これを使えばワンタップで煩雑な一連の作業を自動で実行してくれたり、ある条件になると勝手にショートカットを実行してくれたり
ライブラリを分解して組み合わせて、車輪の再発明をするーードキュメントスキャナ
# 置かれた書類を検知して真っ直ぐにする機能を作ります
# 置かれた書類を自動検知して真っ直ぐにしたい
置かれた書類をカメラで撮影すると、斜めになることがあります。
それを自動で真っ直ぐに直してくれる機能があればいいですよね。で、iOSではVisionKitというフレームワークですでに実現できます。
![Mar-01-2022 08-45-00](https://user-imag
Flutterでダークモード時に画像を切り替える【Dart】
Xcode/AndroidStudioでそれぞれ開発するときは、ライトモード用とダークモード用の画像を用意しておくと勝手に切り替えてくれる機能がありますが、Flutterではそれを使うことができないようです。
以下のようにして対応します。
“`.dart
Image.asset(
Theme.of(context).brightness == Brightness.dark
? ‘assets/images/image_dark.png’
: ‘assets/images/image_light.png’,
),
“``(bool変数) ? (trueのときの処理) : (falseのときの処理)`の構文を利用して、
ダークモード(Theme.of(context).brightness == Brightness.dark)のときは、image_dark.png、
ライトモード(Theme.of(context).brightness == Brightness.light)のときはimage_light.png
を表示させます。[Twitte
エラーが出て、 CocoaPods をインストールできない。「You don’t have write permissions for the /System/Library/Frameworks/Ruby.framework/Versions/2.6/usr/lib/ruby/gems/2.6.0 directory.」
## 1. やりたいことを確認する。
#### CocoaPods をインストールしたい。
> CocoaPodsとは、定番のCocoaの依存管理マネージャーです。アプリ開発で煩雑となりがちな外部ライブラリの管理を、簡単な記述とコマンドだけ支援するものです。
>https://dev.classmethod.jp/articles/cocoapods/
こちらの記事を参考に、 CocoaPods をインストールしようとしているところ。
## 2. 課題(エラーの状況、不明点、エラーログ)を確認する。
#### ⚠️ cocoapods をインストールできない。
“`bash
$ sudo gem install cocoapods
Password:
Fetching rexml-3.2.5.gem
Fetching colored2-3.1.2.gem
Fetching claide-1.1.0.gem
Fetching atomos-0.1.3.gem
Fetching ruby-macho-2.5.1.gem
Fetching nanaimo-0.3.0.ge
[Swift]Delegateについて 初級編
# この記事を書いた理由
Swiftを勉強し始めて、ずっと分かんなかったよ。
難しい。難しいよDelegateの理解。というわけで、もしかしたら他にも同じ方いらっしゃるのではないかと思いDelegateについて備忘録的に私の理解を記載したいと思います。
Delegateは色々なされ方がありますが、まずは初級として概念的に理解していただければと思います。
まだ勉強中なので間違えていましたらご指摘いただけますと幸いです。# 目次
[1.Delegateとは?](#Delegateとは?)
[2.どんな時にDelegateは必要なの?](#どんな時にDelegateは必要なの?)
[3.メンドクサイから処理の一部を、他にやってもらう](#メンドクサイから処理の一部を、他にやってもらう)
[4.エラーが出てしまう理由](#エラーが出てしまう理由)
[5.protocolを使用する](#protocolを使用する)
[6.まとめ](#まとめ)# Delegateとは?
結論から言うと、Delegateとは **「あるクラスから他のクラスに処理を任せる」** というデザインパターンのこ
URLProtocolでURLSessionの通信をハンドリングする
# 概要
例えば、通信などが起きたときに、そのログを残しておいたり、通信量を調べたい時があると思います。
そんな通信のハンドリングを行うために、URLProtocolを利用します。## 通信をURLProtocol継承クラスに処理させる
通信をハンドリングするには、ハンドリングするためのURLProtocol継承クラスを用意します。ここではMyURLProtocolという名前にしました。
URLProtocol継承クラスの実装に関しては後ほど説明します。URLProtocol継承クラスを用意したら、各種通信がURLProtocol継承クラスを通して行われるようにします。
### URLSession.sharedの場合
もしURLSession.sharedしか使われていないのであれば、`URLProtocol.registerClass` を使うことで全てのURLSession.sharedの通信がURLProtocol継承クラスを通してハンドリングされます。“`swift
URLProtocol.registerClass(MyURLProtocol.self)
AIが文章の表現や文体をチェックしてくれるアプリを作った?
# はじめに
文章を分析してアドバイスをしてくれるAIアプリをリリースしました。今回はその機能と使用した技術についての記事になります。ダウンロードは画像もしくは[こちらのリンク](https://textcheckai.page.link/first)からどうぞ。ちなみに画像のキャラクターがAIの「ホメロス」です。[](https://textcheckai.page.link/first)
# ホメロスができること
![AI編集者が 文章チェック!のコピー-2.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/713689/12432fe4-f6a5-7f9a-28d2-2d09bff59378.png)## 文体分析
ユーザーが入力した文章を分析し、その文
斜めに置かれた書類をまっすぐにしたい。画像変形する技術がすごい
# ドキュメントスキャナーのような画像変形を行う方法です。
![Feb-27-2022 23-14-57](https://user-images.githubusercontent.com/23278992/155886008-ecf1d7cb-eea0-4923-9e42-d9499c4911e2.gif)# おいた書類をまっすぐに切り取りたい
書類などを机に置いて斜めから撮影すると、台形に移ります。
これをまっすぐな長方形にするには、画像を変形させる必要があります。# DDPerspectiveTransformが使える
ライブラリを使えば、手動で簡単に画像を整形できるUIがつかえます。https://github.com/d-dotsenko/DDPerspectiveTransform
# 使い方
DDPerspectiveTransformをプロジェクトに入れ、UIを表示します。
“`swift
let cropViewController = DDPerspectiveTransformViewController()
cropViewControll
ショートカット+CoinGecko API+Subscan APIでDOT保有分を日本円換算した結果を確認する
# 作成したもの
iPhoneで保有するDOTを日本円換算し、計算結果をクリップボードにコピーするショートカットを作成しました。ショートカット名:calcHoldDOT-JPY
https://www.icloud.com/shortcuts/09fa7af649ca4b1db1c228d474604c43
# 処理の流れ
1. [CoinGecko API V3](https://www.coingecko.com/ja/api/documentation?)を使用して**Polkadot**の日本円換算の値を取得するショートカットを実行して変数に設定
2. [Subscan API](https://docs.api.subscan.io/#introduction)を使用して指定したアドレスで保有するDOT(**Balance**)を取得するショートカットを実行して変数に設定
3. 1.と2.の変数を掛けて DOT保有量の日本円換算した結果をクリップボードにコピーし、ショートカットをの実行を停止
iOSのNSTimeZoneのUTCってnameがGMTなんだ..![GMT_UTC.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/152641/ac5ea486-92d4-d55f-c618-9febbf5f2194.png)
AndroidとiOSでTimeZoneのUTCにまつわる調査をしていたところ想定外の結果になったので書き残しておきます。誰か真相を知っていたら教えて下さい。
# GMTとUTCの違い
GMTとUTCの違いをググるとCITIZENの用語集とよくある質問リストが最初に出てくるhttps://citizen.jp/faq/detail/id1363
>両者は、目的も概念も算出方法もまったく異なりますが、日常生活に不都合のない精度の時間測定(整数の秒)であれば、ほぼ差がないと考えて問題ありません。
そう、ほぼ一緒と考えてよいということ。日本のAsia/Tokyo(+9:00)より9時間前のタイムゾーンということだ。
# Android(Kotlin)の場合
“`kotlin
import java.util.TimeZonef
【Swift】Combine ✕ Firestore ✕ Codableで通信処理を書く(取得・追加・削除の処理)
## はじめに
Combineを使った非同期処理として、`URLSession`は標準ライブラリが提供されておりますが、`Firestore`は自分で実装する必要があります。このあたりの日本語での情報量が、`URLSession`と比較して、未開拓に感じましたので、自分が実装したサンプルコードを記事にしてみました。
今回、書いた処理は、Firestoreからの**取得・追加・削除**の処理です。(CRUDの中では更新がありませんが、更新処理は追加処理とほぼ変わらないため割愛します。)
## 追記(2022/03/01)
@GleamingCake さんからコメント頂き、知ったのですが、公式リポジトリ内でコミュニティベースの`Combine`をサポートするAPIが実装されているようです。今回の記事で私が実装した方法とは少し異なりますが、同じユースケースが実現可能なメソッドがありましたので、リンクを載せさせていただきます。https://github.com/firebase/firebase-ios-sdk/tree/master/FirebaseCombineSwift
【iOS】アーキテクチャ MVVM 解説してみた!
# 目的
iOS開発における MVVM について知ること(キーワード: `データバインディング`, `リアクティブプログラミング`, `RxSwift`, `Combine`)
# MVVM とは?
`データバインディング`という仕組みを使用したアーキテクチャです。(データバインディング?超重要)構造は `M: Model` `V: View` `VM: ViewModel` となる。
**画面の描画 = View** と **プレゼンテーションロジック = ViewModel** を分離するためのアーキテクチャ。GUIアーキテクチャの1種。ViewとViewModelを`データバインディング`という仕組みで関連づける。
ViewModelの状態変更に同期してViewの状態も更新され、画面に反映される。
GitHub Actions から Autify for Mobile (iOS) テストを実行する
GitHub Actions から Autify for Mobile (iOS) テストを実行する方法を解説します。
## 前提
* Autify for Mobile(iOS) で Simulator テストを実行する
## fastlane 設定
Autify へアップロードするために、*.app を生成します。
以下の fastlane を設定します。
Autify は x86_64 Simulator で実行されるため、arm64 ではなく x86_64 の *.app を生成するようにしています。
`fastlane/Fastfile`
“`ruby
lane :build_simulator do
gym(
scheme: “MyApp”,
skip_package_ipa: true, # *.app を生成するため、*.ipa は不要
skip_codesigning: true # Simulator 実行のため署名不要
destination: “generic/platform=iOS Simulator”
Fast-Neural-Style-TransferをiOS、MacOSで使えるようにする CoreML変換
# Fast-Neural-Style-TransferをiOSで使う方法です
[iOS/Android]FirebaseAuthの電話番号認証(SMS)にてボット判定(reCAPTCHA 検証)をなくす方法# 概要
この記事ではFirebaseAuthの電話番号認証(SMS)にてボット判定(reCAPTCHA 検証)をなくす方法についてご紹介します。
今回iOS,Androidそれぞれボット判定を消す事が出来たのでそれぞれ解説します!# そもそもボット判定とは?
以下のような画面を指します。まずこのような画面が表示されたあとに
![スクリーンショット 2022-02-25 11.02.27.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/49347/a06d2f79-d54f-4d07-8e5d-b14e5c108553.png)このような画面が出る場合があります。
![l_mm_captcha_05_w290.jpeg](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/49347/89a1a2e7-ae64-e3c5-d431-334d8a8acb5f.jpeg)これをユーザにサインアップ、ログインしてもらう度に実施して
WidgetKitで天気予報アプリ作ってみた〜記事まとめ〜
## はじめに
この記事は**WidgetKitで天気予報アプリ作ってみた**シリーズで書いた記事のまとめです。## 記事一覧
1.天気情報取得編https://qiita.com/nkekisasa222/items/359192455b65fb60705d
2.位置情報取得 & 保存編
https://qiita.com/nkekisasa222/items/249240ad36128de05557
3.Widget Extension追加編
https://qiita.com/nkekisasa222/items/744754523172035cc9bf
4.タイムライン作成編
https://qiita.com/nkekisasa222/items/b22c98249330f3f5c459
5.View実装編
https://qiita.com/nkekisasa222/items/93991d64e8b5b5396b36
誰かの役に立てば幸いです!
## おしらせ
現在副業でiOSアプリ開発を募集しています。
ご依頼は[Twitter DM](ht
2022年のiOS/Androidの技術をざっくりキャッチアップ
ネイティブアプリにも宣言型UIとかなんかいろいろ入ってきたので、「いい加減そろそろ覚えないとな~~」ってなってる人は少なくないと思ってるんですけれど、一足先に一通り触ったのでどんな感じで学べばいいのかなという参考になればという感じの記事です。
# 宣言型UI
WebにjQueryがもたらされたとき、だれでも簡単に直接DOMを触ってViewを弄れるようになった結果、アプリの大規模化・保守の長期化に伴って手に負えなくなったので、それを解決するためにReact辺りが宣言型UIの思想を生み出した…というざっくりした認識を持ってるんですけれど、合ってるかは知りません。
とまれ、ネイティブアプリにも数周遅れではありますが宣言型UIの流れがきています。
## SwiftUI
SwiftUIの現在の最新バージョンは3です。
どんどん便利になるのはいいことなんですけれど、サポートするiOSのバージョン指定によっては使えない機能とかがあります…。
これは公式のコードなのですけれど、
“`swift
struct Content: View {
@State var model =