- 1. Custom URL schemesとDeep Linkingの概要
- 2. はじめてのRevenueCat – (1) SDK稼働確認に必要なApp Store Connectでの対応
- 3. jsPDFでiOS Safariでもダウンロードダイアログを出してPDF保存(同じタブで開かないでくれ!!)
- 4. TextFieldに複数改行を入力させない
- 5. AppiumのiOS実機テストでWebDriverAgentのインストールに失敗するとき
- 6. メモリキャッシュとディスクキャッシュの違いと実装方法~パフォーマンスの比較~
- 7. SwiftUI 共有を簡単に実装できるShareLinkの使用方法
- 8. 【Xcode】RealmSwiftのマイグレーションエラー
- 9. テックカンファレンス初心者がiOSDC Japan 2024に現地参加してみて
- 10. モバイルアプリのクラッシュ原因を効率的に分析しよう
- 11. SFSpeechRecognizerは音声認識の権限を取らなくても利用できる
- 12. Warning: cocoapods not installed. skipping pod install.の対処法
- 13. 〜SwiftUIとFirestore DatabaseとFirebase Storage〜
- 14. pod update で target overrides the `EXCLUDED_ARCHS[sdk=iphonesimulator*]`
- 15. XcodeCloudのビルドに失敗する(sentry-cocoa)
- 16. SIGSEGV
- 17. SwiftUIでの柔軟な吹き出し作成とアニメーション化: Popoverから手作りまで
- 18. 【SwiftUI】Toggleのあるセルを行全体タップで値を切り替える方法
- 19. 【個人開発】ティアリストを作成するアプリを作ってみた話
- 20. ExpandableListView ≒ UITableView
Custom URL schemesとDeep Linkingの概要
## Custom URL schemes とは
### iOSの場合 (Custom URL schemes) : やや非推奨
> カスタムURLスキームは、アプリ内のリソースを参照する方法を提供します。たとえば、ユーザーがメール内のカスタム URL をタップすると、指定されたコンテキストでアプリが起動します。他のアプリが、特定のコンテキスト データを使用してアプリを起動するようにトリガーすることもできます。たとえば、フォト ライブラリ アプリは指定された画像を表示する場合があります。
>
> https://developer.apple.com/documentation/xcode/defining-a-custom-url-scheme-for-your-app#### 実装方法
##### 呼び出されるアプリにschemeを設定する
https://developer.apple.com/documentation/xcode/defining-a-custom-url-scheme-for-your-app
`CFBundleURLTypes`を設定すると
はじめてのRevenueCat – (1) SDK稼働確認に必要なApp Store Connectでの対応
## はじめに
現在、[サブスクアプリハッカソン](https://prtimes.jp/main/html/rd/p/000000003.000139088.html) に出場しています。このハッカソンでは、期間中にRevenueCatによるサブスク収益管理を行なっているアプリをストアにリリースすることが要件になっています。
https://prtimes.jp/main/html/rd/p/000000003.000139088.html
今回初めてリリースするアプリにRevenueCat SDKを実装するので、まずはRevenueCat SDKの動作確認を検証用のテストアプリで行いたいと考えました。RevenueCatはストアとのAPIにより収益管理を行うソリューションですので、iOSの場合はAppStore Connectにアプリが登録されていることが前提条件となります。ただ、これは単にアプリ登録しているだけではダメで、ストアとのAPIが使えるように一定の条件を満たす必要があります。RevenueCat の実装よりも、この対応に結構時間を使ってしまいました。
この記事で
jsPDFでiOS Safariでもダウンロードダイアログを出してPDF保存(同じタブで開かないでくれ!!)
## 結論
“`js
// jsPDFのインスタンスを作成
const pdf = new jsPDF()// ~ おのおのPDFをイイカンジに作成してください ~
// PDFをBlob形式で取得
const blob = pdf.output(“blob”);// typeがpdfだとiOSでダウンロードできないので、application/octet-streamに変更
const newBlob = new Blob([blob], { type: ‘application/octet-stream’ })// Blobを使って一時的なURLを生成
const url = URL.createObjectURL(newBlob);// ダウンロードリンクを作成
const link = document.createElement(“a”);
link.href = url;
link.download = “hogehoge.pdf”;// ダウンロードを開始
link.click();// メモリリークを防ぐため、URLを解放
URL.revok
TextFieldに複数改行を入力させない
# はじめに
以前[こちら](https://qiita.com/zensehakittoneko/items/6af329855896240179b1)の記事を公開しました。
今回も「TENBIN」で実装した機能についての記事を書こうと思います。もっとこうした方がいいとかあれば是非コメントをお願いします!
また、是非「TENBIN」で遊んでみてください!https://apps.apple.com/jp/app/tenbin/id6670417709
# 本文
「TENBIN」では投稿内容の入力画面でTextFieldを使用しています。![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/3808248/2b7b6a4d-b609-6698-a6c7-ec56b2c026eb.png)
ここの実装をしていた時に「これ、140文字分の改行を入力されたらどうすればいいんだろう?」と思いました。
パッと思いついたのは3パターン
①: DBから取得した表示内容に複数改行がある場合、単
AppiumのiOS実機テストでWebDriverAgentのインストールに失敗するとき
## 背景
AppiumをPythonで動かすにあたって、iOSの実機を接続して実行すると以下のようなエラーが発生した。(Tracebackから抜粋)“`
UnknownError: An unknown server-side error occurred while processing the command.
Original error: Unable to launch WebDriverAgent because of xcodebuild failure:
xcodebuild failed with code 65. This usually indicates an issue with the local Xcode
setup or WebDriverAgent project configuration or the driver-to-platform version
mismatch. Consider checking the WebDriverAgent configuration guide for real iOS devices
at
メモリキャッシュとディスクキャッシュの違いと実装方法~パフォーマンスの比較~
# はじめに
画像をキャッシュするという言葉をよく聞きます。キャッシュとは、一度読み込んだ内容を一時的に保存しておくことです。キャッシュすることにより再度同じ内容を閲覧する際に素早く読み込むことが可能になります。
以前にメモリキャッシュの実装経験はありましたが、ディスクキャッシュについては知りませんでした。そこでメモリキャッシュとディスクキャッシュの違いと実装方法とパフォーマンスの違いについて学んだ内容を紹介します。
# メモリキャッシュとディスクキャッシュの違い## **メモリキャッシュ (Memory Cache)**
メモリキャッシュは、アプリが実行中にデータを一時的にRAM(メモリ)に保存する方法。**メリット**
高速: メモリに保存されるため、データへのアクセス速度が非常に速い。**デメリット**
小容量: 小容量であるため、過剰なメモリ使用はシステムからアプリが強制終了される原因になる。**特徴**
揮発性: アプリが終了したり、システムのメモリが不足した場合、キャッシュデータは消失する。短期的なキャッシュの利用に適しており、アプリが閉じられた後に保持
SwiftUI 共有を簡単に実装できるShareLinkの使用方法
こちらはSwiftUIを使用しiOS16+のShareLinkの使い方です
今回は文字のシェアをします。
![Videotogif (11).gif](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/274615/4a87c438-578f-6931-798b-0f8afbf3ae7d.gif)
実装は簡単です
“`.swift
ShareLink(item: “Share Text”)
“`これだけで可能です。
引数にシェアしたい文字を設定してあげるだけになります。
【Xcode】RealmSwiftのマイグレーションエラー
# エラー文
::: note alert
Thread 1: Fatal error: ‘try!’ expression unexpectedly raised an error: Error Domain=io.realm Code=10 “Migration is required due to the following errors:
:::RealmSwiftを用いるアプリで、すでにシミュレーターでテスト済みのものに、新たに変数を追加すると上記のようなエラーが出てきてしまいました。
変数を追加するとは以下のような感じです。
“`Swift:CutomeMemo.swift
//変更前
@objc dynamic var memo: String = “”
@objc dynamic var detail: String = “”
“`“`Swift:CutomeMemo.swift
//変更後
@objc dynamic var memo: String = “”
@objc dynamic var detail: String
テックカンファレンス初心者がiOSDC Japan 2024に現地参加してみて
## はじめに
先月iOSDC Japan 2024(以降、iOSDC)が開催されましたね!
https://iosdc.jp/2024/
今回はじめてiOSDCに現地参加させていただいたのですが、正直想像以上によかったです。想像以上に楽しく、学びがあり、そして、また参加したいと思えるイベントでした。この熱が冷めやらぬうちにぜひともこの体験を共有したいと思い、今回こちらの記事にまとめてみました。
ここでお伝えしたいメッセージとしては、**初心者こそテックカンファレンスに現地参加したほうがいいかも!** ということです。
実は私、これまでテックカンファレンスに一度も参加したことがなく、かつiOSアプリエンジニア歴も浅いため、イベントに参加するまで非常に不安でした。さらに、自分の周りではiOSアプリエンジニアの知り合いがほとんどおらず、このこともイベント参加するにあたり大きな障壁となっていました。しかし実際に参加して感じたのは、「むしろ初心者
モバイルアプリのクラッシュ原因を効率的に分析しよう
モバイルアプリがクラッシュに至るまでの経路を俯瞰して把握し、より効率的に原因分析することを可能にするNew Relic Mobile User Journeyをご紹介します。
# New Relic Mobileとは
すでにNew Relic Mobileをご存知の方は次のセクションに飛んでいただいて大丈夫です。オブザーバビリティプラットフォームであるNew Relicの一機能であるモバイル監視機能(New Relic Mobile)は、モバイルアプリに組み込まれたSDKがモバイルアプリのパフォーマンスやエラー、ユーザー操作などを記録することで、モバイルアプリにおけるユーザー操作、パフォーマンスやアプリのエラー、クラッシュなどの問題を分析できる機能です。
SwiftやObjective-C、Javaなどで開発されたiOS/Androidのネイティブアプリはもちろん、FultterやReact Native、Xamarinなどのクロスプラットフォームフレームワーク、ゲームでよく利用されるUnity、Unreal Engineにも対応しています。
また、モバイルアプリと通信し
SFSpeechRecognizerは音声認識の権限を取らなくても利用できる
# 結論
以下の両方を満たす場合には音声認識の権限が不要
– サポートされているLocaleでRecognizerを生成
– `requiresOnDeviceRecognition`をtrueにする
– 言語アセットがインストールされている# `SFSpeechRecognizer.requestAuthorization()`しなくて良い説
ドキュメントに音声認識の権限取得方法に関する記述はある。https://developer.apple.com/documentation/speech/asking_permission_to_use_speech_recognition
が…取得しなければならないとは書いてないっぽい。
コードは省略するが、以下設定で音声認識をする場合は`requestAuthorization`しなくても音声認識できた。
– `SFSpeechAudioBufferRecognitionRequest.requiresOnDeviceRecognition`をtrueにする
– ローカルで音声認識する設定
– on-device
Warning: cocoapods not installed. skipping pod install.の対処法
## 概要
すでにcocoapodをインストールしてあるのにも関わらず上記のエラーが表示された解決方法のメモです。## 環境
– macOS (M1)Sonoma 14
– Android Studio Giraffe |2022.3.1
– Flutter 3.22.3
– Dart 3.4.4
– cocoapod をhomebrew経由でインストール済み## 解決した手順
– M1で必要な手順らしい(要らないかも)
“`
sudo arch -x86_64 gem install ffi
arch -x86_64 pod repo update
arch -x86_64 pod install
“`
command + Tab + q などでAndroid Studioを完全に終了させる
以下のコマンドを実行する
“`
open /Applications/Android\ Studio.app
“`## 参考
https://qiita.com/tetsukick/items/24ffa82f84682e0066d0
https://hack-it-iron
〜SwiftUIとFirestore DatabaseとFirebase Storage〜
# はじめに
「-TENBIN-」という多数決アプリを作成しました!このアプリでは画像を使いたいと思っていてやり方を探していたら、**Firestore Database**と**Firebase Storage**を組み合わせると出来そうだったのでその仕組みで実装してみました!
きっと誰かの役に立つと信じて、実際のソースコードを一部ですが公開します。
イメージを掴むための参考程度にご覧ください!最後にアプリ紹介とかアプリアイコンについて書いてあるので、良かったら最後までご覧ください!
https://apps.apple.com/jp/app/tenbin/id6670417709
# ソースコード
– SearchPosterViewModel.swift
– `fetchPosters()`でFirestore Databaseのデータを全件取得できます。
– `searchPosters()`はsearchTextをキーワードとしてFirestore Databaseから検索ができます。– FireStoreUploadModel.swift
pod update で target overrides the `EXCLUDED_ARCHS[sdk=iphonesimulator*]`
# 背景
CocoaPods を使用しているプロジェクトで pod update を行った際に以下のエラーが発生しました。“`
[!] The `MyApp [Debug]` target overrides the `EXCLUDED_ARCHS[sdk=iphonesimulator*]` build setting defined in `Pods/Target Support Files/Pods-MyApp/Pods-MyApp.debug.xcconfig’. This can lead to problems with the CocoaPods installation
– Use the `$(inherited)` flag, or
– Remove the build settings from the target.
“`# 対応
`EXCLUDED_ARCHS` に設定されている値の前に `$(inherited)` を追加することで解決しました。![スクリーンショット 2024-08-29 23.31.33.png](htt
XcodeCloudのビルドに失敗する(sentry-cocoa)
## Xcode Cloudの実行環境
日付:2024/09/03
Xcode バージョン: Xcode 15.4(15F31d)
MACOS バージョン: macOS Sonoma 14.2(23C64)## エラー内容
“`
…
Adding spec repo `trunk` with CDN `https://cdn.cocoapods.org/`Downloading dependencies
Installing AmazonIVSBroadcast (1.20.0)
Installing LicensePlist (3.25.1)
Installing Periphery (2.21.0)
Installing Sentry (8.33.0)
[!] Error installing Sentry
[!] /usr/bin/git clone https://github.com/getsentry/sentry-cocoa.git /Volumes/workspace/tmp/d20240902-6264-iu5rmu –template=
SIGSEGV
iOSアプリの開発をしていると、クラッシュしたときにを見かけます。これはどういう意味なのでしょうか?
# SIGSEGVとは
**SIGSEGV**(”Segmentation Violation”の略)は、アプリが不正なメモリアクセスを行ったときにオペレーティングシステムから送られるシグナルです。具体的には、アプリがアクセスしてはいけないメモリ領域にアクセスしようとした場合に発生します。例えば、NULLポインタの参照や、メモリが確保されていない領域に書き込みを行おうとしたときです。このようなエラーが発生したときにクラッシュさせないと、システム全体の安定性が脅かされ、さらに深刻な問題(例えばデータの破壊やセキュリティの脆弱性)が引き起こされる可能性があります。そこでシステムはアプリを即座に停止させて、システムの健全性を維持しようとします。
iOSアプリの開発中に見かける似たようなエラーのキーワードとして、EXE_BAD_ACCESSやKERN_INVALID_ADDRESS、SIGNAL 11やSegmentation Fault: 11があります。EXE_BAD_ACCESSは
SwiftUIでの柔軟な吹き出し作成とアニメーション化: Popoverから手作りまで
この記事についての詳細説明となります。
# 1. SwiftUIでのPopoverを使った吹き出しの作成
この記事では、SwiftUIを使って吹き出しを作成する手法が解説されています。最初に紹介されているのは、popover(isPresented:arrowEdge:content:) を利用したシンプルな方法です。Popoverは、iOS開発者にとって便利なツールであり、簡単に使用できる点が魅力です。この方法を使うことで、ユーザーインターフェース内に簡単な吹き出しを表示させることができます。具体的なコードとしては、HStack内に配置されたText要素に対して、popoverメソッドを適用しています。このpopoverメソッドには、表示を制御するためのブール型の状態変数と、吹き出しをどの方向に表示するかを指定するarrowEdge、そして表示するコンテンツを指定するクロージャが渡されます。これにより、ユーザーがボタンを押すと、指定された方向に吹き出しが表示される仕組み
【SwiftUI】Toggleのあるセルを行全体タップで値を切り替える方法
## こうする
“` swift
@State var isOn = false
~~~Toggle(isOn: $isOn, label: {
Text(“Toggle Test”)
})
.contentShape(Rectangle())
.onTapGesture {
self.isOn.toggle()
}“`
`.contentShape(Rectangle())` と `.onTapGesture` を一緒に書くことで、
行全体タップしたときに、Toggleの値を切り替えることができる。
行の中の空白部分をタップしてもイベントを拾うようになる。### 環境
* Xcode 15.4### 参考
https://stackoverflow.com/questions/57191013/swiftui-cant-tap-in-spacer-of-hstack
【個人開発】ティアリストを作成するアプリを作ってみた話
## はじめに
最近、YouTubeで動画を見ていると、ゲームやカードなどを『ティア』というランク形式で分類する動画をよく見かけます。この形式は情報を簡潔に伝えられるため、とても便利だと感じました。そこで、自分でも簡単にティアリストを作成できるアプリを作ってみることにしました。
### 開発したアプリ
本題に入る前に、まずは開発したアプリをご紹介します。このアプリは現在、App Storeで公開中です。気に入っていただけたら、レビューしていただけると幸いです。
[App Storeのリンク](https://apps.apple.com/jp/app/%E3%83%86%E3%82%A3%E3%82%A2%E3%83%A1%E3%83%BC%E3%82%AB%E3%83%BC/id6667102590)
[](http
ExpandableListView ≒ UITableView
Android の [ExpandableListView](https://developer.android.com/reference/android/widget/ExpandableListView) って見た目をほぼ iOS の [UITableView](https://developer.apple.com/documentation/uikit/uitableview) にできるよねって話です。
左:Android (ExpandableListView)、 右:iOS (UITableView)
![cropped.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/3853334/35b99f80-78c1-95a3-2993-7ec8a1e0430e.png)iOS の UITableView は、特に難しいことをしなくてもセクション + 行 というのが作れますが、Android の場合は、ExpandableListView 用のアダプターを作成する必要があります。
ちょっぴり