TouchScript利用時にボタンが2回呼ばれる(iOS)

TouchScriptの現最新版(version 9.0)を使って、iOSに転送するとボタンが2回呼ばれることがある。
TouchScriptのレイヤーはFullscreen Layerを使ってる。
ログを見ると

UnityEngine.EventSystems.StandaloneInputModule:ProcessTouchPress
TouchScript.Core.TouchManagerInstance:updateReleased

と2回呼ばれている。UnityEditorでは発生しない。

Fullscreen Layerの代わりに、Standard Layerを使ってみたけど、今度はEventSystemにTouchScriptInputModuleというコンポーネントが設定され、指定のレイヤー以外のボタンが反応しなくなる。というかなんか挙動がおかしい… こっちはUnityEditorも含め。

Xcodeのパスのrecursiveの設定

PBXProjectなんかを使って、Xcodeの設定を書き換える際、パスのrecursiveを設定するには、パスの値に**とつければいい。
“$(PROJECT_DIR)/Frameworks/Plugins/iOS/**”
こんな感じ。

UIActivityのその他(more)を押すとスクリーンの方向が変わる

uiactivity_more

UnityにてSocialConnectorを使って、シェア機能を使っていて遭遇したんですが、横向きのみのアプリでこのSocialConnectorを使って、iOSのUIActiveViewControllerを呼び出し、そこからその他(more)を押すと許可するメディアの一覧が出てきます。
そのタイミングで端末の回転にロックがかかっていなく、端末自体がアプリの方向とは違う方向に傾いているとUnityのスクリーンの方向(Screen.orientation)が変わってしまった。。(横向きアプリのはずが縦向きなどになる)
1度発生してしまうとUnity上でScreen.orientationを書き換えてももう直らない。。。
取れる方法は、Screen.orientationをみて、本来の値と違っていたらエラーを出すとかになるでしょうか。
Unityのバグなのか、UIActivityのバグなのか、、、SocialConnectorではなさそうな気はするけど。

UIActivityのローカライゼーション

Unityで、Social Connectorを使うと簡単に、UIActivityが呼び出せる。

uiactivity

しかし、表記が英語になってしまう。
info.plistにてLocalization native development regionjaなどに変えれば指定の言語で表記されるようになる。
ただ、Localization native development regionは基本言語なので、ローカライズさせるには

UIActivity

こちらの値を変えたほうがいいかも。
XCodeProjectUpdaterを使う場合には、自分でつけ足す必要がある。
キーはCFBundleLocalizations、値はJapanseではなくja

ちなみに、LINEへの投稿を増やしたい場合には、iOS9以降許可するスキームの設定が必要。
XcodeProjectUpdaterにてApplication Queries Schemesの値を追加してみたけど、うまく反映されていなかった。
みてみたらSetApplicationQueriesSchemesの処理が抜けているようなので(僕が消した??)、その処理も加えて無事LINEへの投稿もできるようになりました。

ムービーを外部へ保存して扱う

mp4などのムービーをHandheld.PlayFullScreenMovieなどで使うときは、Unity用の変換がされないようにStreamingAssetsフォルダに格納する必要がある。
StreamingAssetsに置くとUnity用の変換がされず、生のデータとして扱えるけどムービーなどの大きなファイルの場合書き出した本体ファイルが大きくなってしまう。
そこで、アセットバンドルの仕組みでムービーを外部に置きたいけど、アセットバンドル構築の際に

‘MovieTexture’ is not supported when building for ****.

と怒られてしまう。
Continue…

SOOMLA@Unityによるストアの情報取得(値段とか)

課金を行う際に、値段やタイトルなどアプリに組み込むとタイトルの変更や為替の変動による価格の変更に対応するためアプリの再申請が必要になってしまう。
そもそも世界で売る場合は使用しているマーケットの国がわからないので金額が分かりませんね。
なのでマーケット(iTunes Store/Google Play)から直接取得した方がイイ。

SOOMLAだとまずはイベントのリスニング
[unitycsharp]
StoreEvents.OnSoomlaStoreInitialized += this.OnSoomlaStoreInitialized;
StoreEvents.OnMarketItemsRefreshFinished += this.OnMarketItemsRefreshFinished;
StoreEvents.OnMarketItemsRefreshFailed += this.OnMarketItemsRefreshFailed;

this.storeAssets = new StoreAssets();
SoomlaStore.Initialize(this.storeAssets);
[/unitycsharp]

そして、初期化完了後にマーケットの情報を取得しに行く。

[unitycsharp]
void OnSoomlaStoreInitialized() {
#if UNITY_EDITOR
this.OnMarketItemsRefreshFinished(new List<MarketItem>());
#else
SoomlaStore.RefreshMarketItemsDetails();
#endif
}
[/unitycsharp]

取得ができたら自分のストアの設定の情報を取得したMarketItemで上書き。

[unitycsharp]
void OnMarketItemsRefreshFinished(List<MarketItem> marketItems) {
// ストアの情報を取得したMarketItemで上書きさせていく
foreach (MarketItem item in marketItems) {
foreach (VirtualGood good in this.storeAssets.GetGoods()) {
PurchaseWithMarket purchaseType = good.PurchaseType as PurchaseWithMarket;

if (purchaseType.MarketItem.ProductId == item.ProductId) {
purchaseType.MarketItem = item;
}
}

StoreEvents.OnSoomlaStoreInitialized -= this.OnSoomlaStoreInitialized;
StoreEvents.OnMarketItemsRefreshFinished -= this.OnMarketItemsRefreshFinished;
StoreEvents.OnMarketItemsRefreshFailed -= this.OnMarketItemsRefreshFailed;
}
[/unitycsharp]

ここは…こんな感じでいいのかしら…?
手動でやるのかな?
ストアの情報の取得は稀に失敗することもあるので、何度かリトライさせる必要もありそうです。

SOOMLA@Unityによる、iOS, Androidでの課金方法

UnityでIAP(アプリ内課金)をやってみたのでメモ。(Store Version 1.8.2)
まず、どんなライブラリがあるのかはこちらが参考になります。
基本的にSOOMLAは課金周りの処理だけではなくて、ユーザーのアイテム管理、ショップ管理までサポートするフレームワークでそこに課金機能もサポートされているという感じ。ユーザーの持ち物をすべてOS側のデータ領域に保存してくれる。
アプリ内でショップ、持ち物の管理ができるので便利だけど、サーバー側でも同じような管理をする場合にはその辺の機能は使わず購入処理だけうまく使う感じになりますが、その場合はprime31なんかを使った方がシンプルかもしれません。(有料 iOS/Androidそれぞれ$70くらい)
今回はサーバーでアイテムを管理するものの、SOOMLAのソースコードやコメントがキレイだったり、アップデートが頻繁だったりSOOMLA側のスタッフやユーザーのコミュニティが活発だったのでSOOMLAを選んでみた。

SOOMLAで(消耗型)課金コンテンツの実装でのメモ。
そもそもアプリ内課金自体が初めてなので、各プラットフォームの下準備。
まずはiOS側の下準備。

Continue…