なんか来てたのでアップデートした。
「Swiftのバージョンで誤ったWarningが表示される問題を解決した」だそうです。
ビルドするとよくわかんないメッセージがいっぱい出てりするのが改善されたんだろうか?
追記:よくわかんないメッセージの量はあんまり変わらないような…?
2016年12月24日土曜日
2016年12月21日水曜日
有料アプリ販売のための登録
今まで無料アプリばかりだったけど、今回AppStoreで有料アプリを売ることにした。
アプリの審査通ったのに「iTunes Connectで契約/税金/口座情報の設定がまだだズラ」てなことが書かれたメールが届いた。
さっそくiTunes Connectにログインし、「契約/税金/口座情報」の入力をする。
参考
アップル公式iTunes Connect デベロッパガイド
アプリの審査通ったのに「iTunes Connectで契約/税金/口座情報の設定がまだだズラ」てなことが書かれたメールが届いた。
さっそくiTunes Connectにログインし、「契約/税金/口座情報」の入力をする。
参考
アップル公式iTunes Connect デベロッパガイド
Contract Type(契約タイプ)がPaid Application(有料アプリ)になってて、(たしか初めてアプリを申請した時に登録した)自分の名前と住所が表示されてるので、右のRequestボタンを押す。
Review Agreementの画面になるので、書かれた内容を精読し…って、英語で長々と書かれてて読めるかい!
たぶん読み飛ばしても無慈悲なことされないと思うので、I have read and agree to the agreement presented above.(読んで上記に従うよ)にチェックを入れてSubmit。
今度はContract Info、Bank Info、Tax Infoとか書かれてSet Upボタンが並ぶので、Contact InfoのSet Upから入っていく。
Manage Your Contact Informationの画面になるので、下のSenior Managementなど5つ全てをContactにあるメニューから選ぶ。
要はマネジメントのリーダーや財務担当者は誰かを指定するわけだが、個人なら自分の名前を選んでやればいい。
そしてDone。
今度はBank InfoのSet Upなんだけど、以前に無料アプリを審査に出した時に、銀行情報は登録しちゃったのね。全銀コードとか入力したり、いろいろ面倒だった。
んで、今回はCurrent Bank Accountに登録したのが出てきてるし、Select a different Bank Account:に他の口座は出てこないし、同じ口座情報を再登録しようとしてもはじかれるので、Cancelを押して前の画面に戻った。(Saveは内容に変更があった時しか有効にならない)
銀行情報のSet Upボタンが青いままだけど、税金情報に移る。
Tax InfoのSet Upを押す。
アメリカ、オーストラリア、カナダでの税金情報のSet Upボタンがあるけど、アメリカのだけでいいんだってさ。
「アメリカの市民か? アメリカに住んでるか? アメリカに会社があるか?」当然NoでSubmit。
他に何かアメリカでビジネスしてる? これもNo。
お次は長々と書かれてるけど、アメリカと日本で二重に課税されないための入力なんだそうな。
あらかじめ値が入ってる欄もあるし、空欄でいいところもあるそうな。必要箇所だけ入れればいいようだ。
ただし、一度送信すると変更できないようなので十分注意のこと。(と言われても内容がよくわからん)
I declare that the individual or organization named in 〜をチェック。
Who is authorized to sign this certificate? のTitleには個人だったらPresident(社長)って入れればいいって。
スクロールして下の方に入力する情報。
赤いところが記入要。
さっきも説明した二重課税回避のためにW-8BENという書類をアメリカのAppleに提出するらしいのだが、それにEINという米国納税者番号をあらかじめ取得して記入しなければならず(?!)、以下の参考サイト1によると、その取得がとっても大変らしい。
書き方が間違ってると受け付けてくれず、「出し直せ」という返事もくれないんだとか。
参考サイトでは「だから代理業者に頼んだ方がいい」ということだが、みんなそんなことやってるの?? なんか2〜3万かかるみたいなんですけど。
参考サイト3の情報だと、個人事業者は納税者番号は不要なので「000000000」でいいらしいとも?
Submitを一度押すと、「Submit押すとiTunes Connectから直しきかねーから、それでもよけりゃSubmit押せや」っておっかない赤字のメッセージが出るみたい。
俺とりあえずEINとか入れないでSubmitしちゃったけど…Σ(((°Д°;))))ガクガク
Submit押してからどうすりゃいいんだ!? W-8BENとか、EIN取得のための書類がメールで来るの?
参考
- Kentaro Shimizu/EINの取得
- raizan2ame/iTunes Connectの登録作業を実施
- studio heat Lab./iPhoneアプリ販売準備その2
- iPhone プログラミング トピックス/有料アプリケーションの契約、税金、銀行情報の入力
これで良かったのか?
夜にSubmitして、朝iTunesConnectでアプリのステータス見たらAppStore見たら、Ready for saleになってちゃんと販売されてたよ!
ありがとー! うん、ありがとー!
iTunes Connectの有料アプリの項目がContracts In Effect(事実上契約した)になったからいいみたい。
リリースされてる〜🎵
でも結局アップルに書類とか提出してないし、もちろんEINなんか入力すらしてないから、二重課税されるかどうかわかんないよ!🤣
実際どうなのよ?
アップルの公式デベロッパガイドの「日本の税務情報の入力」を読むと、- 米国で必要な税務情報を入力
- 本拠地が米国の場合は必要事項全て記入
- 本拠地が米国以外の場合は一連の質問に回答して適切な税務書類または証明書に進む
- ダイアログ下部にある文章中のlearn moreというリンクをクリックして表示された書類に情報を入力
- Appleが情報を処理後に追加書類の要件と提出書類を返送
- それに残りの情報を入力して印刷してAppleに郵送
- 日本国税庁の書類のオリジナルを正副2通送信要
- 米国の組織の場合はIRS(米国の国税庁だな)に書類提出要とあるが、日本だからいらないと思う
- Appleが書類を確認して日本国税庁に転送
- 日本国税庁から書類がAppleに返送されたら日本のAppStoreでの源泉徴収税率を更新
という流れのようである。
EIN(米国納税者番号)は取得せんでもええのんか? ほんまにええのんか?
そもそもこの情報が古いのか、learn moreなんてリンクはなかった。(ちゃんと更新してくれよ、アッポーさんよぉ)
この後PDFか何かが添付されたメールがAppleから届き、それを入力、印刷して送り返すことになるんだろうか?
何か動きがあったらまた追記する。
2016年12月14日水曜日
Xcode8.2変更点
iOS10.2とともにXcode8.2になったので、変更点をまとめとく。
MacAppStoreのキャプションを翻訳。
Xcode8.2はSwift 3、iOS10.2 SDK、watchOS 3.1、tvOS 10.1、そしてmacOS Sierra 10.12.2が含まれる。
- タッチ・バーは新しいアクションを得て、カスタマイズすることができます。
- シミュレーターは、シミュレーター・ウインドウの上にドラッグ&ドロップすることでアプリをインストールします。
- さらなるバグ・フィックスと安定性改善。
- タッチバーは新しいMacBookのですな。
- シミュレーターウィンドウにドラッグ&ドロップしてアプリをインストールとはなんぞや? プロジェクトファイルをドロップしてみたけどSafariが立ち上がってファイルを検索してるだけみたい? シミュレーター関係だからMacじゃないよな。
- バグフィクスされたのは良いことです。
とりあえずそんなところで。
2016年12月7日水曜日
Enum/Switch使用時はoptionalに注意
以下のようにEnumが定義されている時に、
しかし、
enum fukidasiState {
case 標準
case 枠だけ
case 透明
}
たとえば以下のようなswitch文を書く。
//currentの吹き出しを辞書から取り出す
let fd = fukidasiDic[currentFukidasiID]
//タップするたびに枠だけ、透明、不透明をスイッチ
switch fd?.fukidasiState {
case .標準:
(何かの処理)
case .枠だけ:
(何かの処理)
case .透明:
(何かの処理)
}
case .標準:
の行で「Enum case '標準' not found in type 'fukidasiState?'」というエラーが出てうまくいかない。
Xcodeで自動で修正候補を出してもくれない。
これはoptionalが関係するようで、以下のように( )!でくくってやるとうまくいく。
値がnilになる場合に?を付けたり、使用時に!でアンラップしたりとなんだかわかりにくいoptionalだ。
switch (fd?.fukidasiState)! {
Swiftを学習するならoptionalは重要な胆になるだろうね。
Enum以外、Switch以外でもエラーは出るけど、単純なものならXcodeで修正候補を出してくれるけど、今回のケースでは出してくれなかったのでだいぶ悩んでしまった。
optionalについてはSwift2.xでも仕様が変更されたり、いろいろめんどかった。早く仕様が固まってくれるといいが。
2016年12月3日土曜日
LandscapeでimagePickerがうまく表示されない
PortraitとLandscapeの両方に対応したアプリ作ってる。
写真ライブラリから選ぶためのUIImagePickerControllerが、公式にはPortrait表示にしか対応していないらしく、Landscapeで表示しようとすると強制的にPortrait表示になってしまう。(iPhoneだけ。iPadではうまくいく)
また、プロジェクトの設定でLandscape以外許可しない状態で表示しようとすると、クラッシュしてしまう。
今まで気にしたことなんかなかったけど、LandscapeのimagePickerって普通になかったっけ? iPadだけでiPhone持ってないから知らなかっただけ?
UIImagePickerControllerのAPIリファレンスには以下のように書かれている。
和訳(by おいら)
どうやらUIImagePickerControllerをサブクラスにしたカスタムクラスを作ることも禁止されているらしい。禁を破って作ると、リジェクトされるという噂もあるらしい。
ちなみにSwift2.xでは以下の書き方だった。
写真ライブラリから選ぶためのUIImagePickerControllerが、公式にはPortrait表示にしか対応していないらしく、Landscapeで表示しようとすると強制的にPortrait表示になってしまう。(iPhoneだけ。iPadではうまくいく)
また、プロジェクトの設定でLandscape以外許可しない状態で表示しようとすると、クラッシュしてしまう。
こういうアプリで |
こうしたいのに |
こうなっちゃう!? |
UIImagePickerControllerのAPIリファレンスには以下のように書かれている。
Important
The
UIImagePickerController
class supports portrait mode only. This class is intended to be used as-is and does not support subclassing. The view hierarchy for this class is private and must not be modified, with one exception. You can assign a custom view to the cameraOverlayView
property and use that view to present additional information or manage the interactions between the camera interface and your code.和訳(by おいら)
重要
UIImagePickerControllerクラスは、縦画面モードだけをサポートします。 このクラスは現状のままで使われることを目的として、サブクラスとすることをサポートしません。 このクラスのためのビューの階層はprivateで、例外的に修正されてはいけません。 あなたはカスタムビューをcameraOverlayViewのプロパティに割り当てることができて、追加情報を提示するか、カメラインターフェースとコードの間の相互作用を管理するために、そのビューを使うことができます。
どうやらUIImagePickerControllerをサブクラスにしたカスタムクラスを作ることも禁止されているらしい。禁を破って作ると、リジェクトされるという噂もあるらしい。
でもネット情報だとカスタムクラス作ったり、overrideして実現しちゃってるみたい。
ViewController.swift あたりのclassの外に以下を書いておけばいい。
extensionは既存クラスを書き換えたり、繼承なしで機能を拡張するためのもの。
extension UIImagePickerController
{
override open var supportedInterfaceOrientations:UIInterfaceOrientationMask {
return .all
}
}
extension UIImagePickerController
{
public override func supportedInterfaceOrientations() -> UIInterfaceOrientationMask {
return .All
}
}
Swift3.0からsupportedInterfaceOrientationsの定義が変更になったらしく、override open var〜で書かないと
method does not override any method from its superclass
なんてエラーが出ちゃう。
関数だったものが変数になったのね? なんだかよくわかんないけど。
無事に表示できたけど、このことが理由でリジェクトされないといいけどな。まあ海外のデベロッパー含めてやってるみたいだから大丈夫なのでは?
そもそもなんでLandscape表示もできるのに、Portrait表示しか対応してないって言ってるんだろうね?
参考
2016年10月26日水曜日
特別編:消えたユーザ辞書を復活
プログラミングと関係ないけど、Mac、iOS関係なのでこちらに書いておく。
macOS Sierraにしたら、ことえり(今もことえりって呼んでいいの?)のユーザ辞書が消えやがりましたよ。
以前のOSでもこういう不具合に悩まされてた人がいたみたいだけど、自分はこれが初めて。
iCloudドライブ経由で同期されるため、iPadに残ってればそこからMacにも反映させられるって情報もあったんだけど、その通りやってもiPadの方のが逆に消えてしまってお手上げだった。
今回、運よくTime Machineでバックアップが取ってあったので、それを使って復活させたわけ。
場所はユーザ/ユーザ名/ライブラリ/Dictionaries。
そこにあるユーザ辞書とUserDictionaryDescription.plistの二つをTime Machineで復活させる。
そしてシステム環境設定のキーボード/入力ソース/日本語の一番下にある追加辞書:に上記のユーザ辞書をドロップすればいい。
念のためにMacを再起動したけどね。
とりあえずうまくいってくれて助かった。
つーかさ、Sierra 10.12.0にアップデートして消えて、ちょこちょこ自分で辞書登録始めてたんだけど、10.12.1に上げたらまた消えたんだよね。
ユーザ辞書のトラブルはずいぶん昔からあるんだから、Appleもなんとかせいや。
編集した後にまた戻してやらないとユーザ辞書が消えてしまうことになる。
書き出されたユーザ辞書はテキストファイルになるので、それを開いて編集し、また戻してやればいい。
macOS Sierraにしたら、ことえり(今もことえりって呼んでいいの?)のユーザ辞書が消えやがりましたよ。
以前のOSでもこういう不具合に悩まされてた人がいたみたいだけど、自分はこれが初めて。
iCloudドライブ経由で同期されるため、iPadに残ってればそこからMacにも反映させられるって情報もあったんだけど、その通りやってもiPadの方のが逆に消えてしまってお手上げだった。
今回、運よくTime Machineでバックアップが取ってあったので、それを使って復活させたわけ。
場所はユーザ/ユーザ名/ライブラリ/Dictionaries。
そこにあるユーザ辞書とUserDictionaryDescription.plistの二つをTime Machineで復活させる。
そしてシステム環境設定のキーボード/入力ソース/日本語の一番下にある追加辞書:に上記のユーザ辞書をドロップすればいい。
念のためにMacを再起動したけどね。
とりあえずうまくいってくれて助かった。
つーかさ、Sierra 10.12.0にアップデートして消えて、ちょこちょこ自分で辞書登録始めてたんだけど、10.12.1に上げたらまた消えたんだよね。
ユーザ辞書のトラブルはずいぶん昔からあるんだから、Appleもなんとかせいや。
ユーザ辞書の書き出し
ユーザ辞書を書き出す場合も、上記を任意のフォルダにドラッグ&ドロップすればいい。その際、なぜか辞書はコピーされずに移動になってしまうので注意。編集した後にまた戻してやらないとユーザ辞書が消えてしまうことになる。
書き出されたユーザ辞書はテキストファイルになるので、それを開いて編集し、また戻してやればいい。
iCloudとの同期
上でも説明したライブラリのDictionariesフォルダ。
これのCoreDataUbiquitySupportフォルダを消して、iCloudを有効にしたままMacを再起動すると、iCloudからユーザ辞書がダウンロードされて復活するようだ。
一応うまくいったが、iPadの方で登録したのとまた違うようだ。
正直わからん。
2016年10月20日木曜日
コードで作ったオブジェクトが動かない時はARCを疑え
Storyboardで配置したUI部品(ボタンとかラベルとか)じゃなく、コードの中で作った部品が機能せず、「なんでじゃー!」と発狂したことなら皆さん何回かあると思います。
これって、本来はプロパティ(インスタンス変数)に保存しておかなけりゃいけないものを、関数の中だけのローカル変数に保存したばっかりに、関数を抜けた途端にARCが働いてガベージコレクションされちゃうからなのよね。
(実際にガベージコレクションするタイミングはARC任せだけど)
エラーやウォーニングが出るわけじゃないし、部品自体は画面に表示されたままだから、なんでじゃー! ってなるんだけど、iOSの仕組みを考えるとなるほどということになる。
UI部品ばかりじゃなく、音を鳴らすとかの場合にも、関数の中でサウンド関係のインスタンスを作って鳴らしたはずが鳴らなかったりするのは、やはり鳴り終えるまでガベージコレクションされない変数(要するにプロパティ)として保持しておかなきゃいけないのよね。
Storyboardで作ると自動的にプロパティが作られるので実感わかないけど、要はそういうこと。
これって、本来はプロパティ(インスタンス変数)に保存しておかなけりゃいけないものを、関数の中だけのローカル変数に保存したばっかりに、関数を抜けた途端にARCが働いてガベージコレクションされちゃうからなのよね。
(実際にガベージコレクションするタイミングはARC任せだけど)
エラーやウォーニングが出るわけじゃないし、部品自体は画面に表示されたままだから、なんでじゃー! ってなるんだけど、iOSの仕組みを考えるとなるほどということになる。
UI部品ばかりじゃなく、音を鳴らすとかの場合にも、関数の中でサウンド関係のインスタンスを作って鳴らしたはずが鳴らなかったりするのは、やはり鳴り終えるまでガベージコレクションされない変数(要するにプロパティ)として保持しておかなきゃいけないのよね。
Storyboardで作ると自動的にプロパティが作られるので実感わかないけど、要はそういうこと。
2016年9月26日月曜日
UIImagePickerControllerは自分で閉じる
フォトライブラリから画像を取得するコードをSwift 3.0で書いてるんだけど、うまくいかなかった。
上記で
と思ったら、
Delegateの設定
if UIImagePickerController.isSourceTypeAvailable(.photoLibrary) {
let imagePicker = UIImagePickerController()
imagePicker.delegate = self
imagePicker.sourceType = .photoLibrary
present(imagePicker, animated: true, completion: nil) //イメージピッカー表示
} else {
print("フォトライブラリが使えません")
}
imagePicker.delegate = self
と宣言するために、頭のところでUIImagePickerControllerDelegateと設定するだけじゃダメで、以下のようにUINavigationControllerDelegateも設定してやらないとエラーが出てしまう。
class ViewController: UIViewController, UIImagePickerControllerDelegate, UINavigationControllerDelegate { ~ }
UIImagePickerControllerのviewは自分で閉じよう
イメージピッカーで画像を選択したら、以下のdelegateメソッドが呼ばれるわけだが、
[Generic] Creating an image format with an unknown type is an errorというメッセージが出るばかりでイメージピッカーが閉じて画像をimageViewに表示してくれない。
func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) {
let image = info[UIImagePickerControllerOriginalImage] as! UIImage?
imageView.image = image
}
picker.dismiss(animated: true, completion: nil)
ってやって自分でイメージピッカーを閉じてやらにゃいかんのね。
今までObjective-Cでやってた時は自分で閉じてくれてたのに。
なんだろ、複数選択とかに対応したとかかね?
なおピッカーが閉じたところ、隠れてたimageViewには選択した画像がちゃんと表示されてた。
それでも[Generic] Creating an image format with an unknown type is an errorのメッセージは出るんだけど、これはXcode8になってから余計なメッセージが出る現象の一つかもしれないので、実用上問題なければ無視すればいいと思う。
それでも[Generic] Creating an image format with an unknown type is an errorのメッセージは出るんだけど、これはXcode8になってから余計なメッセージが出る現象の一つかもしれないので、実用上問題なければ無視すればいいと思う。
2016年9月21日水曜日
Swift3を使わない方法
Xcode8からデフォルトの言語がSwift3.0になったけど、いろいろ大きく変わるようで資料も少ないし、コンバーターかけても動かないコードが続出したり。
いずれ3.0を覚えなければいけないにしても、とりあえず今までのSwiftで書くやり方があった。
プロジェクトのTARGETS、Build Settings、Swift Compiler - Version、Use Legacy Swift Compiler VersionをYESにしてやるだけ。
これでSwift3を回避できる。
Xcode8以前は2.2だったけど、2.3に上がってはいると思う。
いずれ3.0を覚えなければいけないにしても、とりあえず今までのSwiftで書くやり方があった。
プロジェクトのTARGETS、Build Settings、Swift Compiler - Version、Use Legacy Swift Compiler VersionをYESにしてやるだけ。
これでSwift3を回避できる。
Xcode8以前は2.2だったけど、2.3に上がってはいると思う。
Swift 3 DEATHよ
Xcode8でSwift 3になったので、そっちへの気づいた変更点を書いていくですよ。
コードのトランスレーターダとSwift 2.4だかも選べるけど、3にしない理由はないと思うので、3のだけ書きますよ。
ざっと見たけど、いろいろ変わりやがったな。
全てをチェックしてらんない。
関数の引数にラベルを付ける方向で、NSのサフィックスを取る方向で、関数名を短くしたり、関数名と引数のラベルをセットで意味を持たせたり…
書くのが楽になったり、わかりやすくなったりしてるのかどうかわかんないけど、ちょこちょこ変えないでほしいよね…。
今までのアップデートだと、トランスレーターでちょっとした変更点は直してくれたけど、今回トランスレーターかけてもエラーになるところが山のように出たよ!!
何のためのトランスレーターだよ、この野郎!!
みなさん覚悟しましょう(≧∇≦)
コードのトランスレーターダとSwift 2.4だかも選べるけど、3にしない理由はないと思うので、3のだけ書きますよ。
ざっと見たけど、いろいろ変わりやがったな。
全てをチェックしてらんない。
関数の引数にラベルを付ける方向で、NSのサフィックスを取る方向で、関数名を短くしたり、関数名と引数のラベルをセットで意味を持たせたり…
書くのが楽になったり、わかりやすくなったりしてるのかどうかわかんないけど、ちょこちょこ変えないでほしいよね…。
今までのアップデートだと、トランスレーターでちょっとした変更点は直してくれたけど、今回トランスレーターかけてもエラーになるところが山のように出たよ!!
何のためのトランスレーターだよ、この野郎!!
みなさん覚悟しましょう(≧∇≦)
indexPathのプロパティをいじる時は as NSIndexPathとしないといけない
旧
let row = indexPath.row - alienPicsKeysArray.count
新
let row = (indexPath as NSIndexPath).row - alienPicsKeysArray.count
関数の第1引数のラベルがない場合、_ を付ける?
旧
func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
新
func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
UIColorの指定がcolor()がいらなくなった
旧
vc.bgSkyImageView.backgroundColor = UIColor.clearColor()
新
vc.bgSkyImageView.backgroundColor = UIColor.clear
列挙型の指定が先頭小文字になった
旧
UIView.setAnimationCurve(UIViewAnimationCurve.EaseInOut)
新
UIView.setAnimationCurve(UIViewAnimationCurve.easeInOut)
Booleanのプロパティがis〜になった
旧
vc.talkView.hidden = true
vc.cameraBtn.enabled = true
新
vc.talkView.isHidden = true
vc.cameraBtn.isEnabled = true
NSTimerがただのTimerに
どうやら全体的にNSのprefixがいらなくなったようだ。
旧
var urouroTimer = NSTimer()
新
var urouroTimer = Timer()
関数名が変わった
旧
finishTimer = NSTimer.scheduledTimerWithTimeInterval(rnd,
target: self,
selector: #selector(Cennina.finish),
userInfo: nil,
repeats: false)
}
新
finishTimer = Timer.scheduledTimer(timeInterval: rnd,
target: self,
selector: #selector(Cennina.finish),
userInfo: nil,
repeats: false)
}
CGRectMakeとかが CGRectとかに
CGPointMakeなんかもそう。
ラベルも必ずつくようになったのね。
旧
vc.ufoImage.frame = CGRectMake(0, 0, 200 * vc.倍率, 200 * vc.倍率)
新
vc.ufoImage.frame = CGRect(x: 0, y: 0, width: 200 * vc.倍率, height: 200 * vc.倍率)
レイヤーのaddAnimationがaddに
旧
vc.view.layer.addAnimation(transition, forKey: nil)
新
vc.view.layer.add(transition, forKey: nil)
Switch文の書き方
optionalな値を判断するcaseの値の前に?が。めんどくせえ!
旧
switch month {
case 1: //1月
msgJanuary(day)
case 2:
msgFebruary(day)
default:
print()
}
新
switch month {
case ?1: //1月
msgJanuary(day!)
case ?2:
msgFebruary(day!)
default:
print()
}
UserDefaultsの書き方
setする値が何でもsetだけで良くなったのだね。
読む時は型によって.object とか .boolとか指定しないといけない。
旧
let ud = NSUserDefaults.standardUserDefaults()
if let _ = ud.objectForKey("currentStage")
ud.setBool(soundFlag, forKey: "soundFlag")
ud.setObject(currentStage.rawValue, forKey: "currentStage")
let test = ud.objectForKey("currentStage")
新
let ud = UserDefaults.standard
if let _ = ud.object(forKey: "currentStage")
ud.set(soundFlag, forKey: "soundFlag")
ud.set(currentStage.rawValue, forKey: "currentStage")
let test = ud.object(forKey: "currentStage")
Info.plistをローカライズする
注意:結論から言うとうまくいきませんでした。
iOS10、Xcode8からプライバシー関連の設定が増え、例えば画像ライブラリにアクセスするコードを書く場合に、あらかじめInfo.plistの必要な項目にユーザーに伝える使用目的を明示するメッセージを書かなければいけなくなった。
(書いたメッセージがアクセス時にアラートで表示される)
ま、そりゃいいんだけど、そこに日本語用、英語用なんて項目はないんで、Info.plist自体をローカライズして日本語用、英語用を作ることになる。
やり方としてはInfo.plistを選んで、右側のインスペクタからLocalize...ボタンを押して云々なのでまあわかるだろう。
でもそれやってビルドしようとしたら、
メッセージの内容としてはInfo.plistが見つかんないから開けねぇぞってことだけど、ちゃんとplistファイルはある。
調べたところ、Xcodeの以前からのバグで、パスがおかしいんだそうな。
プロジェクトのパッケージ内容を開いてproject.pbxprojを開き、中の該当部分を絶対パスから相対パスに書き直すといいとあったんで見たけど、どうも最初から相対パスになってるっぽい。(参考リンクもう一つ)
一度Localizeのチェックを外し、再度チェックすると直るとか書いてあったんだけど、試してもダメ。
それ以外の情報もないようなので、メッセージは英語と日本語両方入れておく。ダサダサ〜。
後で解決方法がわかったら直します。
iOS10、Xcode8からプライバシー関連の設定が増え、例えば画像ライブラリにアクセスするコードを書く場合に、あらかじめInfo.plistの必要な項目にユーザーに伝える使用目的を明示するメッセージを書かなければいけなくなった。
(書いたメッセージがアクセス時にアラートで表示される)
ま、そりゃいいんだけど、そこに日本語用、英語用なんて項目はないんで、Info.plist自体をローカライズして日本語用、英語用を作ることになる。
やり方としてはInfo.plistを選んで、右側のインスペクタからLocalize...ボタンを押して云々なのでまあわかるだろう。
でもそれやってビルドしようとしたら、
error: could not read data from 'パス/アプリ名-Info.plist': The file "アプリ名-Info.plist" couldn't be opened because there is no such file.というエラーが出てビルドできなかった。
メッセージの内容としてはInfo.plistが見つかんないから開けねぇぞってことだけど、ちゃんとplistファイルはある。
調べたところ、Xcodeの以前からのバグで、パスがおかしいんだそうな。
プロジェクトのパッケージ内容を開いてproject.pbxprojを開き、中の該当部分を絶対パスから相対パスに書き直すといいとあったんで見たけど、どうも最初から相対パスになってるっぽい。(参考リンクもう一つ)
一度Localizeのチェックを外し、再度チェックすると直るとか書いてあったんだけど、試してもダメ。
それ以外の情報もないようなので、メッセージは英語と日本語両方入れておく。ダサダサ〜。
やむを得ずこうなった |
こんなとこで止まってリリースを遅らしちゃなんねぇ!!
登録:
投稿 (Atom)