2015年10月30日金曜日

[iOS] アプリ審査「3.4.そのアプリ名は認めないよ」によるリジェクト体験記

背景

またも、リジェクトされてしまいました・・・
Appleさん厳しいですね・・・

今回は以下の理由でリジェクトされてしまいました。
3.4 - App names in iTunes Connect and as displayed on a device should be similar, so as not to cause confusion
和訳)iTunes Connectでのアプリ名とデバイスに表示される名前は、混乱を生じないために同様であるべきです
参考:App Store Review Guidelines

具体的に見ていきましょう。

2015年10月21日水曜日

Apple Developer Program が統一されて初めての更新!(更新方法)

背景

iOS開発者には年に1度必要な「Developer Program」の更新がありますよね。

私の場合は、数年前に「iOS Developer Program」に登録して以来、10月頃になると更新しないといけないなーと感じるようになっています。
参考:更新されたメンバーシップの詳細

ただし、今年はいつもと違い2015/06/08以降「iOS Developer Program、Mac Developer Program、Safari Developer Program」が、「Apple Developer Program」に統一されて、初めての更新になります。

そんな更新をレポートしていきたいと思います!

2015年10月15日木曜日

[iOS] アプリ申請 超特急レビューの申請方法&体験談【iTunes Connect】


背景

先日、iOS9のURLスキームの扱い変更によりLINE連携ができなくなってしまたので、BugFixをして、AppStoreへのiOS申請を行った。
参考:iOS9でLINE連携ができなくなった理由と対処法

そのときに「Expedited Review(超特急レビュー)」をお願いすることにしたので、そのときの体験話をしようと思う。

今回、不具合が見つかったのは、「 【くまのがっこう】ジャッキーのほしあつめ」になります。

2015年10月6日火曜日

[iOS]【図解】テストアプリを実機で実行するのに面倒なプロビジョニングプロファイル作成を省略する!


背景

iOS(Xcode)で実装をしている際、ちょっと試すためにテストアプリを作りたい場合がある。

端末内だけでシュミレーターを使える場合は問題ないけれど、実機でしか利用できないセンサーなどの動作を試したり、誰かに見せるために実機にインストールしたい場合には、プロビジョニングプロファイルが必要である。

これが面倒なんですよね・・・

実はこれ省略できます。
さて、環境を作っていきましょう。

2015年9月30日水曜日

[iOS] アプリ申請「In Review」で長い期間 放置された話


背景

先日、アプリをリリースしようとアプリ申請をしたところ、ステータス「In Review」のままで、長い間放置されたときの話をしようと思います。
今回、放置されてしまったのは、私がアプリ申請した「 【くまのがっこう】ジャッキーのほしあつめ」になります。

2015年9月28日月曜日

[iOS] アプリ申請 2.25でジェクトされた話とその解決方法


背景

先日、アプリをリリースしようとアプリ申請をしたところ、リジェクトされてしまいました。
今回、問題になったのは、私がアプリ申請した「 【くまのがっこう】ジャッキーのほしあつめ」になります。

2015年9月9日水曜日

[XCode]【Your account already has a valid iOS Distribution certificate】AdHoc出力できないときの対処方法

エラー


Your account already has a valid iOS Distribution certificate
If you have your signing identity on another Mac, you can import a developer profile.
You can also revoke the current certificate and request one again.

背景

Macを新しくしてから、以前に作成したアプリをAdHoc出力しようとしたときに出たエラーです。

Provisioning Profiles は確かに新しくしたはず。
実機でデバッグもできるし、特に問題なくいけていると思っていたのに・・・

いろいろな原因があるのだと思うが、私の場合は次の方法で解決ができました。


2015年8月17日月曜日

[XCode]【App installation failed】実機で実行できないときの対処方法

エラー


App installation failed
The application could not be verified.

背景

ついさっきまで実機実行できていたのに、上記のインフォメーションとともに、なぜか急に実機で実行できなくなってしまった。

何度ビルドかけても、ビルドは成功するんですが、実機で実行できない。

やったことといえば、iPhoneのバージョンアップのお知らせがきて、休憩がてらバージョンを3.4.1にあげたことくらい。
まあこれが原因なんだろうとググったところ解決方法は簡単でした。


2015年8月7日金曜日

[XCode] アプリ作成時によく見るエラーとその解決法 まとめ


はじめに

XCode(Objective-C)でよく見るエラーや警告を集めました。

前々からこういう整理した記事が個人的に欲しかったので作ってみました。

解決方法はざっくりと書きます。
詳細な解決方法はリンク先の記事(当ブログ記事や別サイト記事)に委ねます。

この記事は随時、追加や更新をして、今後どんどん育てていく予定です。
参照するたびに変更になっている可能性があります。ご了承ください。
今後、当ブログでエラーの記事を書いた場合は、別途記事を書いた上で、ここにリンクする予定です。

では、始めてまいりましょう。

2015年7月29日水曜日

[cocos2dx] でローカライズに対応する【LocalizedString】


ローカライズ関数を用意した理由

理由も何もないんですが、cocos2d-xで気軽にObjective-cで利用できるようなローカライズ関数が欲しいなと思い、作成しました。

今回はそんなローカライズ関数です。



実際の関数

はじめに。
この関数は以下の記事の関数を利用しています。
cocos2d-xで文字列を置換する【Replace】
cocos2dでトリミング関数を作る【trim】
cocos2d-xで文字列をデリミタで分解しリスト化する関数を作る【split】

次にこの関数を利用するには、[ja.lproj]や[en.lproj]などのLanguageごとのフォルダを用意し、それぞれにローカライズファイル[Localizable.strings]用意する必要があります。
【ja.lproj/Localizable.strings】
test=テスト
hogehoge=ほげほげ
【en.lproj/Localizable.strings】
test=Test
hogehoge=HogeHoge

【注意】
ローカライズファイル[Localizable.strings][File Type]は、[Localizable Strings]から[Plain Text]に変更して進める必要があります。
これをしておかないと、コンパイル時にファイルが最適化され、getStringFromFile()によるロードがうまくいきません。



使い方


こんな感じで使います。
std::string result = LocalizedString("hogehoge", "ほげほげの取得");
//result は日本語環境では "ほげほげ" となります
//result は英語環境では "Hogehoge" となります

簡単な説明

static map<std::string, std::string> localizable;
ローカライズ文字列のマップデータは、静的変数にセットすることで、無駄なファイル解析を避けます。

if(localizable.empty()){
ローカライズ文字列のマップデータがない場合に、1度だけローカライズファイルを解析します。

FileUtils* fileUtil = FileUtils::getInstance();
LanguageType language = Application::getInstance()->getCurrentLanguage();
if (language == LanguageType::JAPANESE) {
    fileUtil->addSearchPath("ja.lproj");
if (language == LanguageType::★★★★) {  //ローカライズしたいLanguageTypeを指定
    fileUtil->addSearchPath("★★★★");   //LanguageTypeごとのフォルダを指定
} else {
    fileUtil->addSearchPath("en.lproj");
}
ローカライズファイルのあるディレクトリを検索対象パスに追加します。

std::string fullpath = fileUtil->fullPathForFilename("Localizable.strings");
std::string strings = fileUtil->getStringFromFile(fullpath);
if (strings == "") return ret;
ローカライズファイル(Localizable.strings)を読み込みます。

list<std::string> stringLines = split(strings, "\n");
行ごとに分解して、以降の処理を実施します。

for(list<std::string>::iterator begin = stringLines.begin(), end = stringLines.end(); begin != end; ++begin){
    list<std::string> stringKeyValue = split(*begin, "=");
    if(stringKeyValue.size() >= 2){
        list<std::string>::iterator keyv = stringKeyValue.begin();
        localizable.insert(pair<std::string, std::string>(*keyv, *(++keyv)));
    }
}
1行ごととり出し、"="でkeyとvalueに切り出し、ローカライズ文字列のマップデータに設定します。

map<std::string, std::string>::iterator iterator = localizable.find(searchKey);
if(iterator != localizable.end()){
    ret = iterator->second.c_str();
}
ローカライズ文字列のマップデータから、対象のデータを取り出し返却します。

std::string result = stringReplace(ret, "\\n", "\n");
最後に対象データの改行をケアしています。


このプログラムが皆様のお役に立てば幸いです。

ではまた。


2015年7月28日火曜日

[cocos2dx] で文字列をデリミタで分解しリスト化する関数を作る【split】


文字列のデリミタ分解する関数を用意した理由

文字列を分解して作業したい場合があります。
分解した文字列はリスト化して便利に取り出して利用することができます。

私の場合、設定値を文字列にしたものをロードしたり、csv分解したりするのに利用しました。

今回はそんな文字列をデリミタで分解しリスト化する関数です。



実際の関数

はじめに。
この関数は以下の記事の関数を利用しています。
cocos2dでトリミング関数を作る【trim】


使い方


こんな感じで使います。
std::string result = split("I;My;Me;Mine", ";");
//result は "I","My","Me","Mine" のリストが返却されます。

簡単な説明

while( (cutAt = str.find_first_of(delim)) != str.npos ) {
デリミタ文字を検索し、ループします。

if(cutAt > 0) {
    result.push_back(trim(str.substr(0, cutAt)));
}
デリミタ文字までの文字列を結果リストに追加します。

str = str.substr(cutAt + 1);
次の準備のために、追加した文字列分は切り落とします。

if(str.length() > 0) {
    result.push_back(trim(str));
}
上記ループでは最後が追加されないので、残りの文字列を結果リストに追加します。



このプログラムが皆様のお役に立てば幸いです。

ではまた。

2015年7月27日月曜日

[cocos2dx] でトリミング関数を作る【trim】


文字列のトリミング関数を用意した理由

スペースだけのトリミングはよくあるんですが、スペースはもちろんのこと改行やデリミタも含めてトリミングできたらなーと思って作りました。

今回はそんな文字列のトリミング関数です。



実際の関数



使い方


こんな感じで使います。
std::string result = trim("I am Tom;  ");
//result は "I am Tom" となります

簡単な説明

std::string::size_type left = str.find_first_not_of(trimCharacterList);
対象文字(デリミタ文字)の含まれない左端を取得します。

if (left != std::string::npos) {
左端の取得に成功した場合は以下の処理を続行します。

std::string::size_type right = str.find_last_not_of(trimCharacterList);
対象文字(デリミタ文字)の含まれない右端を検索します。

result = str.substr(left, right - left + 1);
最後に左端から右端までをtrim内容として取得し、返却します。



このプログラムが皆様のお役に立てば幸いです。

ではまた。


2015年7月26日日曜日

[cocos2dx] で文字列を置換する【Replace】


文字列の置換関数を用意した理由

画面に見える文字列を整形する場合なんかは「StringUtils::format」でほとんどがなんとかなるんだけれど、内部データを整形する場合(例えばデリミタを置換したり、改行を入れてみたり)なんかは、文字列をまるっと置換できる仕組みがあったほうが嬉しかったりします。

今回はそんな文字列の置換関数です。



実際の関数



使い方


こんな感じで使います。
std::string result = stringReplace("I am Tom", "Tom", "Hogehoge");
//result は "I am Hogehoge" となります

簡単な説明

while(pos = result.find(from, pos), pos != std::string::npos) {
まずターゲットとなる文字列の開始位置を検索しながらループします。

result.replace(pos, from.length(), to);
次にターゲットとなる文字列を、置換する文字列に変換します。

pos += to.length();
ループの最後で次の文字列検索の準備をしています。



このプログラムが皆様のお役に立てば幸いです。

ではまた。


2015年7月24日金曜日

[Objective-C] iOSアプリにソーシャル機能を組み込む【実践編】

はじめに

以前に投稿した下の記事でソーシャル機能の分析と目的、効果について少し書きました。
人気アプリから学ぼう 「ねこあつめ」その5:ソーシャル機能を分析しよう!編

今回はそれの実践編です。

基本的にはコードを見てもらえば、理解していただけると思うのですが、それぞれ少しづつ注意点があるので、確認してください。




Facebookへの投稿

利用するには、Social.frameworkの追加が必要です。


【簡単な説明】
SLComposeViewController *facebookPostVC = [SLComposeViewController composeViewControllerForServiceType:SLServiceTypeFacebook];
[facebookPostVC setInitialText:text];
[facebookPostVC addURL:[NSURL URLWithString:url]];
[facebookPostVC addImage:[UIImage imageNamed:image]];
[facebookPostVC setCompletionHandler:^(SLComposeViewControllerResult result) {
    if (result == SLComposeViewControllerResultDone) {
        //投稿完了の処理
    }
}];
[ViewController presentViewController:facebookPostVC animated:YES completion:nil];
SLComposeViewControllerを利用して、Facebookに対し、投稿テキスト、URL、イメージを投稿しています。
投稿完了時にはイベントを受け取り、投稿のお礼メッセージや、プレゼントなど処理をします。


Twitterへの投稿

利用するには、iOSバージョンごとに適切なframeworkの追加が必要です。
iOS6.0以上の場合、Social.frameworkの追加が必要
iOS5.0以下の場合、Twitter.frameworkの取り込みが必要


【簡単な説明】
NSString *iosVersion = [[[UIDevice currentDevice] systemVersion] stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
if ([iosVersion floatValue] >= 6.0) {
}
else if ([iosVersion floatValue] >= 5.0) {
}
iOSのバージョンで、Social.frameworkを使うか、Twitter.frameworkを利用するかを決定しています。

SLComposeViewController *twitterPostVC = [SLComposeViewController composeViewControllerForServiceType:SLServiceTypeTwitter];
[twitterPostVC setInitialText:text];
[twitterPostVC addURL:appURL];
[twitterPostVC addImage:[UIImage imageNamed:image]];
[twitterPostVC setCompletionHandler:^(SLComposeViewControllerResult result) {
    if (result == SLComposeViewControllerResultDone) {
        //投稿完了の処理
    }
}];
[ViewController presentViewController:twitterPostVC animated:YES completion:nil];
SLComposeViewControllerを利用して、Twitterに対し、投稿テキスト、URL、イメージを投稿しています。
投稿完了時にはイベントを受け取り、投稿のお礼メッセージや、プレゼントなど処理をします。

Lineへの投稿

frameworkは必要ないですが、テキストとイメージが別々にしか投稿できません。
また、投稿完了を受取ることができないので、利用には注意が必要です。


【簡単な説明】
text = [text stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
NSString *LINEUrlString = [NSString stringWithFormat:@"line://msg/text/%@", text];
LINEに文字列を投稿するためのURLを作成します。
LINEへは「line://msg/text/(投稿したい文字列)」というURLスキーマを利用して投稿することになります。

//iOS7.0以降では共有のクリップボードを使う必要がある
UIPasteboard *pasteboard;
if ([[UIDevice currentDevice].systemVersion floatValue] >= 7.0) {
    pasteboard = [UIPasteboard generalPasteboard];
} else {
    pasteboard = [UIPasteboard pasteboardWithUniqueName];
}
[pasteboard setData:UIImagePNGRepresentation(image) forPasteboardType:@"public.png"];
NSString *LINEUrlString = [NSString stringWithFormat:@"line://msg/image/%@", pasteboard.name];
LINEにイメージを投稿するためのURLを作成します。
投稿にはUIPasteboardを利用します。
LINEへは「line://msg/text/(投稿イメージ名)」というURLスキーマを利用して投稿することになります。

if ([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:LINEUrlString]]) {
LINEアプリがインストールされているか確認します。
インストールされていない場合は、LINEアプリのストアへ遷移などしてもよいかもしれません。

[[UIApplication sharedApplication] openURL:[NSURL URLWithString:LINEUrlString]];
LINEへ投稿します。
LINEは投稿完了を受け取れないため、メソッドコールと投稿完了がイコールとなります。


2015年7月21日火曜日

見出しをカスタマイズして、Bloggerの見栄えを良くする!

<div class="separator" style="clear: both; text-align: center;">
</div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjiXpFed1myu1sdFM3s-_ZEpFBbqnYUbvZURyf50kJ-h3mpJ4MlM00WwZ_-pVpBSovxvTa_fDCA_C-GemS6DLZ9coGNaqiRHw5crsdSv24WKR12zO2SB8tyDqPxSfDvxTwEToaGLX0UIMY/s1600/256px-Blogger.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjiXpFed1myu1sdFM3s-_ZEpFBbqnYUbvZURyf50kJ-h3mpJ4MlM00WwZ_-pVpBSovxvTa_fDCA_C-GemS6DLZ9coGNaqiRHw5crsdSv24WKR12zO2SB8tyDqPxSfDvxTwEToaGLX0UIMY/s640/256px-Blogger.png" width="640" /></a></div>
<br />
<br />
ユーザに読みやすい記事を提供するには、コンテンツ(内容)を充実させるのはもちろんですが、<b><span style="font-size: large;"><span style="color: red;">ブログ自体の見易さ</span>も欠かせません</span></b>。<br />
個人的に<b><span style="font-size: large;">手軽で効果的</span></b>だと思っているのは見出しを見やすくして、<b><span style="font-size: large;">文章の区切り</span></b><span style="font-size: large;"><b>を分かりやすく</b></span>することだと思います。<br />
<br />
では初めていきましょう。<br />
<br />
<div style="text-align: center;">
<script async="" src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
<!-- 記事内部の広告(長方形) -->
<br />
<ins class="adsbygoogle" data-ad-client="ca-pub-6222309276407323" data-ad-slot="4455118447" style="display: inline-block; height: 280px; width: 336px;"></ins><script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
</div>
<br />
<h4>
まずは自分のブログを分析</h4>
テンプレートによって変わってきますが、まずは<b><span style="font-size: large;">自分が書いている記事の<span style="color: red;">見出しのタグ</span></span></b>が何になっているかを分析しましょう。<br />
まずは自分のブログ上で右クリックして<b><span style="font-size: large;">コンテキストメニュー</span></b>を開き、<b><span style="font-size: large;">[ページのソースを表示]</span></b>を選びます。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhTMRpeBfkgVIXyU4jlDiEvlpWZo5hZHzschxyQBTPAYeCZZCRqk9acLKNYs0zKrzlspe4_b0O_DZ3Poo8DsxSMMuxbJAtq0j2pJemta5TEs1OK6EzklKEksjzJeXyT4olMuY2Jg0fTvIo/s1600/%25E3%2582%25B9%25E3%2582%25AF%25E3%2583%25AA%25E3%2583%25BC%25E3%2583%25B3%25E3%2582%25B7%25E3%2583%25A7%25E3%2583%2583%25E3%2583%2588+2015-07-19+10.29.13.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="276" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhTMRpeBfkgVIXyU4jlDiEvlpWZo5hZHzschxyQBTPAYeCZZCRqk9acLKNYs0zKrzlspe4_b0O_DZ3Poo8DsxSMMuxbJAtq0j2pJemta5TEs1OK6EzklKEksjzJeXyT4olMuY2Jg0fTvIo/s320/%25E3%2582%25B9%25E3%2582%25AF%25E3%2583%25AA%25E3%2583%25BC%25E3%2583%25B3%25E3%2582%25B7%25E3%2583%25A7%25E3%2583%2583%25E3%2583%2588+2015-07-19+10.29.13.png" width="320" /></a></div>
<br />
すると、HTMLが表示されるとおもいますので、<b><span style="font-size: large;">カスタマイズしたい見出し</span></b>がどうなっているか確認します。<br />
当ブログの場合は、以下のようになってました。<br />
<br />
<blockquote class="tr_bq" style="background: #EFEFEF; padding: 5px;">
<table><tbody>
<tr></tr>
<tr><td class="line-content"><span style="font-size: x-small;">&lt;<b><span style="color: red;">h1</span></b> class='title'&gt;<br /> アプリ作りの現場から@ときどきイラスト<br /> &lt;<span style="color: red;"><b>/h1</b></span>&gt;<br />&lt;<b><span style="color: red;">h3</span></b> class='post-title entry-title' itemprop='name'&gt;</span></td></tr>
</tbody></table>
<span style="font-size: x-small;"> 投稿タイトル<br /> &lt;<b><span style="color: red;">/h3</span></b>&gt;<br /> &lt;div class='post-header'&gt;<br /> &lt;div class='post-header-line-1'&gt;&lt;/div&gt;<br /> &lt;/div&gt;<br /> &lt;div class='post-body entry-content' id='post-body-6160233257508059390' itemprop='description articleBody'&gt;<br /> &lt;<span style="color: red;"><b>h2</b></span>&gt;見出し&lt;<b><span style="color: red;">/h2</span></b>&gt;<br /> &lt;<span style="color: red;"><b>h3</b></span>&gt;小見出し&lt;<b><span style="color: red;">/h3</span></b>&gt;<br /> &lt;<b><span style="color: red;">h4</span></b>&gt;準見出し&lt;<span style="color: red;"><b>/h4</b></span>&gt;<br /> &lt;div&gt;<br /> 本文&lt;/div&gt;</span></blockquote>
<br />
以下のようになっていることが分かります。<br />
<blockquote class="tr_bq">
<b>h1=ブログタイトル、h2=見出し、h3=小見出し、h4=準見出し</b></blockquote>
h1やh2はブログタイトルなどでも利用されているので、今回は<b><span style="font-size: large;">準見出しh4をカスタマイズ</span></b>して見栄えをよくします。<br />
<br />
<h4>
CSSCSSの設定を開く</h4>
Bloggerではスタールシート(CSS)を利用してカスタマイズができるようになっていますので、調整していきます。<br />
Bloggerの<b><span style="font-size: large;">管理画面</span></b>から<b><span style="font-size: large;">[テンプレート]-[カスタマイズ]</span></b>とすすみ、<span style="font-size: large;"><b>[上級者向け]-[CSSの追加]</b></span>とさらに進みます。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjzc2GCjVpE7Y5K8e1OcGOldjDk-3SN4ZjCVYeEqtobvb9Vhm6Gse22r6xN4-Wq53b1j7KTk_0EzOPtN6j2xzuvSP5aGSVO3KKtUz0zTlQWxxPJpJ-_5HsR0p2ohuBLj6az4DM1A-HudeE/s1600/%25E3%2582%25B9%25E3%2582%25AF%25E3%2583%25AA%25E3%2583%25BC%25E3%2583%25B3%25E3%2582%25B7%25E3%2583%25A7%25E3%2583%2583%25E3%2583%2588+2015-07-19+10.46.31.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="313" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjzc2GCjVpE7Y5K8e1OcGOldjDk-3SN4ZjCVYeEqtobvb9Vhm6Gse22r6xN4-Wq53b1j7KTk_0EzOPtN6j2xzuvSP5aGSVO3KKtUz0zTlQWxxPJpJ-_5HsR0p2ohuBLj6az4DM1A-HudeE/s320/%25E3%2582%25B9%25E3%2582%25AF%25E3%2583%25AA%25E3%2583%25BC%25E3%2583%25B3%25E3%2582%25B7%25E3%2583%25A7%25E3%2583%2583%25E3%2583%2588+2015-07-19+10.46.31.png" width="320" /></a></div>
<br />
<br />
すると<b><span style="font-size: large;">CSSが追加できる</span></b>ようになりますので、以下のように入力して、ブログに適用ボタンを押します。<br />
<blockquote class="tr_bq" style="background: rgb(239, 239, 239); padding: 5px;">
<span style="font-size: x-small;">h4{</span><br />
<span style="font-size: x-small;">border-left: 8px #777 solid;</span><br />
<span style="font-size: x-small;">border-top: 1px #777 solid;</span><br />
<span style="font-size: x-small;">border-bottom: 1px #777 solid;</span><br />
<span style="font-size: x-small;">border-right: 1px #777 solid;</span><br />
<span style="font-size: x-small;">font-size: 18px;</span><br />
<span style="font-size: x-small;">font-weight: bold;</span><br />
<span style="font-size: x-small;">margin: 5px 0;</span><br />
<span style="font-size: x-small;">padding: 5px 0 5px 10px;</span><br />
<span style="font-size: x-small;"></span><br />
<span style="font-size: x-small;">}</span></blockquote>
まあ、はじめはおまじないだと思っておけば良いと思いますが、これで<b><span style="font-size: large;">枠線(border)</span></b>や<span style="font-size: large;"><b>フォント(font)</b></span>、<b><span style="font-size: large;">余白</span></b>を変更しています。<br />
<br />
一つ一つの意味は、割愛しますが、詳しく知りたい方や、もっと自由にカスタマイズしたい方は、調べて利用してみることをお勧めします。<br />
ちなみに、私は良く下のサイトを利用させていただいてます。<br />
<a href="http://www.htmq.com/csskihon/301.shtml" target="_blank">HTMLクイックリファレンス - CSSの基本 - ボックス</a><br />
<br />
<b><span style="font-size: large;">上記を設定</span></b>すると、<span style="font-size: large;"><b>このブログの見出しのようなボックス</b></span>にして、見出しを見やすくし、<b><span style="font-size: large;">区切りをはっきりとさせる</span></b>ことができます。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgaYu5AN45EiWKO3LrN7zpMVHAHJp_Q-CHn8t0t76lN6vEzYuyULWFQgg1cHAyXgFlR36HWKWEOPGY0F1qdJH9S-wukJNQ3Jmw7EKcVtuy1K9VXVzTynLiIdkdYtoa6Inh_-JrylPuOHIo/s1600/%25E3%2582%25B9%25E3%2582%25AF%25E3%2583%25AA%25E3%2583%25BC%25E3%2583%25B3%25E3%2582%25B7%25E3%2583%25A7%25E3%2583%2583%25E3%2583%2588+2015-07-19+11.01.43.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="74" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgaYu5AN45EiWKO3LrN7zpMVHAHJp_Q-CHn8t0t76lN6vEzYuyULWFQgg1cHAyXgFlR36HWKWEOPGY0F1qdJH9S-wukJNQ3Jmw7EKcVtuy1K9VXVzTynLiIdkdYtoa6Inh_-JrylPuOHIo/s320/%25E3%2582%25B9%25E3%2582%25AF%25E3%2583%25AA%25E3%2583%25BC%25E3%2583%25B3%25E3%2582%25B7%25E3%2583%25A7%25E3%2583%2583%25E3%2583%2588+2015-07-19+11.01.43.png" width="320" /></a></div>
<br />
<br />
実は<b><span style="font-size: large;">クラス</span></b>という技術を使えば、他にももっと自由なカスタマイズができるのですが、それはまた機会があれば書いていこうと思います。<br />
<br />
<br />

2015年2月4日水曜日

[cocos2dx] v3.3にAdMob SDK 6.12.2(iOS)を入れた時のリンクエラー対処

cocos2d-x v3.3にAdMob SDK 6.12.2(iOS)を入れた時にリンクエラーがわんさか出てきて焦ったのでメモ。


原因はAdMob SDK 6.12.2(iOS)を導入時にOther Linker Flagsに-ObjCを設定したことによるもののようですが、分かりにくいな。


導入時に大量のフレームワークを導入させられるわけですが、これだけでは足りず、以下の3つのフレームワークをさらに導入が必要でした。

まずは、以下を参考にたりないフレームワークを追加。
  • MediaPlayer
  • GameController (iOS6対応アプリの場合はoptional)
この辺は下記のブログを参考にさせていただきました。
cocos2d-x v3.2にiOS版AdMob SDK 6.12.0を導入した時のリンクエラーの対処

うーんこれでもエラーが消えない。
どうやらsqliteのフレームワークがないとのこと。

  • libsqlite3.0.dylib

うーん、導入ガイドに書いとけよなと思いつつ、
これらは事前に導入されていることが前提なのだろうか。。。
と考えさせられた一件でした。