tag:blogger.com,1999:blog-30349601186678154612024-03-05T18:22:34.900+09:00AndCreategari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.comBlogger33125tag:blogger.com,1999:blog-3034960118667815461.post-31854664197436583462014-07-21T20:32:00.001+09:002014-07-21T20:32:24.474+09:00個人でもできるGooglePlay検索最適化(ダウンロードを増やすためのASO)最近、アプリを出しただけでは全くダウンロードされなくなり、ランキング上位は広告をバシバシ打てる企業が占めるようになって、個人の開発者が戦っていくのはほんとに厳しくなりました。<br />
<div>
<br /></div>
<div>
そこで、先月リリースした<a href="https://play.google.com/store/apps/details?id=com.andcreate.app.trafficmonitor&referrer=utm_source%3Dblog%26utm_medium%3Dandcreate" target="_blank"><b><span id="goog_1367524860"></span>「通信量モニター」</b><span id="goog_1367524861"></span></a>というアプリで、検索最適化について色々試して、知見がたまってきたのでここにまとめておこうと思います。</div>
<div>
ダウンロードが思うように伸びなくて困っている開発者のお役に立てれば嬉しいです。</div>
<div>
<br /></div>
<div>
<h3>
<b><span style="font-size: large;">なぜ検索最適化?</span></b></h3>
<a href="http://www.insidemobileapps.com/2013/05/17/google-discloses-how-search-for-google-play-works-for-the-first-time-12-percent-of-dau-search-for-apps-daily/" target="_blank">GooglePlayの中の人</a>によると、ほとんどのアプリはGoogle Playの<b>検索結果からのダウンロードが一番多い</b>らしい。<br />
12%のユーザが毎日GooglePlayで検索し、50%のユーザが毎週GooglePlayで検索する。<br />
検索でアプリを探しているユーザは目的があって検索しているので、問題を解決できるアプリを見つけたら長期的に使ってくれる優良ユーザになりやすい。<br />
なので検索結果で上位に表示される事が、多くのユーザにアプリをダウンロードしてもらえることにつながります。<br />
<br />
※広告を打てないデベロッパーは新着などのランキングにはこだわらないほうがいいかもしれません。<br />
多くの開発者がリリースして1ヶ月の新着ランキング上位を狙いますが、TOP20ぐらいにならない限りダウンロードはそんなに増えません。「通信量モニター」も最終的に新着ランキング100位ぐらいまでいきましたが、新着ランキングから消えた前と後でのデイリーDLに差は無かったです。多分デイリーDL50もないです。<br />
<b><br /></b>
<br />
<h3>
<span style="font-size: large;"><b>検索で上位表示するためにやること</b></span></h3>
<div>
<span style="font-size: large;"><b><br /></b></span></div>
<h3>
キーワードの選定</h3>
</div>
<div>
自分のアプリを使って欲しいターゲットユーザがどんなキーワードで検索するかを考えて、キーワードを選びます。</div>
<div>
アプリの特徴を表すキーワードはもちろんですが、ビッグワードな場合、それだけで上位表示を狙うのは難しいので、複合キーワードも狙います。</div>
<div>
Google Playの検索機能は優秀なのでキーワードを打つとレコメンドしてくれます。レコメンドされるキーワードは他にもその<b>検索結果を使っているユーザがいる</b>ということなので、それらのキーワードで上位表示されるようにします。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiQrueQ5C5xwBQn3Gq0uwFSqRD-DnFlhNHBKilwH2mP0jtlkR7Nj3i47iN4v7qKQvsjqoyboFgatvy8sn69H32kHaq9_-bajyG2Hyz-49zvize4Jov0l6u1PsPdy9-Av7F4_v1mEfK5rcc/s1600/screenshot0001.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiQrueQ5C5xwBQn3Gq0uwFSqRD-DnFlhNHBKilwH2mP0jtlkR7Nj3i47iN4v7qKQvsjqoyboFgatvy8sn69H32kHaq9_-bajyG2Hyz-49zvize4Jov0l6u1PsPdy9-Av7F4_v1mEfK5rcc/s1600/screenshot0001.png" height="320" width="315" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
(検索マークと履歴マークがあるが重要なのは検索マークの方)</div>
<div class="separator" style="clear: both; text-align: center;">
<br /></div>
<div class="separator" style="clear: both; text-align: left;">
また、そのキーワードがどれくらいの検索ボリュームなのか調べます。</div>
<div class="separator" style="clear: both; text-align: left;">
正確に計測する手段はありませんが、<a href="https://www.google.co.jp/trends/" target="_blank"><b>Googleトレンド</b></a>で調べるとどのキーワードが検索ボリュームが多いか推測できます。<b>(Webの検索ボリュームとGooglePlayの検索ボリュームは同じではないので参考程度に)</b></div>
<div class="separator" style="clear: both; text-align: left;">
<br /></div>
<h3 style="clear: both; text-align: left;">
タイトルや説明文にキーワードをいれる</h3>
</div>
<div>
選定したキーワードをタイトルや説明文に加えます。</div>
<div>
ここで重要なのは<b>濃度</b>です。現在GooglePlayではタイトルに30文字、説明文に4000文字含めることができますが、限界まで含めてもあまり良いことはなく、<b>キーワードの濃度</b>を重視しているようです。</div>
<div>
「通信量モニター」で同じ日に次の2つを試したところ、</div>
<div>
『通信量・通信速度モニター』</div>
<div>
→通信速度:<b>6位</b>、通信量オーバー:<b>圏外</b></div>
<div>
『通信量・通信速度モニター:通信量オーバー対策に最適!』</div>
<div>
→通信速度:<b>8位</b>、通信量オーバー:<b>2位</b></div>
<div>
となりました。</div>
<div>
どちらをとるかはケースバイケースですが、一つのキーワードで上位を狙いたい場合は、そのキーワードを含めつつ、タイトルを短くすると上位に表示されやすくなります。</div>
<div>
タイトルほど大きな影響力はありませんが、説明文も同様で濃度が重要です。取りたいキーワードをいれつつコンパクトにまとめた説明文を作りましょう。</div>
<div>
開発者コンソールで変更して2時間ぐらいで検索結果に反映されるので、どのキーワードで上位を狙えるかいろいろ試すのがベストです。</div>
<div>
<br /></div>
<div>
<b>※検索ボリュームが多いからといって、アプリに関係のないキーワードをタイトルや説明文にいれるのは垢バンされる可能性が高いのでやめましょう。説明文の下のほうにキーワードを羅列していたり、競合アプリの名前を入れたりすると危険です。すぐには発見されませんが、GooglePlayの中の人は人力でもチェックしているようなので、目立ってくると消されます。</b></div>
<div>
<br /></div>
<h3>
レビューサイトにレビュー依頼</h3>
<div>
最近はレビューサイトの影響も2年ほど前に比べて落ちてきたように思いますが、初期ユーザを増やすためには重要です。検索結果にはインストール数、アンインストール数もすこし考慮されるため、初期の優良ユーザは多いほうがいいです。</div>
<div>
またGooglePlayは外からのリンクも考慮しているようなので、レビューサイトで取り上げられることはダウンロード数もリンク数も増えるので一石二鳥です。<br />
レビューサイトは沢山あるので、以下から探してください。</div>
<div>
<a href="http://matome.naver.jp/odai/2132218813593385101" target="_blank"><b>iPhone/Androidアプリの人気レビューサイトまとめ</b></a><br />
<br /></div>
<div>
またレビュー依頼を代行してくれるサービスもありますが、無料のものは殆ど効果ないのでやってもやらなくても一緒です。</div>
<div>
有料のものは使ったことがなかったので、今回試しに<a href="http://app-release.com/" target="_blank">APPリリース</a>さんの<b>プレミアム(49800円)サービス</b>を使ってみました。</div>
<div>
結果として「通信量モニター」の場合は2社に取り上げてもらい、そこからのインストールは大体1000件ぐらいです。<b>CPI50円</b>ぐらいになった結果なので、少しお金があるなら使ってみるのも悪くないと思います。<br />
<br />
<h3>
事前登録サービスを使う(リリース前限定)</h3>
<div>
リリース予定のアプリを予約しておく事前登録サービスというものがあります。</div>
<div>
いくつかありますが、個人でも参加できる無料の<a href="https://yoyaku-top10.jp/pc/r/android/daily" target="_blank">予約トップ10</a>がオススメです。<br />
登録されているアプリはソーシャルゲームが多いですが、カジュアルゲームやツール系のアプリも登録できます。<br />
通信量モニターの場合は予約登録数700ぐらいで、リリース後に300件ぐらいダウンロードしてくれました。貴重な初期ユーザを獲得できるのでオススメです。</div>
<br />
<h3>
平均評価を高くする</h3>
</div>
<div>
良いアプリは上位に表示されやすくなるため、アプリの平均評価を高めることも重要です。ユーザに評価をお願いするダイアログを表示することが、わりと当たり前になってきましたが、そのタイミングと表示方法も重要です。</div>
<div>
<b>1. ユーザがアプリを良いと思ったタイミングで表示する</b></div>
<div>
そのアプリがユーザの困っていることを解決した時や、ゲームでハイスコアを出した時など、ユーザの満足度が高いタイミングで出すと良い評価をしてくれる可能性が高くなります。</div>
<div>
<b>2. ユーザに★5の評価を促す</b></div>
<div>
1.で評価してくれる可能性は高くなりますが、★5の評価の可能性を高くするためにユーザに具体的に訴えることも重要です。</div>
<div>
<a href="https://play.google.com/store/apps/details?id=com.cleanmaster.mguard&hl=ja" target="_blank"><b>「CleanMaster」</b></a>はこの辺がとても上手く、平均評価も4.7ととても高いです。</div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjyVoDNpIRB1J415DvjH6QnO8RNaY-CsPBXKtLN1Jt-oGkqBoxNEtW8cP4_A7K1fOieyAEJPjN4HubmE_vjBo6Wu09vRH7Aciy11uEcFOI0mkasDrSF56-cccf_c2nUBHaR6ekv0bkD3rQ/s1600/screenshot0002.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjyVoDNpIRB1J415DvjH6QnO8RNaY-CsPBXKtLN1Jt-oGkqBoxNEtW8cP4_A7K1fOieyAEJPjN4HubmE_vjBo6Wu09vRH7Aciy11uEcFOI0mkasDrSF56-cccf_c2nUBHaR6ekv0bkD3rQ/s1600/screenshot0002.png" height="277" width="320" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
(キャッシュやメモリを掃除した後に出るダイアログ)</div>
<div>
※評価でインセンティブを与えるのはダメです。(★5の評価でポイント付与など)<br />
<br /></div>
<h3>
+1を増やす</h3>
<div>
+1を積極的に増やしていくこともポイントです。</div>
<div>
+1の数が順位にも影響するのはもちろんですが、+1をすると、その友達のストアのトップにおすすめアプリとして表示される可能性が高くなります。</div>
<div>
アプリのなかに+1ボタンを置くこともそこまで難しくないのでオススメです。</div>
<div>
実装方法は<a href="http://qiita.com/gari_jp/items/1e5a63910ba7900f8945" target="_blank">「Qiita:+1ボタンを設置する」</a>にまとめてるので参考にしてください。</div>
<div>
導入してから+1される数が3倍ぐらいに増えました。<br />
<br />
<h3>
<span style="font-size: large;">結果</span></h3>
<br />
以上が、「通信量モニター」でやった検索最適化です。<br />
現在の検索でのランキングはこのようになっています。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgBXhKY66UZEE5MIekVaxA5tQEE_n99zD_gKFhhS3lrUuO_GwpXT_p89A0KEYlczcUzRdVu8stYHRPICBkt9Mtqx0mCBoMdRMXNYurFVmQmU_x5cVJ5k7Vu-VyhGf1NsgvZs2iKayfbdrM/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2014-07-21+19.57.09.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgBXhKY66UZEE5MIekVaxA5tQEE_n99zD_gKFhhS3lrUuO_GwpXT_p89A0KEYlczcUzRdVu8stYHRPICBkt9Mtqx0mCBoMdRMXNYurFVmQmU_x5cVJ5k7Vu-VyhGf1NsgvZs2iKayfbdrM/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2014-07-21+19.57.09.png" height="235" width="400" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
(App Annieのデータ)</div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicWiOYsL8YWxdy7Iu9FQnl2lMN9DkR2GLiYXmqlFlT-BKwrYzpkxfLX5xiJRwaD8eype0U4_RFwOlddqcPFARZol5Ric_D17tDlmEu7aiCRqdWHAbRdPAcAe6ySQ182b97AHwUin4n_Pg/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2014-07-21+20.12.24.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEicWiOYsL8YWxdy7Iu9FQnl2lMN9DkR2GLiYXmqlFlT-BKwrYzpkxfLX5xiJRwaD8eype0U4_RFwOlddqcPFARZol5Ric_D17tDlmEu7aiCRqdWHAbRdPAcAe6ySQ182b97AHwUin4n_Pg/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2014-07-21+20.12.24.png" height="100" width="400" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
(デベロッパーコンソールのデータ)</div>
<div class="separator" style="clear: both; text-align: center;">
<br /></div>
</div>
<div>
現在のデイリーのDLは400~500ぐらいで、殆ど検索流入です。<br />
検索結果の上位に表示されることでこれぐらいのダウンロードは稼げるようになります。<br />
ご自身のアプリの検索最適化に役立てば幸いです。頑張ってダウンロードを増やしましょう。<br />
<br />
※「こういうのも有効だよ」というものがあれば、ぜひ教えて下さい。<br />
<br />
<b>参考にしたページ</b><br />
<i><a href="http://y-anz-m.blogspot.jp/2013/05/google-io-2013-android-getting.html" target="_blank">Y.A.M の 雑記帳: Google I/O 2013 - Android : Getting Discovered on Google Play - </a></i><br />
<a href="http://web-tan.forum.impressrd.jp/e/2013/12/02/16528" target="_blank">基礎から学ぶアプリストア最適化「ASO」</a><br />
<br /></div>
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com1tag:blogger.com,1999:blog-3034960118667815461.post-70419431821787598092013-03-27T18:47:00.002+09:002013-03-27T18:51:03.499+09:00Androidでスプラッシュ画面を表示する何番煎じかわかりませんが、Androidでスプラッシュを表示する方法です。<br />
<br />
スプラッシュを実現するにあたって、編集するファイルは<br />
<br />
<ul>
<li>一番最初に表示するActivity(MainActivity.java)</li>
<li>アクティビティのxmlファイル(activity_main.xml)</li>
</ul>
<div>
<br /></div>
<div>
の2つです。</div>
<div>
<br /></div>
<div>
まずxmlファイルの方を編集していきます。</div>
<div>
<pre class="xml" name="code"><?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:animateLayoutChanges="true"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
// アクティビティに表示するコンポーネントをここに書く
</LinearLayout>
<ImageView
android:id="@+id/splash_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:contentDescription="@string/content_description_splash"
android:scaleType="fitXY"
android:src="@drawable/splash" />
</FrameLayout></pre>
<br />
一番外側をFrameLayoutでラップして、通常の画面の上にSplash画像が重なるようにします。<br />
<br />
<pre class="xml" name="code">android:animateLayoutChanges="true"
</pre>
<br />
これは、レイアウトが変更されるときにアニメーションするかどうかを設定しています。<br />
フェードアウトしたほうが綺麗なので、trueに設定しています。(APILevel11以上の時なので,2.xではアニメーションしません)<br />
<br />
次に、MainActivity.javaの方を編集します。<br />
<pre class="java" name="code"> @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.actiivty_main);
initSplashView();
SplashClearTask splashClearTask = new SplashClearTask();
splashClearTask.execute();
}
private void initSplashView() {
ImageView splashView = (ImageView)findViewById(R.id.splash_view);
// スプラッシュ表示中はクリックを無視する
splashView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
return;
}
});
}
private void clearSplash() {
ImageView splashView = (ImageView)findViewById(R.id.splash_view);
splashView.setVisibility(View.GONE);
}
private class SplashClearTask extends AsyncTask<Void, Void, Void> {
@Override
protected Void doInBackground(Void... params) {
try {
// 一定時間待機
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(Void result) {
clearSplash();
}
}
</pre>
<br /></div>
ポイントは、スプラッシュ表示中のクリックを無効化している部分と、SplashClearTaskの部分です。<br />
<br />
FrameLayoutでViewを重ねるだけでは、その下にあるViewをクリックできてしまうので、スプラッシュ画像が表示されている間、その下にあるコンポーネントをクリックできないようにしています。<br />
<br />
SplashClearTaskでは、スプラッシュを一定時間表示してからスプラッシュを消すためにdoInBackgroundでThread.sleep()を使っています。<br />
<br />
アクティビティのレイアウトの階層が1段深くなりますが、スプラッシュ用にアクティビティを使わなくてすみます。<br />
<br />
注意するポイントとしては、アクションバーやメニューバーは表示されてしまうので、スプラッシュの前後で表示の切替が必要です。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-78753521267020032722013-03-12T12:58:00.000+09:002013-03-12T12:58:37.084+09:00アプリで個人として独立してやっていくためにいくら稼げばいいのかそろそろ確定申告の締切が迫って来ました。<br />
<div>
<br /></div>
<div>
独立されている方や、副業でそこそこ稼いでいる方、もう確定申告は済ませました?</div>
<div>
<br /></div>
<div>
青色申告で65万円控除できる締切は3/15日です。</div>
<div>
<br /></div>
<div>
僕は今日、提出してきました。(昨年はこんなにギリギリじゃなかったのに)</div>
<div>
<br /></div>
<div>
いつもはこのブログでは、Androidの備忘録的なのをぽろぽろ書いているのですが、今日はちょっと違ったことを書きます。</div>
<div>
<br /></div>
<div>
それは、</div>
<div>
<br /></div>
<div>
<span style="font-size: large;">「アプリで食べていくためにはどれくらい稼がないとダメなのか。」</span></div>
<div>
<span style="font-size: large;"><br /></span></div>
<div>
です。</div>
<div>
<br /></div>
<div>
これを書こうと思った理由は、</div>
<div>
<ul>
<li>今までアプリの売上で2回確定申告してきて、だいたいどのくらい稼げば大丈夫なのか感じがつかめてきたから</li>
<li>新年度を迎えるにあたり、今の会社をやめて独立しようとか思っている人の参考になればとか</li>
</ul>
<div>
そんな感じです。</div>
</div>
<div>
<br /></div>
<div>
まだ2年ぐらいですが、そんなに的はずれな内容にはならないと思います。<br />
<br />
例として「都内一人暮らし」で出してみます。<br />
<br />
まず、ひと月にかかる生活費ですが、だいたいこんな感じだと思います。<br />
<br />
家賃:6~7万ぐらい<br />
食費:3~4万ぐらい<br />
水道光熱費:1万ぐらい<br />
通信費:1万ぐらい<br />
その他:1~2万ぐらい<br />
<br />
で大体月に15万ぐらいかな。自炊とかもっと安いところに住んでたりすると12万ぐらいで済むかもしれません。家族を養う必要があるひとはもっとかかってきますね。とりあえず一例なので。合計は180万ぐらいです。<br />
<br />
でアプリを開発ってことでその他必要なものを書いていきます。(1年でかかる費用)<br />
PCとか設備費:10万ぐらい(ノートPC買ったり、PCのパーツ買ったり)<br />
書籍費:1~5万ぐらい(ネット主体の人は安く済む)<br />
開発者登録とか:1万<br />
検証端末購入費とか:0~10万<br />
<br />
大体20万ぐらいです。<br />
<br />
その他にかかってくる費用(1年でかかる費用)<br />
国民健康保険:前年の稼いだ額に依存するけど大体20~30万ぐらい<br />
年金:14980円x12=18万ぐらい<br />
奨学金返済:1~2万x12=12~24万ぐらい<br />
<br />
社会保険料+αでだいたい60~80万ぐらいです。奨学金借りてこなかった人はその分安くなります。両親に感謝ですね。<br />
<br />
ここまでで「一年に必要な金額」はだいたい180+20+70で270万円です。じゃあこの額を1年で稼げばいいやって思って270/12で大体月に23万ぐらい稼げばいいなって試算がでますが、そうはいきません。<br />
<br />
そうです。<span style="font-size: large;">「税金」</span>です。<br />
<br />
生活している以上、その国に税金を納めなければいけません。<br />
で、かかってくる税金の種類は次のとおりです。<br />
<br />
<ul>
<li>所得税</li>
<li>個人事業税(アプリ開発の場合、地方によって課税されたり非課税だったり)</li>
<li>住民税</li>
<li>消費税(売上が1000万以上あった場合、その2年後から課税)</li>
</ul>
<br />
所得税は「総売上-必要経費」の金額が高くなるほど、税金が高くなります。細かい計算は省いて、だいたい15%ぐらいかかってきます。<br />
<br />
次に個人事業税が大体5%ぐらいです。知り合いの方でも課税されてたり、非課税だったりします。ただ、まだアプリで稼ぐ人が現れ始めたのがここ2~3年なので、今後アプリ開発で稼ぐ人がもっと増えると制度が変わって課税されると思います。<br />
<br />
次に住民税ですが、均等割という全員にかかるものが3000円で、市民税が6%、県民税が4%です。なので10%ととしておきます。<br />
<br />
次に消費税ですが、これは1期目2期目ではまず課税されません。1期目で1000万以上売り上げた場合、3期目から消費税を納めなければいけません。今は5%ですが、一年後は8%、二年後の10月からは10%です。<br />
見なし仕入率とかあるので実際にはその半分ぐらいです。その分を所得から計算し、申告納税します。<br />
<br />
税金は以上ですが、だいたい稼いだ金額のうち30%ぐらいは持っていかれると見ていたほうがいいです。<br />
経費を積むと納税額を抑えられますが、アプリ開発自体はそんなに経費がかかる事業じゃないので、積むにも限界があります。<br />
<br />
これらから、簡単ながら計算式が作れます。<br />
<br />
「稼がなければいけない金額」-「税金(稼いだ金額の30%)」=「一年に必要な金額(270万)」<br />
<br />
「稼がなければいけない金額」× 0.7 = 「一年に必要な金額(270万)」<br />
<br />
「稼がなければいけない金額」 = 「一年に必要な金額(270万)」× 1.43<br />
<br />
「稼がなければいけない金額」 = 386万<br />
<br />
になります。これを12ヶ月で割ると大体32万円ぐらいです。<br />
<br />
ただ、独立してやっていくと、会社員のような保証は無いので、体を壊して稼げなくなった時とかのための保険として貯蓄するようにもっと稼いでないとまずいです。<br />
年金も、国民年金だけで、会社員のように厚生年金に入らないので、もらえる年金も少ないです。(年金システム自体が無くなるかもしれないけど)<br />
なので余裕をもてるように一年に100万ぐらい貯蓄していくとして、だいたい月に40~50万ぐらいは稼いでおかないとやっていくのは厳しいです。<br />
<br />
<span style="font-size: large;">結論</span><br />
<br />
<span style="font-size: large;">アプリで食べていくためには月40~50万ぐらい稼がないと厳しい。</span><br />
<br />
アプリで独立しようとか考えている人の参考になれば。</div>
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-74905004036032213962013-03-03T15:45:00.000+09:002013-03-03T15:55:20.241+09:00ListViewのlayout_heightにwrap_contentを使ってはいけないandroidの開発でよく使うListViewのコンポーネントですが、使うときに注意する事があります。<br />
<br />
レイアウト指定で、ListViewのlayout_heightの値にwrap_contentの値を使わないことです。<br />
<br />
これをwrap_contentとかにしておくと、listviewにつけるadapterのgetView()メソッドが何度も呼び出されて無駄な処理が発生します。<br />
<br />
同じListViewでlayout_heightの属性を変えた場合のLogを出してみました。<br />
<br />
layout_height="match_parent"のとき<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiZ02_NIWOSsbWUmXFf3ETc7FF94m0gEp0w_cY6y5-Z_9s9q90Nx9WECgia2PsnFFQBZgDOUZ1uFtDORu9wFF2XVSj_4OlR__Xd3IaJjz4bPArZCmIM3XxkXbVSCbpCC4GEwF7kbYipFSU/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2013-03-03+15.33.33.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiZ02_NIWOSsbWUmXFf3ETc7FF94m0gEp0w_cY6y5-Z_9s9q90Nx9WECgia2PsnFFQBZgDOUZ1uFtDORu9wFF2XVSj_4OlR__Xd3IaJjz4bPArZCmIM3XxkXbVSCbpCC4GEwF7kbYipFSU/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2013-03-03+15.33.33.png" /></a></div>
<br />
layout_height="wrap_content"のとき<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhV74NsqfSGKnFOaU64lXDyus766Y2nUdSp-bfZU3LHqBy_qbenBW9nOCN8Oa6VxfuapexRpICyXFntZuZWfQnrrzDlpzV_aT4iqlFk_VZgxWPOP5LeS8zL_LMZ_IGshOL5HDAy4e6vjgQ/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2013-03-03+15.34.43.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhV74NsqfSGKnFOaU64lXDyus766Y2nUdSp-bfZU3LHqBy_qbenBW9nOCN8Oa6VxfuapexRpICyXFntZuZWfQnrrzDlpzV_aT4iqlFk_VZgxWPOP5LeS8zL_LMZ_IGshOL5HDAy4e6vjgQ/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2013-03-03+15.34.43.png" /></a></div>
<br />
実際にはcountが54まで繰り返し処理されていました。<br />
<br />
原因はよくわからないですが、wrap_contentだと高さの値がコンテンツのサイズになるのでそこら辺が関係してるのかなと思います。<br />
<br />
ちなみに,「layout_height="0dp" layout_weight="1"」でも 「layout_height="match_parent"」と同じ振る舞いで問題はありませんでした。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-68112685226001252352013-02-28T09:57:00.001+09:002013-02-28T10:00:54.561+09:00Androidの自作CalendarViewAndroidでCalendarViewを使うにはいくつか方法があります。<br />
<ol>
<li>Android公式のandroid.widget.CalendarViewを使う</li>
<li><a href="http://d.hatena.ne.jp/Kazzz/20101112/p1" target="_blank">CalendarView 公開しました</a>のCalendarViewを使う</li>
<li>自分で作る</li>
</ol>
<div>
1.に関してはAPIが11以上でないと使えないので、2.x系以上をサポートするアプリでは使えません。</div>
<div>
<br /></div>
<div>
2.に関してはページ送り、祝日情報などが含まれていてかなり有用なCalendarViewだと思います。</div>
<div>
<br /></div>
<div>
3.本当に最低限のCalendarViewでいいとか、後で色々細かいところを調整したいとかはこっちの方がいいのかなと思います。</div>
<div>
<br /></div>
<div>
今作っているアプリにCalendarView使いたいなってことで、上記の3件を考慮したのですが、今回作っているアプリに一番しっくりきそうなのは3.の形だったので、</div>
<div>
<br /></div>
<div>
<a href="http://smartphone-zine.com/mobile/custom-component-calendarview%E3%82%92%E4%BD%9C%E6%88%90.html" target="_blank">カスタムコンポーネントでCalendarViewを作成</a></div>
<div>
<br /></div>
<div>
のソースコードを元に作りました。(主にリファクタリングと、少しの調整)</div>
<div>
<pre class="java" name="code">import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Color;
import android.graphics.Typeface;
import android.util.AttributeSet;
import android.view.Gravity;
import android.widget.LinearLayout;
import android.widget.TextView;
import <package_name>.R;
/**
* 指定した年月日のカレンダーを表示するクラス
*/
public class CalendarView extends LinearLayout {
@SuppressWarnings("unused")
private static final String TAG = CalendarView.class.getSimpleName();
private static final int WEEKDAYS = 7;
private static final int MAX_WEEK = 6;
// 週の始まりの曜日を保持する
private static final int BIGINNING_DAY_OF_WEEK = Calendar.SUNDAY;
// 今日のフォント色
private static final int TODAY_COLOR = Color.RED;
// 通常のフォント色
private static final int DEFAULT_COLOR = Color.DKGRAY;
// 今週の背景色
private static final int TODAY_BACKGROUND_COLOR = Color.LTGRAY;
// 通常の背景色
private static final int DEFAULT_BACKGROUND_COLOR = Color.TRANSPARENT;
// 年月表示部分
private TextView mTitleView;
// 週のレイアウト
private LinearLayout mWeekLayout;
private ArrayList<Linearlayout> mWeeks = new ArrayList<Linearlayout>();
/**
* コンストラクタ
*
* @param context context
*/
public CalendarView(Context context) {
this(context, null);
}
/**
* コンストラクタ
*
* @param context context
* @param attrs attributeset
*/
@SuppressLint("SimpleDateFormat")
public CalendarView(Context context, AttributeSet attrs) {
super(context, attrs);
this.setOrientation(VERTICAL);
createTitleView(context);
createWeekViews(context);
createDayViews(context);
}
/**
* 年月日表示用のタイトルを生成する
*
* @param context context
*/
private void createTitleView(Context context) {
float scaleDensity = context.getResources().getDisplayMetrics().density;
mTitleView = new TextView(context);
mTitleView.setGravity(Gravity.CENTER_HORIZONTAL); // 中央に表示
mTitleView.setTextSize((int)(scaleDensity * 14));
mTitleView.setTypeface(null, Typeface.BOLD); // 太字
mTitleView.setPadding(0, 0, 0, (int)(scaleDensity * 16));
addView(mTitleView, new LinearLayout.LayoutParams(
LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
}
/**
* 曜日表示用のビューを生成する
*
* @param context context
*/
private void createWeekViews(Context context) {
float scaleDensity = context.getResources().getDisplayMetrics().density;
// 週表示レイアウト
mWeekLayout = new LinearLayout(context);
Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.DAY_OF_WEEK, BIGINNING_DAY_OF_WEEK); // 週の頭をセット
for (int i = 0; i < WEEKDAYS; i++) {
TextView textView = new TextView(context);
textView.setGravity(Gravity.RIGHT); // 中央に表示
textView.setPadding(0, 0, (int)(scaleDensity * 4), 0);
LinearLayout.LayoutParams llp =
new LinearLayout.LayoutParams(0, LayoutParams.WRAP_CONTENT);
llp.weight = 1;
mWeekLayout.addView(textView, llp);
calendar.add(Calendar.DAY_OF_MONTH, 1);
}
addView(mWeekLayout, new LinearLayout.LayoutParams(
LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
}
/**
* 日付表示用のビューを生成する
*
* @param context context
*/
private void createDayViews(Context context) {
float scaleDensity = context.getResources().getDisplayMetrics().density;
// カレンダー部 最大6行必要
for (int i = 0; i < MAX_WEEK; i++) {
LinearLayout weekLine = new LinearLayout(context);
mWeeks.add(weekLine);
// 1週間分の日付ビュー作成
for (int j = 0; j < WEEKDAYS; j++) {
TextView dayView = new TextView(context);
dayView.setGravity(Gravity.TOP | Gravity.RIGHT);
dayView.setPadding(0, (int)(scaleDensity * 4), (int)(scaleDensity * 4), 0);
LinearLayout.LayoutParams llp =
new LinearLayout.LayoutParams(0, (int)(scaleDensity * 48));
llp.weight = 1;
weekLine.addView(dayView, llp);
}
this.addView(weekLine, new LinearLayout.LayoutParams(
LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
}
}
/**
* 年と月を指定して、カレンダーの表示を初期化する
*
* @param year 年の指定
* @param month 月の指定
*/
public void set(int year, int month) {
setTitle(year, month);
setWeeks();
setDays(year, month);
}
/**
* 指定した年月日をタイトルに設定する
*
* @param year 年の指定
* @param month 月の指定
*/
@SuppressLint("SimpleDateFormat")
private void setTitle(int year, int month) {
Calendar targetCalendar = getTargetCalendar(year, month);
// 年月フォーマット文字列
String formatString = mTitleView.getContext().getString(R.string.format_month_year);
SimpleDateFormat formatter = new SimpleDateFormat(formatString);
mTitleView.setText(formatter.format(targetCalendar.getTime()));
}
/**
* 曜日を設定する
*/
@SuppressLint("SimpleDateFormat")
private void setWeeks() {
Calendar week = Calendar.getInstance();
week.set(Calendar.DAY_OF_WEEK, BIGINNING_DAY_OF_WEEK); // 週の頭をセット
SimpleDateFormat weekFormatter = new SimpleDateFormat("E"); // 曜日を取得するフォーマッタ
for (int i = 0; i < WEEKDAYS; i++) {
TextView textView = (TextView) mWeekLayout.getChildAt(i);
textView.setText(weekFormatter.format(week.getTime())); // テキストに曜日を表示
week.add(Calendar.DAY_OF_MONTH, 1);
}
}
/**
* 日付を設定していくメソッド
*
* @param year 年の指定
* @param month 月の指定
*/
private void setDays(int year, int month) {
Calendar targetCalendar = getTargetCalendar(year, month);
int skipCount = getSkipCount(targetCalendar);
int lastDay = targetCalendar.getActualMaximum(Calendar.DATE);
int dayCounter = 1;
Calendar todayCalendar = Calendar.getInstance();
int todayYear = todayCalendar.get(Calendar.YEAR);
int todayMonth = todayCalendar.get(Calendar.MONTH);
int todayDay = todayCalendar.get(Calendar.DAY_OF_MONTH);
for (int i = 0; i < MAX_WEEK; i++) {
LinearLayout weekLayout = mWeeks.get(i);
weekLayout.setBackgroundColor(DEFAULT_BACKGROUND_COLOR);
for (int j = 0; j < WEEKDAYS; j++) {
TextView dayView = (TextView) weekLayout.getChildAt(j);
// 第一週かつskipCountが残っていれば
if (i == 0 && skipCount > 0) {
dayView.setText(" ");
skipCount--;
continue;
}
// 最終日より大きければ
if (lastDay < dayCounter) {
dayView.setText(" ");
continue;
}
// 日付を設定
dayView.setText(String.valueOf(dayCounter));
boolean isToday = todayYear == year &&
todayMonth == month &&
todayDay == dayCounter;
if (isToday) {
dayView.setTextColor(TODAY_COLOR); // 赤文字
dayView.setTypeface(null, Typeface.BOLD); // 太字
weekLayout.setBackgroundColor(TODAY_BACKGROUND_COLOR); // 週の背景グレー
} else {
dayView.setTextColor(DEFAULT_COLOR);
dayView.setTypeface(null, Typeface.NORMAL);
}
dayCounter++;
}
}
}
/**
* カレンダーの最初の空白の個数を求める
*
* @param targetCalendar 指定した月のCalendarのInstance
* @return skipCount
*/
private int getSkipCount(Calendar targetCalendar) {
int skipCount; // 空白の個数
int firstDayOfWeekOfMonth = targetCalendar.get(Calendar.DAY_OF_WEEK); // 1日の曜日
if (BIGINNING_DAY_OF_WEEK > firstDayOfWeekOfMonth) {
skipCount = firstDayOfWeekOfMonth - BIGINNING_DAY_OF_WEEK + WEEKDAYS;
} else {
skipCount = firstDayOfWeekOfMonth - BIGINNING_DAY_OF_WEEK;
}
return skipCount;
}
private Calendar getTargetCalendar(int year, int month) {
Calendar targetCalendar = Calendar.getInstance();
targetCalendar.clear(); // カレンダー情報の初期化
targetCalendar.set(Calendar.YEAR, year);
targetCalendar.set(Calendar.MONTH, month);
targetCalendar.set(Calendar.DAY_OF_MONTH, 1);
return targetCalendar;
}
}</pre>
<br /></div>
<div>
実際に使うときはこんなかんじで<br />
<br />
<pre class="java" name="code">CalendarView calendarView = (CalendarView) findViewById(R.id.carendar);
calendarView.set(2013, 3-1); // 2013年3月にセット
</pre>
<br />
実際に生成されるViewは参考元とほぼ同じです。<br />
<br />
後は、日付部分にListenerつけたり、ViewPagerにセットするなりで色々カスタマイズすれば、独自のカレンダーが作れます。</div>
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com4tag:blogger.com,1999:blog-3034960118667815461.post-49121418341687682092013-02-07T21:48:00.000+09:002013-02-16T11:09:04.879+09:00SimpleCursorAdapterのListViewが即座に更新されない時に確認すべき箇所SimpleCursorAdapterを使っているLIstViewが更新されなくて色々調べたので書く。<br />
<br />
問題だったのは、ListViewのアイテムをクリックした時にSQLiteの該当データを削除する機能を実装していたんだけど、押しても即座に更新されなくてどーすんのかなーっと思って調べた。<br />
<br />
よくあるのは<br />
<pre class="java" name="code">mAdapter.notifyDataSetChanged();
</pre>
とかで更新するってあるけどこれはどうもArrayAdapterだけの時っぽい。
<br />
<br />
<a href="http://tmken2.blog95.fc2.com/blog-entry-19.html">SimpleCursorAdapterのListView更新について</a><br />
とかも試したけど、Cursor#requery()ってのがUIスレッドでの更新処理なので使うなって怒られたので、これもちがうなーと。<br />
<br />
で、さらに調べてたら次の記事を見つけた。<br />
<br />
<a href="http://d.hatena.ne.jp/kaw0909/20120923/1348381926">CursorAdapterとContentProviderの関係</a><br />
<br />
どうやら正しいContentProviderを作ってないとSimpleCursorAdapterが変更を検知できないらしい。<br />
<br />
で、自分の作ったContentProvider見てみると、ContentProvider#query()で次のコードが抜けてた。
<br />
<pre class="java" name="code">cursor.setNotificationUri(getContext().getContentResolver(), uri);
</pre>
上のコードをqueryBuilderからcursorを取得した後に書いておかないとダメだった。
<br />
<br />
作るときに参考にしたサンプルにはちゃんと書かれていたので普通に自分のミスでした。<br />
<br />
で、修正すると、即座に更新されるようになった。<br />
<br />
他にもありそうなのはContentProvider#insert()とかで<br />
<pre class="java" name="code">getContext().getContentResolver().notifyChange(uri, null);
</pre>
とかかな。
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-9678144875955239082013-02-07T18:21:00.000+09:002013-02-07T18:21:35.742+09:00SimpleCursorAdapterを使っているListViewのアイテム要素にListenerをつけるAndroidでSimpleCursorAdapterを使っているListViewでレイアウトの中にListenerをつけたので、その備忘録として。<br />
<br />
やりたかったのは、SimpleCursorAdapterを使っているListViewのItem要素の中に複数のclickできるViewがあり、それぞれのclickで異なる動作をすること。<br />
<br />
ポイントは<br />
<br />
<ul>
<li>ListViewの拡張</li>
<li>SimpleCursorAdapterの拡張</li>
</ul>
<div>
<br /></div>
<div>
サンプルとして使うItem要素のxmlはこんな感じ<br />
(今回はTextViewにlistenerをつける。<br />
@stringと@dimensは別に定義してるもの)</div>
<div>
<br /></div>
<div>
list_item.xml</div>
<div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjwQZsmQY7qjz3hTtPhZlswDfqn-4zOp4m7NuTf-64xZg5mdww0-tpQQZXWYTeEVC7_N0A_VOfVi9rgD91d6iDak2VtAXkh9P7db23L5mMLoht3UvD64ffc5MQ7zx-8ZaTpCO5n_qa5NqA/s1600/item_preview.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="77" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjwQZsmQY7qjz3hTtPhZlswDfqn-4zOp4m7NuTf-64xZg5mdww0-tpQQZXWYTeEVC7_N0A_VOfVi9rgD91d6iDak2VtAXkh9P7db23L5mMLoht3UvD64ffc5MQ7zx-8ZaTpCO5n_qa5NqA/s400/item_preview.png" width="400" /></a></div>
<pre class="java" name="code"><?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="8dp"
android:paddingLeft="16dp"
android:paddingRight="16dp"
android:paddingBottom="8dp"
android:orientation="vertical" >
<TextView
android:id="@+id/name_textview"
android:layout_alignParentTop="true"
android:layout_alignParentLeft="true"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="@dimen/text_size_large" />
<TextView
android:id="@+id/point_textview"
android:layout_below="@id/name_textview"
android:layout_alignParentLeft="true"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="@dimen/text_size_small" />
<TextView
android:id="@+id/delete_textview"
android:layout_below="@id/name_textview"
android:layout_alignParentRight="true"
android:layout_width="48dp"
android:layout_height="24dp"
android:gravity="center"
android:text="@string/textview_label_delete"
android:textSize="@dimen/text_size_small" />
<View
android:id="@+id/separator_view_to_left_of_delete"
android:layout_below="@id/name_textview"
android:layout_toLeftOf="@id/delete_textview"
android:layout_width="2dp"
android:layout_height="24dp"
android:background="@android:color/darker_gray" />
<TextView
android:id="@+id/edit_textview"
android:layout_below="@id/name_textview"
android:layout_toLeftOf="@id/separator_view_to_left_of_delete"
android:layout_width="48dp"
android:layout_height="24dp"
android:gravity="center"
android:text="@string/textview_label_edit"
android:textSize="@dimen/text_size_small" />
<View
android:id="@+id/separator_view_to_left_of_edit"
android:layout_below="@id/name_textview"
android:layout_toLeftOf="@id/edit_textview"
android:layout_width="2dp"
android:layout_height="24dp"
android:background="@android:color/darker_gray" />
<TextView
android:id="@+id/record_textview"
android:layout_below="@id/name_textview"
android:layout_toLeftOf="@id/separator_view_to_left_of_edit"
android:layout_width="48dp"
android:layout_height="24dp"
android:gravity="center"
android:text="@string/textview_label_record"
android:textSize="@dimen/text_size_small" />
</RelativeLayout></pre>
<br />
次にListViewを拡張したMyListView。<br />
<pre class="java" name="code">/**
* リスト内にボタンを配置して、ボタンが押された時にonItemClickを通知するListView
*/
public class MyListView extends ListView implements OnClickListener {
/**
* コンストラクタ
*/
public MyListView(Context context) {
super(context);
}
/**
* コンストラクタ
*/
public MyListView(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public void onClick(View v) {
int pos = (Integer)v.getTag();
this.performItemClick(v, pos, v.getId());
}
}
</pre>
<br />
次にSimpleCursorAdapterを拡張したMyCursorAdapter</div>
<pre class="java" name="code">private class MyCursorAdapter extends SimpleCursorAdapter {
public MyCursorAdapter(Context context, int layout, Cursor c,
String[] from, int[] to, int flags) {
super(context, layout, c, from, to, flags);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// viewのセットなどはスーパークラスのメソッドに任せる
View view = super.getView(position, convertView, parent);
/*
* それぞれのTextViewにpositionTagと
* MyListViewのlistenerをつける
*/
TextView deleteTextView = (TextView)view.findViewById(
R.id.delete_textview);
deleteTextView.setTag(position);
deleteTextView.setOnClickListener((MyListView)parent);
TextView editTextView = (TextView)view.findViewById(
R.id.edit_textview);
editTextView.setTag(position);
editTextView.setOnClickListener((MyListView)parent);
TextView recordTextView = (TextView)view.findViewById(
R.id.record_textview);
recordTextView.setTag(position);
recordTextView.setOnClickListener((MyListView)parent);
return view;
}
}
</pre>
<br />
これで、アイテム要素の中のonClick()でListViewのonItemClick()が呼ばれるようになるので、<br />
onItemClick()の中でidで処理を切り替えればOK。<br />
<pre class="java" name="code"> @Override
public void onItemClick(AdapterView<?> parent, View view, int pos, long id) {
switch(view.getId()) {
case R.id.delete_textview:
// 消去の時の処理
break;
case R.id.edit_textview:
// 編集の時の処理
break;
case R.id.record_textview:
// 記録の時の処理
break;
default:
// 通常のonItemClick()の時の処理
break;
}
}
</pre>
<br />
参考にした記事<br />
<a href="http://tomstay.hatenablog.jp/entry/20110421/1303391426">ListViewの中のボタンのクリックイベントをActivityに通知する</a>gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-63961860838528982162013-02-06T18:31:00.000+09:002013-02-06T18:31:36.902+09:00Androidのテキストサイズはdimens.xmlに書いておくアプリ作ってる時のレイアウトで結構次のように書く場合が多い。<br />
<div>
<br /></div>
<div>
<pre class="xml" name="code">android:textSize="18sp"
</pre>
<br />
直に書いてもいいんだけど、Googleさんが<a href="http://developer.android.com/design/style/typography.html">公式:Typography</a>で<br />
「テキストの大きさは限定したほうがいいよ。一つのアプリでテキストサイズがバラバラだと見づらいしね。Android Frameworkでは12sp、14sp、18sp、22spの4つに限定してる」<br />
って言ってて、俺もGoogleさんに従うかな〜と最近はその4種類だけ使うようにしてます。<br />
<br />
で、いっつもレイアウトファイルいじっているわけじゃないので、たまに数値を忘れるんだけど、こうすれば忘れないなーってのを思いついたのでメモ。<br />
<br />
dimens.xml</div>
<pre class="xml" name="code"><resources>
<dimen name="text_size_micro">12sp</dimen>
<dimen name="text_size_small">14sp</dimen>
<dimen name="text_size_medium">18sp</dimen>
<dimen name="text_size_large">22sp</dimen>
</resources></pre>
あとは
<br />
<pre class="xml" name="code">android:textSize="@dimen/text_size_medium"
</pre>
って書くだけでいい。<br />
<br />
別にこの値じゃなくてもいいんだけど、種類は絞った方がいいのでdimens.xmlに書いて限定しておくといいと思う。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-85428987056099968902013-01-27T16:14:00.001+09:002013-01-27T16:19:05.477+09:00Androidのアイデアシート作ってみたFireworksの使い方勉強してて、ある程度使い方覚えたので、練習兼ねてアイデアシート作ってみた。<br />
<div>
<br /></div>
<div>
iPhoneのアイデアシートは頂いたものはあるんだけど、Androidの無かったし、探してもGalaxyNexusのは無かったっぽいので、GalaxyNexusのアイデアシート。</div>
<div>
<br /></div>
<div>
こんな感じ</div>
<div>
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg0m2Yr2VSUvT6TRMZwxviRdFQQ7jbDck639KBAmPW0CJkpzFf-aY5nbZ3-eTyRo48w1iAY-pn7WvwQm7QGSDDaE_wcUrxEjLCgOOmyNqA7n5dD3HkXZQu5j0eESB6CvDfjsT_0iZeeMI8/s1600/android_idea_sheet_galaxy_nexus.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="452" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg0m2Yr2VSUvT6TRMZwxviRdFQQ7jbDck639KBAmPW0CJkpzFf-aY5nbZ3-eTyRo48w1iAY-pn7WvwQm7QGSDDaE_wcUrxEjLCgOOmyNqA7n5dD3HkXZQu5j0eESB6CvDfjsT_0iZeeMI8/s640/android_idea_sheet_galaxy_nexus.png" width="640" /></a></div>
<div>
<br /></div>
<div>
欲しい方は<a href="https://dl.dropbox.com/u/29316085/android_idea_sheet_galaxy_nexus.pdf">PDF</a>どーぞ</div>
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-67123919482091708102013-01-19T18:42:00.000+09:002013-01-19T18:42:01.713+09:00AndroidのLogを使う時のちょっと便利な方法Androidで開発している時に、よく使うのがandroid.util.Logクラスですよね。<br />
<br />
みなさんもよく使っていると思います。<br />
<pre class="java" name="code"> Log.d(TAG, "hogehoge");</pre>
こんな風に使うのが一般的なのですが、これをいろんな場所に組み込んでログを出力してると、後でめんどうなことになります。<br />
<br />
リリースビルドした時も、このログ出力は消えないので、リリース前にはLogの部分を削除したりコメントアウトしたりといった事が必要になってきます。<br />
<br />
Logを組み込んでる場所が5箇所とか10箇所ぐらいなら問題ありませんが、100箇所を超えるようになると、消す作業そのものが大変ですし、消し忘れなども出てきます。<br />
<br />
そして、この問題を解決できる便利な方法があります。<br />
<br />
ADT17から/genに生成されるようになったBuildConfig.javaを利用します。<br />
<pre class="java" name="code">public final class BuildConfig {
public final static boolean DEBUG = true;
}
</pre>
このDEBUGはデバッグビルドの時はtrueのままですが、リリースビルドの時falseになります。<br />
<br />
なのでログを出力する際に以下のようにすると、開発してる時はログが出力され、リリースするときはログが出力されないようになります。<br />
<pre class="java" name="code">if (BuildConfig.DEBUG) {
Log.d(TAG, "hogehoge");
}</pre>
<br />
さらに、いちいちログ出力するのに3行も書くのはちょっとめんどうなので、Loggerクラスを作りました。<br />
<pre class="java" name="code">public class Logger {
private static final String TAG = "MyApplication";
public static final void d(String msg) {
if (BuildConfig.DEBUG) {
Log.d(TAG, msg);
}
}
public static final void d(String tag, String msg) {
if (BuildConfig.DEBUG) {
Log.d(tag, msg);
}
}
public static final void e(String msg) {
if (BuildConfig.DEBUG) {
Log.e(TAG, msg);
}
}
public static final void e(String tag, String msg) {
if (BuildConfig.DEBUG) {
Log.e(tag, msg);
}
}
public static final void i(String msg) {
if (BuildConfig.DEBUG) {
Log.i(TAG, msg);
}
}
public static final void i(String tag, String msg) {
if (BuildConfig.DEBUG) {
Log.i(tag, msg);
}
}
public static final void v(String msg) {
if (BuildConfig.DEBUG) {
Log.v(TAG, msg);
}
}
public static final void v(String tag, String msg) {
if (BuildConfig.DEBUG) {
Log.v(tag, msg);
}
}
public static final void w(String msg) {
if (BuildConfig.DEBUG) {
Log.w(TAG, msg);
}
}
public static final void w(String tag, String msg) {
if (BuildConfig.DEBUG) {
Log.w(tag, msg);
}
}
public static final void heap(){
heap(TAG);
}
public static final void heap(String tag) {
if (BuildConfig.DEBUG){
String msg = "heap : Free=" + Long.toString(Debug.getNativeHeapFreeSize() / 1024) + "kb" +
", Allocated=" + Long.toString(Debug.getNativeHeapAllocatedSize() / 1024) + "kb" +
", Size=" + Long.toString(Debug.getNativeHeapSize() / 1024) + "kb";
Log.v(tag, msg);
}
}
}
</pre>
このクラスを適当な場所に置いて、ログ出力したい箇所で<br />
<pre class="java" name="code">Logger.d("hogehoge");
// もしくは
Logger.d(TAG, "hogehoge");
</pre>
とすると、いつもと同じようにログ出力ができます。もちろんリリースビルド時にはログが出力されません。<br />
あと、heap()メソッドはヒープメモリの情報をログに出力するので、メモリ関連の調査をしてる時に役に立つかなとおもいます。
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-65448838682589545412012-12-18T14:18:00.000+09:002012-12-18T14:18:14.641+09:00これからのAndroidアプリはxhdpiとhdpi<div>
今まではアプリの画像リソースを用意する時は、hdpiをメインに余力があれば、mdpiも用意するというのが主流でしたが、Android4.0以上の端末がたくさん発売されて、それにともない、高解像度の端末も増えてきました。</div>
<div>
<br /></div>
<div>
<a href="http://developer.android.com/about/dashboards/index.html">公式の情報</a>によると2012年12月3日時点でldpiが約2%、mdpiが約18%、hdpiが約51%、xhdpiが約29%になっています。</div>
<div>
これからはldpi、mdpiの端末が減っていき、xhdpiの端末が増えていくはずなので、画像リソースはhdpi、xhdpi用の2種類を用意するのがよさそうです。</div>
<div>
<br /></div>
<div>
xhdpiの端末でもhdpiの画像リソースがあれば、表示されるようになっていますが、表示する上で問題があります。</div>
<div>
<br /></div>
<div>
わざとhdpiにだけ画像をおいて、試してみます。</div>
<div>
今回はAndroidのマーク(280x280の大きさ)の画像を用いました。</div>
<div>
左が、hdpiで、右がxhdpiのキャプチャー画像です。</div>
<div>
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiO61VK6cFxIapUIy7Rzwf3LcYPpCIdDpi-sCN6gkOEsGI3BKuKjE7QqNidhvRFME9yUPksewo6ceCFCks7cKyQSOmJ2pzl6xgNxVhiKNYNrE8si7-P_6MSi9LRH2wllw19uqJJCx5lMGI/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-12-18+13.10.59.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="366" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiO61VK6cFxIapUIy7Rzwf3LcYPpCIdDpi-sCN6gkOEsGI3BKuKjE7QqNidhvRFME9yUPksewo6ceCFCks7cKyQSOmJ2pzl6xgNxVhiKNYNrE8si7-P_6MSi9LRH2wllw19uqJJCx5lMGI/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-12-18+13.10.59.png" width="400" /></a></div>
<div>
<br /></div>
<div>
見た目の大きさを同じにするためにxhdpiの端末では画像がシステムによって拡大されています。</div>
<div>
拡大するということは、画面に描画する際に画像処理が入るので、バッテリーとメモリを消費することになります。</div>
<div>
今回のテストでは、画像が一つなので、あまり問題ありませんが、アプリをフルデザインしていると、アプリが強制終了する原因にもなります。</div>
<div>
<br /></div>
<div>
最近はアプリのデザイン自体は1280x720(xhdpi)で作ることが理想的(詳細は「<a href="http://www.ladybeetle-design.com/androidappdesigns/">デザイナーがコードから読み解く、Androidアプリのデザインの幅を広げるコツとTips</a>」)なのですが、その大きさで作った画像素材を何も考えずにhdpiに入れて実装し、苦労してレイアウトを調整(viewのサイズをハードコーディングしたり)して、作ってたことがありました。そのアプリは、リリース後、リソースが見つからないなどのバグ報告がちょこちょこ上がってきていました。</div>
<div>
<br /></div>
<div>
そしてリソース画像の用意ですが、デザイナーさんがxhdpiとhdpiの2種類を用意してくれる時はそれでいいのですが、1280x720でデザインして、プログラマーのもとにやってくるのはxhdpi用の画像だけという場合があります。</div>
<div>
自分が関わっているプロジェクトでも、xhdpi用の画像だけしか渡されませんでした。</div>
<div>
<br /></div>
<div>
なのでこちらですべての画像をリサイズしなければいけませんでした。</div>
<div>
<br /></div>
<div>
自分が画像をリサイズする際に、一つ一つ変換するのはとてもめんどくさかったので、macに標準で入っているAutomatorを使いました。</div>
<div>
<br /></div>
<div>
Windowsで開発されている方は、画像を一括変換できるフリーソフトがあると思うので、そちらを使ってください。</div>
<div>
<br /></div>
<div>
Automatorはあまり複雑なことはできませんが、単純な作業を任せるのに向いているので、まだ使ったことない人は色々ためしてみるといいですよ。</div>
<div>
<br /></div>
<div>
今回はxhdpiの画像をhdpiの画像に変換するための使い方を紹介します。</div>
<div>
mdpiを1とした時に、hdpiは1.5、xhdpiは2の割合なので、xhdpiの画像を75%にしたものがhdpiの画像になります。</div>
<div>
<br /></div>
<div>
その作業をAutomatorでやってみます。</div>
<div>
<ol>
<li>まずは、変換作業に使うフォルダを作ります。どこでもいいので「xhdpi」と「hdpi」のフォルダをつくり「xhdpi」に画像リソースをすべて入れます。</li>
<li>Automatorを起動し、「ワークフロー」を選択します。</li>
<li>左のメニューから「ファイルとフォルダ」→「Finder項目を検索」を選び、右のスペースにドラッグ&ドロップします。</li>
<li>「Finder項目を検索」の詳細を設定します。検索を「xhdpi」にして、「ファイル拡張子」が「png」「である」に設定します。</li>
<li>左のメニューから「写真」→「イメージをサイズ調整」を選び、右のスペースの「Finder項目を検索」の下にドラッグ&ドロップします。</li>
<li>途中「Finder項目のコピー」を追加するかどうかのダイアログが表示されるので、「追加」を選択します。</li>
<li>「Finder項目をコピー」の保存先を「hdpi」に設定します。</li>
<li>「イメージサイズを調整」で「比率(パーセント)指定」「75」に設定します。</li>
</ol>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhx9DwZTfwdHTpsodNGneQFXsRULvgsAScwH38gjxrQTu8o4d-BCkhsTglaRfgvtUUw_6QBbz254YLat93YzLrBAz3AoPJ7veTDIILDORxE1FOzOruwWGumRSC6cu3ym3wfNPw1Pc-QLW0/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-12-18+14.09.29.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img alt="" border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhx9DwZTfwdHTpsodNGneQFXsRULvgsAScwH38gjxrQTu8o4d-BCkhsTglaRfgvtUUw_6QBbz254YLat93YzLrBAz3AoPJ7veTDIILDORxE1FOzOruwWGumRSC6cu3ym3wfNPw1Pc-QLW0/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-12-18+14.09.29.png" title="" width="360" /></a></div>
<div>
<br /></div>
<div>
上記の手順でxhdpiの画像からhdpiの画像を複製するワークフローの完成です。</div>
</div>
<div>
あとは右上の「実行」ボタンをクリックすれば、処理が走って、すべての画像を複製してくれます。Automator便利!</div>
<div>
xhdpiとhdpiで同じ名前の画像ファイルができるので、Androidプロジェクトのresフォルダにそのまま入れて大丈夫です。</div>
<div>
<br /></div>
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-17176871959762203062012-12-02T00:00:00.000+09:002012-12-02T14:26:59.003+09:00海外のサイトにレビュー依頼してみた。本エントリーは<a href="http://androidadvent.blogspot.jp/2012/11/welcome-to-android-advent-calendar-2012.html" target="_blank">Android Advent Calendar 2012</a>の12/2裏エントリーです。<br />
<br />
12/2の表エントリーは<a href="https://twitter.com/rkisato">@rkisato</a>さんの「<a href="http://www.kisato.net/wp/android/androidadvent-2012-12-02/">NOT専門家向け・Android一問一答</a>」です<span style="color: #555555; font-family: Verdana, BitStream vera Sans, Tahoma, Helvetica, sans-serif;"><span style="line-height: 17px;">。そちらもあわせて御覧ください。</span></span><br />
<div>
<br /></div>
<div>
今回はAndroidアプリを海外に向けて宣伝するために海外のレビューサイトに記事掲載依頼をしたのでそのレポートという形式になっています。</div>
<div>
<br /></div>
<div>
個人で作っているデベロッパーさん、また会社でアプリを作っている企業さんで海外に向けて宣伝したい人は参考になると思われます。</div>
<div>
<br /></div>
<div>
このエントリーを見ている人は個人でAndroidアプリを作ったことがあったり、会社でAndroidやってる人だと思います。</div>
<div>
<br /></div>
<div>
どうせなら、自分が作った、もしくは製作に関わったアプリはできるだけ多くのユーザに使ってもらいたいですよね。</div>
<div>
<br /></div>
<div>
現在、アプリを宣伝する方法は次のようにいろいろあります。</div>
<div>
<br /></div>
<h2>
<span style="font-size: large; font-weight: normal;">レビューサイト</span></h2>
<div>
OCTOBAさんとかAndroiderさんとかに依頼してレビュー記事を掲載してもらいます。</div>
<div>
依頼して確実に掲載されるわけではないですが、無料です。</div>
<div>
<br /></div>
<h2>
<span style="font-size: large; font-weight: normal;">プレスリリースを打つ</span></h2>
<div>
個人のデベロッパーさんはなかなか打つのは難しいと思います。無料のもありますが無料のはそんなに効果ないです。</div>
<div>
<br /></div>
<h2>
<span style="font-weight: normal;">アドネットワーク</span></h2>
<div>
デベロッパーコンソールで「このアプリを宣伝する」ってやつですね。AdMobのバナーを通して、Androidユーザに向けて宣伝できます。以前5000円ぐらい突っ込んだことがありますが、一瞬でなくなって効果もあんまりなかったです。</div>
<div>
<br /></div>
<h2>
<span style="font-weight: normal;">成果報酬型広告(リワード広告とか)</span></h2>
<div>
成果報酬型の広告です。だいたい1DLあたり200~350円ぐらいが相場のようです。</div>
<div>
<br /></div>
<div>
この他にもいろいろ宣伝する方法はあるかと思いますが、たいていは多くのお金がかかるものです。(記事広告など)</div>
<div>
<br /></div>
<div>
比較的大きな会社や、お金が余ってるところなら、成果報酬型の広告とか記事広告とか売ってバンバンDL稼ぐこともできるかもしれませんが、僕のような個人デベロッパーには無理な話です。</div>
<div>
<br /></div>
<div>
そうなると、個人のデベロッパーはレビュー記事ぐらいしかありません。</div>
<div>
<br /></div>
<div>
日本のアプリレビューサイトへの依頼はすでにやってるよって方も多いかもしれませんが、海外のレビューサイトってなると、なかなかやっていない方も多いんじゃないでしょうか。</div>
<div>
<br /></div>
<div>
やらない理由としては2つの理由があると思います。</div>
<div>
<ol>
<li>どのサイトにレビュー依頼したらいいのかわからない。</li>
<li>英語が得意ではないので依頼の英文が書けない。</li>
</ol>
<div>
1.については英語のレビューサイトをまとめた資料がSlideShareに上がっているのでそちらを利用します。</div>
</div>
<div>
「<a href="http://www.slideshare.net/MinoruYanai/108-14869758" target="_blank">英語108レビューサイトまとめ</a>」</div>
<div>
<br /></div>
<div>
2.については、僕も英文を書くとか全くできないので、格安で日本語を各言語に翻訳してくれるWebサービス「<a href="http://ja.gengo.com/" target="_blank">gengo</a>」を使いました。</div>
<div>
<br /></div>
<div>
<br /></div>
<div>
10月末ごろに、制作したランチャーアプリ「<a href="https://play.google.com/store/apps/details?id=com.andcreate.app.fliplauncher&referrer=utm_source%3Dblog%26utm_campaign%3Dblog" target="_blank">FlipLauncher</a>」のレビュー記事依頼を海外のレビューサイトにお願いしたのでその流れと結果です。</div>
<div>
(FlipLauncherのローカライズは英語だけ行なっています。)</div>
<div>
<br /></div>
<div>
まず、レビュー記事をお願いする英文を「<a href="http://ja.gengo.com/" target="_blank">gengo</a>」で作成します。</div>
<div>
「<a href="http://ja.gengo.com/" target="_blank">gengo</a>」は会員登録する必要がありますが、facebookのアカウントやgoogleのアカウントでもOKなので、開発用のアカウントですませばいいと思います。</div>
<div>
<br /></div>
<div>
gengoは翻訳にグレードが4つあります。</div>
<div>
<br /></div>
<div>
<b>スタンダード</b></div>
<div>
ネイティブスピーカーによる迅速かつ確かな翻訳</div>
<div>
<b><br /></b></div>
<div>
<b>ビジネス</b></div>
<div>
一般公開用および正式な用途に、さらにレベルの高い翻訳を</div>
<div>
<b><br /></b></div>
<div>
<b>ウルトラ</b></div>
<div>
最高のクオリティをお求めの方に、ビジネスレベルの翻訳+校正を</div>
<div>
<br /></div>
<div>
<b>専門分野</b></div>
<div>
<span style="color: #4d4843; font-family: Open Sans, Hiragino Kaku Gothic Pro, sans-serif;"><span style="line-height: 21px;">専門分野のスペシャリストによる翻訳</span></span></div>
<div>
<span style="color: #4d4843; font-family: Open Sans, Hiragino Kaku Gothic Pro, sans-serif;"><span style="line-height: 21px;"><br /></span></span></div>
<div>
<span style="color: #4d4843; font-family: Open Sans, Hiragino Kaku Gothic Pro, sans-serif;"><span style="line-height: 21px;">レビュー記事の掲載依頼なのでスタンダードで十分だと思います。</span></span></div>
<div>
<span style="color: #4d4843; font-family: Open Sans, Hiragino Kaku Gothic Pro, sans-serif;"><span style="line-height: 21px;"><br /></span></span></div>
<div>
<span style="color: #4d4843; font-family: Open Sans, Hiragino Kaku Gothic Pro, sans-serif;"><span style="line-height: 21px;">で、スタンダードで訳しました。</span></span></div>
<div>
<br /></div>
<div>
日本文<span style="color: #4d4843; font-family: 'Open Sans', 'Hiragino Kaku Gothic Pro', sans-serif; line-height: 21px;">(1行目は件名として)</span></div>
<div>
=======================================================</div>
<div>
<div class="p1">
Androidアプリ[[[FlipLauncher]]]のレビューのお願い</div>
<div class="p2">
<br /></div>
<div class="p1">
こんにちは。</div>
<div class="p2">
<br /></div>
<div class="p1">
私は日本のAndroidアプリ開発者です。</div>
<div class="p2">
<br /></div>
<div class="p1">
サイトにレビュー記事を載せて頂きたく連絡しました。</div>
<div class="p2">
<br /></div>
<div class="p1">
レビュー記事に取り上げていただきたいアプリは以下です。</div>
<div class="p2">
<br /></div>
<div class="p1">
アプリ名:</div>
<div class="p1">
[[[FlipLauncher]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
アプリURL:</div>
<div class="p1">
[[[https://play.google.com/store/apps/details?id=com.andcreate.app.fliplauncher]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
アプリ概要:</div>
<div class="p1">
[[[ ]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
ユーザの使いやすさを第一に考えて作ったアプリです。</div>
<div class="p2">
<br /></div>
<div class="p1">
よろしくお願いします。</div>
<div class="p1">
=======================================================</div>
<div class="p1">
<br /></div>
<div class="p1">
この日本文がこうなります。</div>
<div class="p1">
<br /></div>
<div class="p1">
「<a href="http://ja.gengo.com/" target="_blank">gengo</a>」で英訳された文</div>
<div class="p1">
=======================================================</div>
<div class="p1">
</div>
<div class="p1">
A request for a review of the android application [[[FlipLauncher]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
Hello.</div>
<div class="p2">
<br /></div>
<div class="p1">
I am a Japanese android application developer.</div>
<div class="p2">
<br /></div>
<div class="p1">
I have contacted you to ask if our site could publish a review article.</div>
<div class="p2">
<br /></div>
<div class="p1">
The application I would like you to review is listed below.</div>
<div class="p2">
<br /></div>
<div class="p1">
Application name:</div>
<div class="p1">
[[[FlipLauncher]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
Application URL:</div>
<div class="p1">
[[[https://play.google.com/store/apps/details?id=com.andcreate.app.fliplauncher]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
Application outline:</div>
<div class="p1">
[[[ ]]]</div>
<div class="p2">
<br /></div>
<div class="p1">
This is an application designed with ease of use in mind.</div>
<div class="p2">
<br /></div>
<div class="p1">
Thank you for your consideration.</div>
<br />
<div class="p1">
=======================================================</div>
<div class="p1">
<br /></div>
<div class="p1">
英語に翻訳してほしくない箇所、翻訳する必要のない箇所は[[[ ]]]で囲めば翻訳されません。</div>
<div class="p1">
<br /></div>
<div class="p1">
この英訳を依頼してから、1時間ぐらいで英訳された文章が提案されてきました。修正して欲しい箇所がある場合は部分的に修正依頼することもできます。</div>
<div class="p1">
この文章でかかった翻訳料金は351円でした。</div>
<div class="p1">
<br /></div>
<div class="p1">
アプリ概要の部分には、予め英訳しているGoogle Play のアプリ紹介文のところをそのまま突っ込みます。</div>
</div>
<div>
<br /></div>
<div>
アプリ紹介文の方は日本語419文字で翻訳料金1089円でした。</div>
<div>
<br /></div>
<div>
で英訳した文章をもとに各英語レビューサイトに依頼していきます。</div>
<div>
<br /></div>
<div>
まずは乗っている全メールアドレスにメールしていきます。</div>
<div>
<br /></div>
<div>
自分がやったときは一件一件クリックしてメーラーが立ち上がったり、リンクが無効だったりで大変めんどうだったので、コピーや手打ちでメールアドレスを持ってきてBCCでメールを送信しました。</div>
<div>
<br /></div>
<div>
メールアドレスはまとめてあるので使いたい人は「<a href="https://dl.dropbox.com/u/29316085/contact_email_list.txt.zip" target="_blank">ここ</a>」からどうぞ。</div>
<div>
(いくつかエラーメールがかえってきました。すでに無効のメールアドレスもいくつかあるようです。)</div>
<div>
<br /></div>
<div>
次に、乗っているリンクをたどってフォーム上でレビューの依頼をしていきます。</div>
<div>
「inquiry」をクリックするとそれぞれのサイトの申請フォームに直接飛ぶので必要事項を入力してポストします。(結構大変です)</div>
<div>
<br /></div>
<div>
大体どのフォームも氏名、メールアドレス、件名、本文なので、一時的にどこかにメモっておいてひたすらコピペしました。</div>
<div>
<br /></div>
<div>
以上で申請作業は終わりです。「FlipLauncher」のときは10/29日のお昼ぐらいにやりました。</div>
<div>
<br /></div>
<div>
ここから今まででどれくらい効果があったかを見てみます。</div>
<div>
<br /></div>
<div>
紹介されたサイト一覧</div>
<div>
<br /></div>
<div>
<div class="p1">
<b>Android Police 10/29</b></div>
<div class="p1">
<a href="http://www.androidpolice.com/2012/10/29/new-app-fliplauncher-is-an-ultra-quick-way-to-launch-apps-from-anywhere/">http://www.androidpolice.com/2012/10/29/new-app-fliplauncher-is-an-ultra-quick-way-to-launch-apps-from-anywhere/</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>smartdroid 10/29</b></div>
<div class="p1">
<a href="http://www.smartdroid.de/fliplauncher-fuer-android-ermoeglicht-zugriff-auf-apps-von-ueberall/">http://www.smartdroid.de/fliplauncher-fuer-android-ermoeglicht-zugriff-auf-apps-von-ueberall/</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>noticias android 10/29</b></div>
<div class="p1">
<a href="http://noticias-android.com/fliplauncher-es-una-forma-ultra-rapida-para-iniciar-aplicaciones-desde-cualquier-lugar/?utm_source=dlvr.it&utm_medium=twitter">http://noticias-android.com/fliplauncher-es-una-forma-ultra-rapida-para-iniciar-aplicaciones-desde-cualquier-lugar/?utm_source=dlvr.it&utm_medium=twitter</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>Android Spin 10/29</b></div>
<div class="p1">
<a href="http://androidspin.com/2012/10/29/app-flip-launcher-24-apps-or-shortcuts-at-your-finger-tips-on-any-screen/">http://androidspin.com/2012/10/29/app-flip-launcher-24-apps-or-shortcuts-at-your-finger-tips-on-any-screen/</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>gizmode australia (list-up) 10/30</b></div>
<div class="p1">
<a href="http://www.gizmodo.com.au/2012/10/app-deals-android-iphone-ipad-wp7-10/?utm_source=twitterfeed&utm_medium=twitter&utm_campaign=Feed%3A+GizmodoAustralia+%28Gizmodo+Australia%29">http://www.gizmodo.com.au/2012/10/app-deals-android-iphone-ipad-wp7-10/?utm_source=twitterfeed&utm_medium=twitter&utm_campaign=Feed%3A+GizmodoAustralia+%28Gizmodo+Australia%29</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>Android apps olicious 10/30</b></div>
<div class="p1">
<a href="http://www.androidapps.com/tech/articles/12905-new-android-apps-worth-downloading-google-search-update-flip-launcher-chrono-trigger">http://www.androidapps.com/tech/articles/12905-new-android-apps-worth-downloading-google-search-update-flip-launcher-chrono-trigger</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>Droid LIFE 10/31</b></div>
<div class="p1">
<a href="http://www.droid-life.com/2012/10/30/flip-launcher-for-android-convenient-app-launching-with-the-flick-of-a-finger/?utm_source=twitterfeed&utm_medium=twitter&utm_campaign=Feed%3A+DroidLife+%28droid+life%29">http://www.droid-life.com/2012/10/30/flip-launcher-for-android-convenient-app-launching-with-the-flick-of-a-finger/?utm_source=twitterfeed&utm_medium=twitter&utm_campaign=Feed%3A+DroidLife+%28droid+life%29</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>your life updated 11/01</b></div>
<div class="p1">
<a href="http://yourlifeupdated.it/android/flip-launcher-launcher-originale-per-tenere-sotto-controllo-le-app-piu-importanti-android-app/?utm_source=twitterfeed&utm_medium=twitter">http://yourlifeupdated.it/android/flip-launcher-launcher-originale-per-tenere-sotto-controllo-le-app-piu-importanti-android-app/?utm_source=twitterfeed&utm_medium=twitter</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>letsgodroid 11/01</b></div>
<div class="p1">
<a href="http://letsgodroid.blogspot.jp/2012/10/conheca-o-flip-launcher-for-android-e.html">http://letsgodroid.blogspot.jp/2012/10/conheca-o-flip-launcher-for-android-e.html</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>Android Headlines (list-up) 11/01</b></div>
<div class="p1">
<a href="http://androidheadlines.com/2012/10/droid-daily-103112-flip-launcher-samsung-us-cellular-att-htc-desire-c-and-more.html">http://androidheadlines.com/2012/10/droid-daily-103112-flip-launcher-samsung-us-cellular-att-htc-desire-c-and-more.html</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>AndroidVZLA 11/02</b></div>
<div class="p1">
<a href="http://www.androidvzla.com/2012/11/flip-launcher-nuevo-launcher-de.html?utm_source=twitterfeed&utm_medium=twitter">http://www.androidvzla.com/2012/11/flip-launcher-nuevo-launcher-de.html?utm_source=twitterfeed&utm_medium=twitter</a></div>
<div class="p2">
<br /></div>
<div class="p1">
<b>makeuseof 11/03</b></div>
<div class="p1">
<a href="http://www.makeuseof.com/dir/flip-launcher-easy-switch-apps-phone-android/">http://www.makeuseof.com/dir/flip-launcher-easy-switch-apps-phone-android/</a></div>
</div>
<div>
<br /></div>
<div>
一番早いところで、お昼に出したものが夜の9時ごろに紹介されてました。</div>
<div>
それから続々といろんなサイトに取り上げてもらえて確認できているぶんで12サイトでした。</div>
<div>
<br /></div>
<div>
ゲームアプリレビューサイトを除く80サイトぐらいに依頼を出したので、打率は15%ぐらいです。今回のアプリがランチャーアプリだったので、もっと一般的なツールやゲームアプリだともっと取り上げてくれるかもしれません。</div>
<div>
<br /></div>
<div>
次にダウンロードの推移がどの程度変化したかを示します。</div>
<div>
(図の赤線は2012/10/29を表しています。)</div>
<div>
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjwX3ZlzzHT6bkcs1QF0Qbhys5gdo6XlSgnAVJ9BLVfM3a-821J9eI-QNu6f8Y5FUY5ZDmIHYuQecTP3_E1hvOZQmlxwXyPujLDnN4Ee54xigZYzOu_vwgOOEWfCucyBqZV6f8EVlxU_4U/s1600/fliplauncher_screenshot01.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="223" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjwX3ZlzzHT6bkcs1QF0Qbhys5gdo6XlSgnAVJ9BLVfM3a-821J9eI-QNu6f8Y5FUY5ZDmIHYuQecTP3_E1hvOZQmlxwXyPujLDnN4Ee54xigZYzOu_vwgOOEWfCucyBqZV6f8EVlxU_4U/s400/fliplauncher_screenshot01.png" width="400" /></a></div>
<div>
<br /></div>
<div>
海外でレビュー記事が紹介されはじめたところからダウンロード数が増加しています。</div>
<div>
<br /></div>
<div>
そして、12/2現在で確認できる統計での総ダウンロード数は下図になります。</div>
<div>
<br /></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi7OKcwUlqxG_0CVsryL-AykyqCzMfCUjO20PRvAsUuHO7ndb39vWac561gdt1ucHGA1xYTalPy0aBfloiOtav1rti4cmlyKozuzmCLy9h2uIqxdvusXp8bVRTB2sXGQi1iPytEYO4_cs8/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-12-01+16.34.43.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="245" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi7OKcwUlqxG_0CVsryL-AykyqCzMfCUjO20PRvAsUuHO7ndb39vWac561gdt1ucHGA1xYTalPy0aBfloiOtav1rti4cmlyKozuzmCLy9h2uIqxdvusXp8bVRTB2sXGQi1iPytEYO4_cs8/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-12-01+16.34.43.png" width="400" /></a></div>
<div>
<br /></div>
<div>
<br /></div>
<div>
日本以外の合計は約19000インストールなのでかなり効果があったことがわかります。</div>
<div>
<br /></div>
<div>
今では1日の海外のダウンロード数も大分下がってきましたが、それでも一日平均100DLぐらいあります。海外のレビュー記事が掲載される前は一日平均5DLぐらいでした。</div>
<div>
<br /></div>
<div>
掛かったのは翻訳料金の約1500円と掲載依頼作業2時間ほどなので、海外ユーザにも使って欲しいアプリを作っている人は十分やる価値はあるとおもいます。</div>
<div>
<br /></div>
<div>
掲載依頼したところから「俺のところは今一日50件以上の依頼が来るから全てに対応するのは難しいんだよ。30ドルくれたら、優先してトップにレビュー記事掲載してあげるよ」みないな英文のメールが幾つかきてましたが、やりませんでした。それもやるともっとDL数が伸びるかもしれません。<br />
<br /></div>
gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-59745810004790375492012-09-06T22:48:00.001+09:002012-09-06T22:48:50.275+09:009patchの画像をdraw9patch以外で作成する方法Androidのデザインで伸びて欲しい部分を指定できる便利な9patchという方法があります。<br />
<br />
そしてこれはAndroidSDKの中に入っているdraw9patchで作るのですが、これがあまり使いやすいとは言えない。<br />
<br />
そして今日<br />
<br />
<a href="http://www.zusaar.com/event/366053" target="_blank">デザイナーがコードから読み解く、 Androidアプリのデザインの幅を広げるコツとTips【第1回】</a><br />
<br />
に参加してきました。<br />
<br />
その中で、発表者がdraw9patch以外では9patch画像をうまく作れないといっていたので、<br />
<br />
ちょっと試してみました。<br />
<br />
使った画像はこれです。<br />
<br />
ちょっと前までプロジェクトの新規作成で自動生成されていたやつですね。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhQZ6hNM4JUeIMkl2m6yZr2slwqzfiv68OwL01-1uWahrb_wrDgW3otu2hXeoFSRpE1RSmsohyuV5VpdFmFR4k2kUsregT_vIkbNKwMV67YAZM3VouR1RGTai2pp4p0UAxUcmsnP0V7CDk/s1600/%E3%82%AD%E3%83%A3%E3%83%97%E3%83%81%E3%83%A3%EF%BC%91.PNG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhQZ6hNM4JUeIMkl2m6yZr2slwqzfiv68OwL01-1uWahrb_wrDgW3otu2hXeoFSRpE1RSmsohyuV5VpdFmFR4k2kUsregT_vIkbNKwMV67YAZM3VouR1RGTai2pp4p0UAxUcmsnP0V7CDk/s320/%E3%82%AD%E3%83%A3%E3%83%97%E3%83%81%E3%83%A3%EF%BC%91.PNG" width="314" /></a></div>
<br />
<br />
9patchは、画像の周囲1pixelの部分に黒点を描画することで、その部分が伸びるように認識させる事ができます。<br />
<br />
なので72x72のものを74x74に拡大し、こんなふうに黒点を描画してみます。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjZrnYklgSianrg6lhZGuXiRmcYkRwN19Z55F5lSX8vQMD4BxIQrhXtW64la7MUOied4TcPxFIPw7SFl5vL3uzOmHBSssgtWmuJwowBJPF7PXzVYAZh4cblS4FO5IytazZsgyK9f2ubk3Y/s1600/%E3%82%AD%E3%83%A3%E3%83%97%E3%83%81%E3%83%A32.PNG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjZrnYklgSianrg6lhZGuXiRmcYkRwN19Z55F5lSX8vQMD4BxIQrhXtW64la7MUOied4TcPxFIPw7SFl5vL3uzOmHBSssgtWmuJwowBJPF7PXzVYAZh4cblS4FO5IytazZsgyK9f2ubk3Y/s320/%E3%82%AD%E3%83%A3%E3%83%97%E3%83%81%E3%83%A32.PNG" width="308" /></a></div>
<br />
<br />
上と左の黒点の交わった部分が伸びる部分で、右と下の黒点(もはや黒い線)の交わった部分が、内容を表示できるエリアです。<br />
<br />
これを、PhotoShop CS5で作成しました。<br />
<br />
それをリソースファイルに入れて、ImageViewの背景に指定し画面いっぱいに広げたらこんな風になりました。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgs1DOk7XodszQEuIIB0S9Tt3C5LsK4aA4t2TV9y4yLTb394COn6PUkSYa6BQEubSrKWTp0-KW3PgTwNpLsdhlleys-66K7QSkBheg3dKldEUxzRMvT_0_QVxjQ-MC9os-sW09GmRiDPjQ/s1600/%E3%82%AD%E3%83%A3%E3%83%97%E3%83%81%E3%83%A33.PNG" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="314" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgs1DOk7XodszQEuIIB0S9Tt3C5LsK4aA4t2TV9y4yLTb394COn6PUkSYa6BQEubSrKWTp0-KW3PgTwNpLsdhlleys-66K7QSkBheg3dKldEUxzRMvT_0_QVxjQ-MC9os-sW09GmRiDPjQ/s320/%E3%82%AD%E3%83%A3%E3%83%97%E3%83%81%E3%83%A33.PNG" width="320" /></a></div>
<br />
<br />
ちゃんと伸びてますね。<br />
<br />
ということで結論として、9patchの画像をdraw9patchで作ることは可能です。<br />
<br />
ただ、気をつけなければいけない点があります。<br />
<br />
一つ目はAndroidに9patchの画像として認識させるには次のような条件があります。<br />
<br />
周囲1pixelを9patch専用の領域とする。<br />
<br />
9patch専用の領域には完全な黒と完全な透明の2つ以外、存在してはいけない。<br />
<br />
拡張子は「.9.png」とする<br />
<br />
上の勉強会の発表者がうまく作れなかった原因は主に2つ目が原因ではないかなと思います。<br />
<br />
PhotoshopやFireworksなどで9patch用の黒点を打つときに大きさ1pixelのペンで書くと思われますが、位置が少しずれると隣のpixelに少し影響が出ます。その影響で完全な黒でない部分や、うっすらと黒が描画されている部分が発生し、9patchの画像として認識されなかったのではと思っています。<br />
<br />
で、今回この画像を作るときにはペンを使わず、9patchとして指定したい部分を選択範囲にし、その部分を完全な黒で塗りつぶすことによって作成しています。<br />
<br />
あと、これは9patchの生成には関係のないことですが、<br />
<br />
ImageViewのsrc属性に画像を設定しても、伸びてくれませんでした。<br />
<br />
ImageViewのbackground属性に画像を設定したときに、上の画像のように9patchとして認識してくれました。<br />
<br />
9patchは背景画像にしか使えないのかも知れないです。あ、でも背景に使えれば十分か。<br />
<br />
<br />
以上、9patchの生成に関する記事でした。デザイナーさんはいつも使っている環境で9patchの画像を作ることができるので、挑戦してみてください。<br />
<br />
<br />gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com1tag:blogger.com,1999:blog-3034960118667815461.post-31101708586069260652012-08-02T17:52:00.002+09:002012-08-02T17:52:39.849+09:00[Android]OutOfMemoryError(メモリリーク)対策AndroidアプリのOutOfMemoryError(メモリリーク)の対策としてやったことのまとめ。<br />
<br />
Androidアプリを作っている人ならOutOfMemoryErrorに悩まされた事のある人も多いと思います。<br />
<br />
自分も悩まされて色々試行錯誤したので、そのへんをまとめておきます。<br />
<br />
まず、OutOfMemoryErrorに関してですが、エラーレポートには大抵、画像の描画、ロード時に発生したと書かれていることが多いですが、画像が直接の原因じゃないことも結構多いです。(もちろん、単純に画像が大きすぎる、使用する画像の数が多すぎることもありますが、その場合はサイズの縮小などを行なってください。)<br />
<br />
自分も最初は画像が原因だと思い込んでいたので、BitmapのConfigを変更してアルファ情報を抜いたりとかして使用するメモリ容量を減らして、「対策できた!」とか思ってました。<br />
<br />
でも、あんまりエラーレポート減りませんでした。<br />
<br />
で、色々試行錯誤していくうちに画像が原因じゃないなとわかりました。<br />
<br />
アプリを起動すると、様々なオブジェクトが生成されます。色々動かしたあと、アプリを終了します。アプリを終了したあとに、端末のメモリが少なくなってきたらGCが走って使っていないオブジェクトを削除してくれるのですが、アプリを終了した時に色々オブジェクトの参照が残っていたりすると、GCで開放されません。<br />
<br />
そして、次回にアプリを起動した時に、残っているオブジェクトが再利用されるかというと、全く再利用されずに新しいオブジェクトが次々に生成されます。<br />
<br />
これの繰り返しで、ごみオブジェクトがどんどん溜まっていき、それと比例して、アプリが使用するメモリ領域を圧迫していきます。<br />
<br />
そして、何回目かの起動時にメモリを大きく使用する処理(画像のロードとか)がきっかけでOutOfMemoryErrorが発生します。<br />
<br />
なので開発時のデバッグとかでは、ほとんど見つからなく(実機にインストールする段階でアプリが使用するメモリ領域が初期化されるので)、リリース後にエラーレポートが送られてくることになります。やっかいですね。<br />
<br />
で、今回はごみオブジェクトをなるべく残さないようにするためにごみオブジェクトの調べ方と参照の消し方とかを書いておきます。<br />
<br />
まず、調べ方についてですが、Memory Analyzerを使います。<br />
<br />
インストールについては次のページを参照してください<br />
<a href="http://xiangcai.at.webry.info/201009/article_7.html" target="_blank">Eclipseで使うMemory Analyzerのインストール</a><br />
<br />
まず、調べたいアプリを起動して、色々動かしてから戻るボタンなどでアプリを終了させます。<br />
<br />
そしてDDMSを開いて、Memory Analyzerを起動します。<br />
<br />
<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/AVvXsEje6R-0zCRNh_eLJfuIPO41iICcYxVcM3TvlPW4ApRl1eNRElh7fS1LB8lWI5ZiNM_SWda77X7dQmjmdeWzYwPcGI1cZSNdnp-Ch7KVh3-7CIbNrAfnvUQjgRsZY__rLNKjp2NBSkBpz-E/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+13.59.39.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="206" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEje6R-0zCRNh_eLJfuIPO41iICcYxVcM3TvlPW4ApRl1eNRElh7fS1LB8lWI5ZiNM_SWda77X7dQmjmdeWzYwPcGI1cZSNdnp-Ch7KVh3-7CIbNrAfnvUQjgRsZY__rLNKjp2NBSkBpz-E/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+13.59.39.png" width="400" /></a></div>
「Dump HPROF file」をクリックすると初回起動時はダイアログが表示されます。とりあえず、一番上の「Leak Suspects Report」を押します。<br />
<br />
すると、次のような画面が表示されるので、図の部分をクリックして「Histogram」を表示します。<br />
<br />
<span id="goog_451603970"></span><span id="goog_451603971"></span><br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjXBExAGIL6R_pm9ibGxtXbGLP1ESh3IjJ2KudfVSSQ9QoVaSIdT5WIcs3_UxaHXrBAcsSv2TB9gAGydnFxqBIeA0eP9T0dnHe3YpGLtNd3YP2kMUXB3JOU18zo6n_GFYgyqoPlHYRbAn8/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.13.09.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="337" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjXBExAGIL6R_pm9ibGxtXbGLP1ESh3IjJ2KudfVSSQ9QoVaSIdT5WIcs3_UxaHXrBAcsSv2TB9gAGydnFxqBIeA0eP9T0dnHe3YpGLtNd3YP2kMUXB3JOU18zo6n_GFYgyqoPlHYRbAn8/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.13.09.png" width="400" /></a></div>
<br />
Histogramでは、アプリが保持しているオブジェクトの一覧が次の図のような感じで表示されます。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEibXUpk2mcpmYz0tUgqf0cp9i8KJKWH6NKs4F6q3oi5s6UAx37EfgAmcmeFlnx-xxNTMYyqwWxkvXl-WeKYvzYIWAaF1kucZzcooLbOdEwzLBQfr9d2ZT-32wYt0BPnqa3Wj4oV_ejUOkM/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.20.21.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="233" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEibXUpk2mcpmYz0tUgqf0cp9i8KJKWH6NKs4F6q3oi5s6UAx37EfgAmcmeFlnx-xxNTMYyqwWxkvXl-WeKYvzYIWAaF1kucZzcooLbOdEwzLBQfr9d2ZT-32wYt0BPnqa3Wj4oV_ejUOkM/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.20.21.png" width="400" /></a></div>
<br />
<Regex>のところにアプリのパッケージ名を入れると、アプリのオブジェクトがどのくらい開放されずに残っているかが表示されます。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgmBLzgVgvHHq4Y2P2urhDDV0lsG1DQF9kLHov7qrqkzA65Snz36AJIycBoCZ4Iem82FrmR2Q5EhNQ3eR64rAAoHV6YA7A5FCK5Xqi2yOuQi6Gtyu2ljckAhFJD_pvIPFyPoEWbeBFBx-8/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.27.14.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="190" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgmBLzgVgvHHq4Y2P2urhDDV0lsG1DQF9kLHov7qrqkzA65Snz36AJIycBoCZ4Iem82FrmR2Q5EhNQ3eR64rAAoHV6YA7A5FCK5Xqi2yOuQi6Gtyu2ljckAhFJD_pvIPFyPoEWbeBFBx-8/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.27.14.png" width="400" /></a></div>
<br />
アプリが終了したのに、オブジェクトの参照が残っているとこんなかんじになります。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjv15z4Sn-CdgqNKGP-QZTbDGtlHhVxkmkt8c90uFn3YynzAYlGhxMebB0wxOfOXn5lP__cSxEASJhCBOVQoEpgRZ2rQSK4CHuPr8QhcAMtvgUK6vv7gmEm2-hscQEsO6OxIIQHuspGuxQ/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.35.07.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="210" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjv15z4Sn-CdgqNKGP-QZTbDGtlHhVxkmkt8c90uFn3YynzAYlGhxMebB0wxOfOXn5lP__cSxEASJhCBOVQoEpgRZ2rQSK4CHuPr8QhcAMtvgUK6vv7gmEm2-hscQEsO6OxIIQHuspGuxQ/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.35.07.png" width="400" /></a></div>
<br />
起動と終了を繰り返すとどんどん溜まっていきます。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh_Jp-84O_2mjNyNcpkYAySSwOykds1mxs6Yc59FDiaP8IziOTL5sKZg7YzIla0jd-7T8mCi47va2dCcpfGayo1nJWdaeJU7GUZQTTo_J0_UD8svfDYEznWOh5LFYHqM6S4ZeMa1SsYOKM/s1600/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.38.08.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="200" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh_Jp-84O_2mjNyNcpkYAySSwOykds1mxs6Yc59FDiaP8IziOTL5sKZg7YzIla0jd-7T8mCi47va2dCcpfGayo1nJWdaeJU7GUZQTTo_J0_UD8svfDYEznWOh5LFYHqM6S4ZeMa1SsYOKM/s400/%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%BC%E3%83%B3%E3%82%B7%E3%83%A7%E3%83%83%E3%83%88+2012-08-02+16.38.08.png" width="400" /></a></div>
<br />
このようにどんどん、ごみオブジェクトを保持し続けていき、メモリを圧迫していきます。<br />
<br />
アプリの終了時に参照が残っていなければ、何回起動と終了を繰りかえしても、ごみオブジェクトは残りません。<br />
<br />
なので、アプリが終了した時に参照が残らないようにします。<br />
<br />
メモリリークの原因として有名なのはActivityの参照が残り続けることですが、Activity単体が残るだけであれば、そこまで大きな問題ではありません。<br />
問題はActivityが参照しているクラスのインスタンスが残り続けることです。複雑な作りのアプリほど残りやすいです。<br />
<br />
自分が行ったのはActivity#onDestroy()やFragment#onDestroyView()で次のように明示的に参照を切りました。<br />
自分が使ってたのが、Fragment, ViewPager, ListViewぐらいなので、それらの参照の切り方だけ書いています。<br />
<br />
<pre class="java" name="code">/**
* onDestroy()やonDestroyView()で
*/
//Fragmentのとき
fragment = null;
//ViewPagerのとき
viewPager.setAdapter(null);
adapter = null;
//ListViewのとき
listView.setAdapter(null);
adapter = null;
//各種リスナー
button.setOnClickListener(null);
</pre>
<br />
特に、カスタムしたView,Adapter,Listenerなどは明示的に参照を切らないと残り続けるようです。<br />
<br />
自分の場合、このように明示的に参照を切ってあげる事でほとんどオブジェクトが残らなくなりました。<br />
<br />
検索かけてもあまりこの辺の具体的な情報はあまり見つからなかったので(見つけられなかっただけかもしれない...)、OutOfMemoryError(メモリリーク)で困っている人の手助けになれば幸いです。<br />
<br />
ちなみに今回対策したアプリはこちらです。<a href="https://play.google.com/store/apps/details?id=jp.quan_inc.kaomojibank" target="_blank">「顔文字BANK」</a><br />
良ければ、DLして使ってください。<br />
<br />gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-24789678022287904392012-04-30T14:46:00.000+09:002012-04-30T14:46:45.072+09:00ViewFlipperを使ってリストビューのレイアウトを切り替えるAndroidのアプリでよく使われるListViewについて。<br />
<br />
すべての要素が同じなら普通にListAdapterをセットすればいいんだけど、間になにか要素を挟みたいときとかなかなか苦労する。ListViewの要素を再利用するためにViewHolderとか使ってるとレイアウトが固定されてしまうので。<br />
<br />
今回はViewHolderを使いつつある箇所でListViewの要素のレイアウトを切り替えることができたのでメモ。<br />
<br />
ビューの切り替え自体はViewFlipperを使う。<br />
<br />
リストビューの1つの要素のXMLはこんな感じ(object.xml)<br />
<pre class="xml" name="code"><?xml version="1.0" encoding="utf-8"?>
<ViewFlipper xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/flipper"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<!-- ViewFlipperの初期画面(1ページ目) -->
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TextView
android:id="@+id/text_view"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
</LinearLayout>
<!-- ViewFlipperの2ページ目 -->
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<Button
android:id="@+id/button"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
</LinearLayout>
</ViewFlipper>
</pre>
<br />
テスト用のアクティビティのXML(main.xml)<br />
<pre class="xml" name="code"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<ListView
android:id="@+id/listview"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</ListView>
</LinearLayout>
</pre>
<br />
そしてサンプルコードはこんな感じ(MainActivity.java)<br />
<pre class="java" name="code">package com.andcreate.sample.viewflipperlistview;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.ViewFlipper;
public class MainActivity extends Activity{
@Override
public void onCreate(Bundle bundle){
super.onCreate(bundle);
setContentView(R.layout.main);
ListView listView = (ListView)findViewById(R.id.listview);
List<ObjectData> objects = new ArrayList<ObjectData>();
for(int i = 0; i < 50; i++){
if(i % 5 == 0){
objects.add(new ObjectData("text:" + i, "button:" + i, false));
}
else{
objects.add(new ObjectData("text:" + i, "button:" + i, true));
}
}
listView.setAdapter(new SampleAdapter(this, objects));
}
}
class ObjectData{
String textStr;
String buttonStr;
boolean isBtn; //ボタンを表示するかどうか
public ObjectData(String textStr, String buttonStr, boolean isBtn){
this.textStr = textStr;
this.buttonStr = buttonStr;
this.isBtn = isBtn;
}
}
class ViewHolder{
ViewFlipper flipper;
TextView textView;
Button button;
}
class SampleAdapter extends ArrayAdapter<ObjectData>{
private LayoutInflater inflater;
public SampleAdapter(Context context, List<ObjectData> objects){
super(context, 0, objects);
this.inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
@Override
public View getView(int position, View convertView, ViewGroup parent){
ViewHolder holder;
if(convertView == null){
convertView = inflater.inflate(R.layout.object, parent, false);
holder = new ViewHolder();
holder.flipper = (ViewFlipper)convertView.findViewById(R.id.flipper);
holder.textView = (TextView)convertView.findViewById(R.id.text_view);
holder.button = (Button)convertView.findViewById(R.id.button);
convertView.setTag(holder);
}else{
holder = (ViewHolder)convertView.getTag();
}
ObjectData data = getItem(position);
if(data.isBtn){
//ボタンなら
holder.button.setText(data.buttonStr);
holder.flipper.setDisplayedChild(1); //2ページ目を表示
}else{
//テキストビューなら
holder.textView.setText(data.textStr);
holder.flipper.setDisplayedChild(0); //1ページ目を表示
}
return convertView;
}
}
</pre>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi6MRkE3jqsD0O3wqj0ZgZn3tY3DSXTj7DjZblwsHuvMLMuKuDNQMrGfkbX9MOoAD3tDDUr3ZYS8SgPXQWrPWgZKcJhoaQ50nmzZHoKqOPzskqrzK-7wlXK3PVhTQMSicyLh3B9zLJp_2A/s1600/device-2012-04-30-143928.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="320" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi6MRkE3jqsD0O3wqj0ZgZn3tY3DSXTj7DjZblwsHuvMLMuKuDNQMrGfkbX9MOoAD3tDDUr3ZYS8SgPXQWrPWgZKcJhoaQ50nmzZHoKqOPzskqrzK-7wlXK3PVhTQMSicyLh3B9zLJp_2A/s320/device-2012-04-30-143928.png" width="180" /></a></div>
<br />
ViewHolderの切り替え自体はViewHolder#showNext()やViewHolder#showPrevious()でやることが多いけど、今回の場合それでやると表示がうまくいかなかったのでViewHolder#setDisplayChild()を使った。<br />
今回の場合、ViewFlipperなので、動的に要素の高さを変更することはできない。できたらなかなかすごいけど何かいい方法があるのかな?<br />
<br />gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-50821233333234980812012-02-23T00:27:00.000+09:002012-02-23T00:27:35.386+09:00Windows7でGitのインストールWindows7でのGitのインストール方法のメモ<br />
<br />
<br />
Gitはソースコードのバージョン管理システムの一つ。ほかにも有名なものでSubversionとかCVSとかあるけど、いまからやるならGit一択っぽい感じ。<br />
<br />
<br />
そして、Windows7の環境でGit環境を構築する正式な方法はCygwinを使う方法なんだけど、自分を含めて初心者には敷居が高いっぽい。<br />
<br />
<br />
手軽にやる方法として、「msysgit」ってのがあるのでそちらを使ってGit環境を構築する。<br />
<br />
<br />
まずはインストーラをダウンロードする。<br />
<br />
<br />
<a href="http://code.google.com/p/msysgit/">ここ</a>から「Downloads」ページへジャンプし、「Git-1.7.9-preview20120201.exe」をダウンロード。<br />
<br />
<br />
インストールウィザードに従って進めていく。<br />
<br />
<br />
途中の「Adjusting your PATH environment」画面で、<br />
<br />
<br />
<div class="separator" style="clear: both; text-align: center;"></div><div class="separator" style="clear: both; text-align: center;"></div><br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjqTTweJvyehZeZdeuTFjFe53w75qZG0dsG_rWqLeMMWzZ3qzVmK4r6KN-IdELj2a8YOLo9gW7quLS8vAH2r6WpA0Nml11dsRDmpKdnS15rI7HgRK6wmzcg0yI3oXtCmMMc-nUo6nQUSac/s1600/%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB%E7%94%BB%E9%9D%A21.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="250" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjqTTweJvyehZeZdeuTFjFe53w75qZG0dsG_rWqLeMMWzZ3qzVmK4r6KN-IdELj2a8YOLo9gW7quLS8vAH2r6WpA0Nml11dsRDmpKdnS15rI7HgRK6wmzcg0yI3oXtCmMMc-nUo6nQUSac/s320/%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB%E7%94%BB%E9%9D%A21.png" width="320" /></a></div><br />
<br />
「Run Git from the Windows Command Prompt」を選択。<br />
<br />
<br />
次の「Configuring the line ending conversions」はデフォルトのままでOK。<br />
<br />
<br />
でインストールが終わる。<br />
<br />
<br />
正しくインストールできたかどうかはコマンドプロンプトで<br />
<br />
<br />
git --version<br />
<br />
<br />
と打ち込んで確認できます。<br />
<br />
<br />
次のような画面がでれば成功です。<br />
<br />
<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjKbXQRZjmrLdyaBZ__NFDlaUpxrXjY4THOhs1YlBRegU1v44LGWVGyQfPNk1Yg3jPQae1ixaCIj67i3klfvdngKkRX7QrojEWraEQtDyurHyth9HrO7wBBN0U1NwoZPxwhOsjlUEfoKGY/s1600/%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB%E7%94%BB%E9%9D%A23.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="233" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjKbXQRZjmrLdyaBZ__NFDlaUpxrXjY4THOhs1YlBRegU1v44LGWVGyQfPNk1Yg3jPQae1ixaCIj67i3klfvdngKkRX7QrojEWraEQtDyurHyth9HrO7wBBN0U1NwoZPxwhOsjlUEfoKGY/s320/%E3%82%A4%E3%83%B3%E3%82%B9%E3%83%88%E3%83%BC%E3%83%AB%E7%94%BB%E9%9D%A23.png" width="320" /></a></div>gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-66411004232514568692012-02-07T01:21:00.000+09:002012-02-07T01:21:10.568+09:00学生スタートアップカンファレンスに参加してきた今日参加してきたのはコレ→http://atnd.org/events/24340<br />
学生スタートアップカンファレンス<br />
<br />
ハッシュタグは#gakucon<br />
<br />
学生で起業してる人たちが自分たちの事業紹介して色々質問も受けますよってやつ。<br />
<br />
全部じゃないけどメモれた分だけ書いてみます。<br />
<br />
今日発表してたのはfacematch、Creatty、hhhungry、ヒルカツ、tetolの5つ。<br />
<br />
【facematch】<br />
facebookの情報持ってきて、異性との出会いを手助けするアプリ。<br />
例えばユーザが男性なら、友達の友達の女の子とかどっかのイベントに参加してた女の子がアプリに表示されて、プロフィールなどが見られる。<br />
プロフィール見て気に入った女の子がいたらハートボタンを押す。<br />
押された女の子の方では、ユーザを含む9人の男性が画面に表示されて、この中の誰かがあなたの事を気になっています。って表示されるらしい。<br />
それで、女の子がその中から選んだりして、両思いになれたら、その二人だけで使えるクーポンが発行されるらしい。<br />
<br />
で、今はコアメンバー4人とインターン16人で活動中で人材募集中のようです。<br />
<br />
求めてる人材は<br />
・自分たちのビジョンに共感できる人<br />
・私たちと一緒に働きたいと思える人<br />
・私たちの持っていない何かの高い能力を持っている事<br />
らしいです。<br />
<br />
人と人とのつながりを濃くしていきたいって言ってました。<br />
日本でのリリースは3月予定。<br />
<br />
<br />
【Creatty】<br />
物を作っている人向けのサービス<br />
クリエイターや美大生なんかで物を作っている人がweb上でサイトやギャラリーを簡単に持てるようにするサービス。<br />
そしてそれらを欲しい人が購入できるようにするらしい。<br />
作る人にとっては、自分の作品をより多くの人に見てもらえたりするし、見る人にとっては世界に1つしかない作品のカタログを見る事ができると。<br />
マネタイズはプレミアム課金、売買手数料、企業タイアップでやっていくらしい。<br />
<br />
ベータ版を2月に公開予定<br />
<br />
サーバー/フロントサイド/iOS/Androidなどのエンジニアを募集してた。<br />
<br />
<br />
【hhhungry】<br />
食事行くときのめんどくささを解決するサービス。<br />
今おなかが減っている近くにいる友達が表示されて、簡単にさそって一緒にご飯に行く事ができるサービス。<br />
今開催されているランチを友達の人は見る事ができて、そこに合流したければ簡単にできるよってのも言ってた。<br />
<br />
おなかが減ってるとかどうやって調べるのとか色々疑問あったし、あまり流行りそうではないなって印象を発表を見て思った。<br />
<br />
<br />
【ヒルカツ】<br />
昼食の時間を使ってOBOG訪問できるサービス。<br />
学生は友人とペアを組んで、志望している業界の人とかとマッチングしてくれる。<br />
新しいタイプの就職活動と言っていた。<br />
<br />
ただもうソーシャルランチとかのサービスがあるから、正直厳しいんじゃないかなって思った。もしかしたらヒルカツ側でのすごい差別点とかあるのかもしれないけど。<br />
<br />
あと、発表が残念すぎた。笑いをとろうとしてやってたけどそこまで笑いとれてなかったし、無駄な内容に時間を割きすぎてた。最終的には来てる視聴者の方に振りだしたりでひどい印象をうけた。<br />
<br />
<br />
【tetol】<br />
GPSとスマートフォンを利用したソーシャル助け合いプラットフォーム<br />
スマートフォンのアプリから依頼内容と報酬と期限をGooglemapに投稿して、近くのユーザがそれを見て、依頼を受けたりできるサービス。<br />
大学などの場合は「代返願い」や、「ノートコピーさせて」などで、それに対して報酬500円など。(紹介の例としてどうなのと思ったが。)<br />
労働力のCtoCと言っていた。(BtoCはタウンワークみたいなバイト紹介システム)<br />
収益は手数料や、フリーミアム、広告料でと言っていた。<br />
2月末にクローズドβ版を公開予定。<br />
発表者が「日本を変えるのは学生」って言ってた。今日一番印象に残ってる。<br />
<br />
〜最後に〜<br />
自分と同じぐらいの学生がこうやってベンチャーキャピタルからお金をもらって事業を起こしてるのはやっぱりすごい。<br />
そんなにうまくいかないんじゃないかと思ったのもあったけど、何かのサービスを考えだしてそれに全力で取り組んでるってところはなかなかできるものじゃない。<br />
彼らの方が行動力も技術力も格段に上なんだろうと感じた。自分はまだまだ。<br />
よりいっそうの努力が必要だなと感じたので、勉強と開発頑張っていく。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com2tag:blogger.com,1999:blog-3034960118667815461.post-59515697504048080282012-01-19T00:53:00.000+09:002012-01-19T00:53:12.780+09:00進路について大学もそろそろ卒業となり、進路についてずっと悩んでましたが、やっと自分なりの答えを出したので、ここにまとめておこうと思います。<br />
大学4回生のときに、経済的な理由から大学を退学になりました。<br />
ここから一年間、実家に戻って親の仕事を手伝いながら、Androidアプリの開発の勉強を始めました。そして2011年1月に初めてアプリを公開し、その後もいくつかアプリを開発しマーケットに公開してきました。<br />
そんな中、大学へ復学するための資金をなんとか準備する事ができ、2011年の9月に大学へ復学する事ができました。<br />
しかし、就職活動を全くしてなかったので、何となく自分はこのまま大学院へ行くのがベストなのかなと思っていました。大学院へ進めば一年後に問題なく就職活動ができるので。<br />
ただ、最近いろんな本を読んだり、twitterなどでいろんなツイートを見て、「働く」ってなんなんだろうなって感じてました。<br />
日本の会社でのプログラマーってのは降りてきた仕様通りにプログラムするのがお仕事で、だんだん出世していくとSEやマネージャーになってどんどんプログラムを書く事から離れていくイメージを持っています。<br />
会社に属してプログラムを書いていくのは正直楽しくなさそう。<br />
そんなふうに色々考えていく中で、自分の中で「働く」ってことは、「誰かの役に立つ」「価値を生み出す」これが大切なんじゃないかなと。<br />
こう思ってから、必ずどこかに就職しなきゃいけないって思いが無くなりました。<br />
なので、研究して知識を深めたいってのが3割、就活のためってのが7割だった大学院の進学も考え直そうと思いました。<br />
復学してから約半年、卒業研究をやってきて、研究というスタイルは自分に合っていなかった。これを後2年も続けるのはあまり意味を見いだせないし面白くないなと。なにより今はアプリ事業にもっと専念したいなと思っていました。<br />
なので卒業後はアプリ事業に専念しつつ、技術力の向上を目指していきます。<br />
一人でやってるとなにかと病みそうなので、勉強会に参加して様々な人に会って刺激もらいつつやっていきたいなと思っています。<br />
「誰かの役に立つ」「価値を生み出す」そんなアプリやサービスを創り出していきたい。<br />
しばらくは関東方面で活動していこうと思っていますので、関東方面にいらっしゃる方はよろしくお願いします。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com0tag:blogger.com,1999:blog-3034960118667815461.post-74286038366532396732011-07-18T23:23:00.000+09:002011-07-18T23:23:17.947+09:00Androidの広告をまとめてみた最近Androidもどんどんユーザー数が増えていき、アプリ開発者にとってはそれなりに広告収入を得ている人もいると思います。<br />
<br />
これから広告を載せてみたいけど、どれを使えばいいのかわからない。とか、他の広告に乗り換えてみようかなってデベロッパーの為に、いろんな広告会社を簡単にまとめてみようと思います。<br />
<br />
<br />
自分が使ったことのある、または組み込んだことのある広告会社のみです。<br />
また、私のアプリが日本専用アプリなので、海外での効果はわかりません。<br />
<br />
まとめるのは、<br />
<a href="http://jp.admob.com/">「AdMob」</a><br />
<a href="http://jp.ad-maker.net/">「AdMaker」</a><br />
<a href="http://www.adlantis.jp/">「AdLantis」</a><br />
<a href="https://admin.adsta.jp/">「AD-STA」</a><br />
<a href="http://iphone.trafficgate.net/">「TG-Ad」</a><br />
<a href="http://rinad.jp/smartphone/">「Rin」</a><br />
の6つです。<br />
<br />
<b>AdMob</b><br />
<br />
メリット<br />
・google adsenseの広告も配信しているので表示される広告の種類が多い。<br />
・アプリのメインカラーに合わせて広告の背景色の変更が可能。<br />
・管理画面が見やすく、カテゴリごとにフィルタをかけられる。<br />
デメリット<br />
・手数料がかかる電信送金かpaypalでの支払いしかない。<br />
・eCPMの変化が激しい(2011/7でeCPMが2.78→0.57へ)<br />
<br />
スマートフォンの広告といえばこれが一番有名かと思われます。<br />
ただ広告のインプレッション数は広告表示依頼数が高くなればなるほど多くなるようで、あまり依頼数が多くないアプリでは広告の表示回数が少なくなる傾向があるようです。<br />
<br />
<b>AdMaker</b><br />
<br />
メリット<br />
・高い広告単価(ちょっと前まで9.3円で固定。現在は7~9.3円ぐらい)<br />
・medibaとの提携で広告の種類が多い。(バナー広告も豊富)<br />
・銀行口座に直接振り込み<br />
デメリット<br />
・レポート画面や広告配信システムで不具合が多い。<br />
・人の審査が入るので、広告配信の許可が降りるまで時間がかかる。<br />
<br />
ほぼ100パーセントのインプレッション率を誇るアドネットワーク。<br />
広告の表示も速く、単価が高いので有名です。請求書などをこちらで発行しなくても、銀行に振り込んでくれる手軽さが良いです。<br />
<br />
<b>AdLantis</b><br />
<br />
メリット<br />
・高い広告単価(ちょっと前まで7.5円で固定だったかが、現在は7.5~15円ぐらい)<br />
デメリット<br />
・広告収益の請求方法がHPに掲載されておらず、メールでのお知らせ。<br />
・請求書を発送しないと収益が振り込まれない。<br />
<br />
広告配信システムなどではAdMakerといい勝負をします。ただ、請求方法に難ありです。メールで「請求書を発送していただいた翌月末支払い、発送されなかった場合は翌々月末支払い」とあり、請求書を送っていないので、翌々月末支払いされるかどうか待っている段階です。<br />
個人的にはAdMakerと比べて、請求書を作成して送るのが非常にめんどくさいです。<br />
<br />
ここからは組み込んでみたものの、公開までいたらなかったものです。<br />
<br />
<b>AD-STA</b><br />
<br />
メリット<br />
・どんな広告が表示されるのか管理画面で見ることができる。<br />
・広告ごとに配信の可否が設定可能。<br />
デメリット<br />
・広告表示までが少し遅め。<br />
・広告の種類が他と比べて少ない(2011/7/18現在、広告主はmobageのみ)<br />
<br />
広告掲載依頼があったアドネットワーク。<br />
まだ一般には公開されていないようで、まだまだ様子見の段階です。<br />
一般に公開されるようになり、広告の種類が増えてきたら化けるかも。<br />
<br />
<b>TG-Ad</b><br />
<br />
メリット<br />
・唯一のインプレッション毎に広告単価が発生するアドネットワーク。<br />
デメリット<br />
・審査が多い<br />
<br />
このアドネットワークはアプリを登録するときに審査。<br />
アプリに広告配信システムを組み込んでからまた審査。<br />
と、とにかく審査が多く、公開に踏み切れませんでした。<br />
もし、TG-Ad使っている方がいたら、どんなかんじなのか教えていただきたいです。<br />
<br />
<b>Rin</b><br />
<br />
メリット<br />
・興味関心連動型広告(らしいです。)<br />
デメリット<br />
・テキスト広告しかない。<br />
・定期的に広告を更新し、その際にアプリの処理が0.5~1秒とまる。<br />
・2011/7/18現在、美容液の広告一つだけ。<br />
<br />
ホームページがかっこよく、興味関心連動型広告ということで期待していたアドネットワーク。<br />
今の段階では、まったく使えません。<br />
自動的に広告の更新が行われ、その際の処理がUIスレッドで行われるようで、アプリが一瞬止まります。<br />
この仕様が改善され、広告の種類が増えれば使えるようにはなるかも。<br />
<br />
<br />
以上、自分が使ってみた経験を参考にまとめてみました。<br />
<br />
<br />
<br />
国内限定で考えると、私が現時点でお勧めするのは<b>AdMaker</b>です。<br />
いろいろ不具合も多いですが、問い合わせをすれば、今のところ丁寧に対応してもらっています。<br />
不具合が発生しないように改善してもらうのが一番なんですが。<br />
あと、特にこちらからのアクションなしで自動的に銀行の口座に振り込んでもらえるのが非常に楽です。<br />
<br />
最近出てきた、AD-STAとRinには結構期待しています。<br />
これから広告の種類が増加し、安定してきたら試してみようと思います。<br />
<br />
このまとめが、どこかの誰かの役に立てば幸いです。<br />
<br />gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com2tag:blogger.com,1999:blog-3034960118667815461.post-49023115395820063142011-06-15T19:10:00.000+09:002011-06-15T19:10:19.436+09:00顔文字入力補助「顔文字入力補助」専用のページです。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgvn1a6iYA0TD7PEFwZL0jR-fPtZJAFIFAt6sc0jBdoON5sqN3njOdQ97mRKiG-hsRHw1ohsVshTkLErdxUFkWZh7DC7F-QY74Yu3pI1a4rL80QDKL2iIt_Dl70b26OSaB50Ia-j3bXSGY/s1600/icon.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="200" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgvn1a6iYA0TD7PEFwZL0jR-fPtZJAFIFAt6sc0jBdoON5sqN3njOdQ97mRKiG-hsRHw1ohsVshTkLErdxUFkWZh7DC7F-QY74Yu3pI1a4rL80QDKL2iIt_Dl70b26OSaB50Ia-j3bXSGY/s200/icon.png" width="200" /></a></div><br />
「顔文字入力補助」は顔文字を簡単に入力することができるマッシュルームアプリです。<br />
<br />
質問や要望などはお気軽にコメントへお願いします。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com16tag:blogger.com,1999:blog-3034960118667815461.post-31823984490939615772011-06-02T19:41:00.003+09:002011-07-03T09:38:22.937+09:00マッシュルーム機能の使い方このページは、開発アプリ「MixiEmojiInputHelper」「DocomoEmojiInputHelper」「MobageEmojiInputHelper」「GreeEmojiInputHelper」用のマッシュルーム機能の使い方の解説ページです。<br />
<br />
<br />
【マッシュルーム機能を使うために】<br />
以下のマッシュルーム機能が使えるアプリのインストールが必要です。<br />
※スマートフォンでのみアクセスできます。<br />
「<a href="market://details?id=com.justsystems.atokmobile.tv.service">ATOKトライアル</a>」<br />
「<a href="market://details?id=com.adamrocker.android.input.simeji">Simeji</a>」<br />
「<a href="market://details?id=com.pm9.flickwnn">OpenWnnフリック入力対応版</a>」<br />
自分にあった好きなものを選んでダウンロードしてください。リンクが張ってあるので直接マーケットからダウンロードできます。(ATOKトライアルは15日間限定の試用版です)<br />
<br />
<br />
【ダウンロードしたアプリを使用できるようにする】<br />
「設定」→「言語とキーボード」で次のような画面が表示されるので、赤枠のところにチェックを入れる。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiPJJUtA0Kd0VjMLPtUATNJW8lYFY0JNgIUO5fI-uCWbCnL9Dsz1sbt1Wu4kWoAIEY54o1EH85GP7YGypm058_pXxGA1ZUdlVQT6dpwMGWHu46sQ4AAeSi3xdh7mnG9yg_xjNA6MWmKgg8/s1600/%25E3%2582%25AD%25E3%2583%25BC%25E3%2583%259C%25E3%2583%25BC%25E3%2583%2589%25E3%2581%25AE%25E3%2583%2581%25E3%2582%25A7%25E3%2583%2583%25E3%2582%25AF%25E3%2582%2592%25E5%2585%25A5%25E3%2582%258C%25E3%2582%258B.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiPJJUtA0Kd0VjMLPtUATNJW8lYFY0JNgIUO5fI-uCWbCnL9Dsz1sbt1Wu4kWoAIEY54o1EH85GP7YGypm058_pXxGA1ZUdlVQT6dpwMGWHu46sQ4AAeSi3xdh7mnG9yg_xjNA6MWmKgg8/s400/%25E3%2582%25AD%25E3%2583%25BC%25E3%2583%259C%25E3%2583%25BC%25E3%2583%2589%25E3%2581%25AE%25E3%2583%2581%25E3%2582%25A7%25E3%2583%2583%25E3%2582%25AF%25E3%2582%2592%25E5%2585%25A5%25E3%2582%258C%25E3%2582%258B.png" width="223" /></a></div><br />
次にどこでもよいので適当な文字入力画面(検索キーワード入力欄やメールの本文入力画面など)で、入力欄を長押しします。<br />
すると次のようなダイアログが出るので、「入力方法」を選択します。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgnjb9iFxX3_BycCs2JcZrJfGUOQ5W7S8sujlB2RuT9GxKxx-6UzIxdb5MFF3XuhidJCpN6Y7ZgTvpsCtA-rCkhrbxWpg6rtC2A_Bxm2_acsKNCum-GrVtCVjzy64re4CxXIvyvpRBiPxY/s1600/%25E5%2585%25A5%25E5%258A%259B%25E6%2596%25B9%25E6%25B3%2595%25E3%2581%25AE%25E5%2588%2587%25E3%2582%258A%25E6%259B%25BF%25E3%2581%2588.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgnjb9iFxX3_BycCs2JcZrJfGUOQ5W7S8sujlB2RuT9GxKxx-6UzIxdb5MFF3XuhidJCpN6Y7ZgTvpsCtA-rCkhrbxWpg6rtC2A_Bxm2_acsKNCum-GrVtCVjzy64re4CxXIvyvpRBiPxY/s400/%25E5%2585%25A5%25E5%258A%259B%25E6%2596%25B9%25E6%25B3%2595%25E3%2581%25AE%25E5%2588%2587%25E3%2582%258A%25E6%259B%25BF%25E3%2581%2588.png" width="223" /></a></div><br />
いろんな入力方法が一覧で表示されるので、先程ダウンロードしたアプリを選択します。<br />
<br />
【マッシュルームの起動】<br />
「ATOKの場合」<br />
左下の赤枠部分を長押しします。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgnp8eWjPRLm8_NJE3-MyIGsNNhfWtzRA4ZMrnWgkdwk47_TBxZcK7-MSlQb6ukfnWqVMGIo8clDqu_zZ1aqfQt0zUFtj-fU1w8eGeWgdLEsq-JDGjsIzVSWst6MrLDHanzE0OWbpWCEkg/s1600/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2591.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgnp8eWjPRLm8_NJE3-MyIGsNNhfWtzRA4ZMrnWgkdwk47_TBxZcK7-MSlQb6ukfnWqVMGIo8clDqu_zZ1aqfQt0zUFtj-fU1w8eGeWgdLEsq-JDGjsIzVSWst6MrLDHanzE0OWbpWCEkg/s400/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2591.png" width="223" /></a></div><br />
以下のような画面になるので、長押ししたままマッシュルームマークまで指を移動させます。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh-CCRGl2J9tARA_8xpj3gUqYlSgFN5kbABX2CpQN7DK0EAHhCqiU92nIo6ZiZyEWMl2liGAWK8NP8_55an7Nv9gYntrGBs37gICaVx4R03ezXA7vXyIxZ4SeD_pkwbFIed7nDonbuylYc/s1600/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2592.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh-CCRGl2J9tARA_8xpj3gUqYlSgFN5kbABX2CpQN7DK0EAHhCqiU92nIo6ZiZyEWMl2liGAWK8NP8_55an7Nv9gYntrGBs37gICaVx4R03ezXA7vXyIxZ4SeD_pkwbFIed7nDonbuylYc/s400/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2592.png" width="223" /></a></div><br />
マッシュルームマークの上で指を離すと、マッシュルームに対応したアプリが一覧で表示されます。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhYDXUmyOX5QvzKhz_WAOap4MZ8BwMtZ3sQlsla-Yid2IDY2oaZ1HErve5QpLRo8_bgMJHrrBcFfwl908ZG_tbtWgnIP1fL3NQRok1yUfije5m7UIM2f2naqhP8wKfz6aQEqiWJEd3r-Cg/s1600/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2593.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhYDXUmyOX5QvzKhz_WAOap4MZ8BwMtZ3sQlsla-Yid2IDY2oaZ1HErve5QpLRo8_bgMJHrrBcFfwl908ZG_tbtWgnIP1fL3NQRok1yUfije5m7UIM2f2naqhP8wKfz6aQEqiWJEd3r-Cg/s400/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2593.png" width="223" /></a></div><br />
ここでは「MixiEmojiInputHelper」を起動してみます。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhyAxOKzHA19g76kg2hVSJokUvAjeeIVYKBLKyms-gj8341iySFQfLLY0MHagUVaaG6hi9Ljb9_SOq8PAKHPUVPpaIXTegJ2EOf6wKof-LaGEZ0jiDLeD7RmRK8DrO1cXUF-VaTidr9lVw/s1600/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2594.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhyAxOKzHA19g76kg2hVSJokUvAjeeIVYKBLKyms-gj8341iySFQfLLY0MHagUVaaG6hi9Ljb9_SOq8PAKHPUVPpaIXTegJ2EOf6wKof-LaGEZ0jiDLeD7RmRK8DrO1cXUF-VaTidr9lVw/s400/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2594.png" width="223" /></a></div><br />
入力したい絵文字を選んで、入力決定ボタンを押せば、絵文字コードまたは絵文字が入力されます。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEivxtYk2TT4qXr4XbnOOantjmiPgBkSqx9XhSAGhXpIv3Ytt6UgNkDVvVDTHq_OQdpbUhI7AfmTQGh2POnEeZPMj2aqkTK3KiXTwWfgG1qCi3K5lUqglLFv-3nRADEG6IJHU4_b0Oc4Uyw/s1600/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2595.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEivxtYk2TT4qXr4XbnOOantjmiPgBkSqx9XhSAGhXpIv3Ytt6UgNkDVvVDTHq_OQdpbUhI7AfmTQGh2POnEeZPMj2aqkTK3KiXTwWfgG1qCi3K5lUqglLFv-3nRADEG6IJHU4_b0Oc4Uyw/s400/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2595.png" width="223" /></a></div><br />
ATOKの場合、一度起動したマッシュルームアプリは次からショットカットが利用できます。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi45ycb9KzpM_8AUBhKm8jecFgHQgofC3iJ63vN9xCKJMoThIvgXArxvOUILnyO3-GmbhblRUE3efKIXHOc3wt4kT0uAk9QmigxNqwNOV3CVMvOIOgNILKZ5IZfBBSOBZvtlBm0p7w5y0g/s1600/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2596.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi45ycb9KzpM_8AUBhKm8jecFgHQgofC3iJ63vN9xCKJMoThIvgXArxvOUILnyO3-GmbhblRUE3efKIXHOc3wt4kT0uAk9QmigxNqwNOV3CVMvOIOgNILKZ5IZfBBSOBZvtlBm0p7w5y0g/s400/ATOK%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0%25EF%25BC%2596.png" width="223" /></a></div><br />
「Simejiの場合」<br />
ソフトウェアキーボードの左上にマッシュルームアイコンがあるのでそこを長押しします。<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhCeQcE8dk2grw3-H-6xowsdR6m6MKWpDaosTNDA09DUWXDkqvvmfgQXE4OFna0LitHurWkR9_U748PJtwotJX78GLlEN2sWVABdFBje2foH82pSRFOFsFTplOoNuRiam5FLsjfsSYIoQ0/s1600/Simeji%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhCeQcE8dk2grw3-H-6xowsdR6m6MKWpDaosTNDA09DUWXDkqvvmfgQXE4OFna0LitHurWkR9_U748PJtwotJX78GLlEN2sWVABdFBje2foH82pSRFOFsFTplOoNuRiam5FLsjfsSYIoQ0/s400/Simeji%25E3%2583%259E%25E3%2583%2583%25E3%2582%25B7%25E3%2583%25A5%25E3%2583%25AB%25E3%2583%25BC%25E3%2583%25A0.png" width="223" /></a></div><br />
後の使い方はATOKとほぼ同じです。<br />
<br />
以上でマッシュルーム機能の使い方についての解説は終わりです。<br />
<br />
最後に、開発したマッシュルームアプリのリンクを貼っておきます。<br />
※スマートフォンでのみアクセスできます。<br />
「<a href="market://details?id=com.hideo.android.mixiemojiinputhelper">MixiEmojiInputHelper</a>」<br />
「<a href="market://details?id=com.hideo.android.docomoemojiinputhelper">DocomoEmojiInputHelper</a>」<br />
「<a href="market://details?id=com.hideo.android.mobageemojiinputhelper">MobageEmojiInputHelper</a>」<br />
「<a href="market://details?id=com.hideo.android.greeemojiinputhelper">GreeEmojiInputHelper</a>」gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com251tag:blogger.com,1999:blog-3034960118667815461.post-57691442338229234982011-06-01T13:33:00.000+09:002011-06-01T13:33:00.826+09:00Androidアプリの名前の重要性少し前にどっかで見かけたが、アプリのダウンロードにはアプリ名とアイコンが重要といった事が書かれていた記憶がある。<br />
<br />
<br />
最近ちょっとDL数が落ち着いてきてたので実験的にアプリ名を変更してみた。<br />
<br />
<br />
アイコンは良い改良案がすぐには見つからなかったので、とりあえずアプリ名だけ。<br />
<br />
<br />
結論としては、アプリ名の変更は<span class="Apple-style-span" style="color: red;">効果的</span>だった。<br />
<br />
<br />
今回、実験に使用したアプリは2つ。(名前変更は4つ行ったが、内2つは総DL数が少なく、アプリ名だけの影響と断定できなかったので除外)<br />
<br />
<br />
1つ目<br />
「MixiEmojiInputHelper」→「mixi絵文字入力補助」<br />
アプリの詳細は<a href="https://market.android.com/details?id=com.hideo.android.mixiemojiinputhelper">こちら</a>から。<br />
<br />
デベロッパーコンソールの統計のキャプチャ画像<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgxyArBbKX5pUzJ5_OHfcedghaBnzUURi-91IcOyVg1FekqVqT6KqSt7B1NBEv-Vh1cfqValUCLQth3b9HkSYZ81wwmHcs1QmM3ltEIslH27HwQGidZlHIHCYaqFVf6Gq-XN28Iwxx13mw/s1600/MixiEmojiInputHelperDL%25E6%258E%25A8%25E7%25A7%25BB.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="155" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgxyArBbKX5pUzJ5_OHfcedghaBnzUURi-91IcOyVg1FekqVqT6KqSt7B1NBEv-Vh1cfqValUCLQth3b9HkSYZ81wwmHcs1QmM3ltEIslH27HwQGidZlHIHCYaqFVf6Gq-XN28Iwxx13mw/s400/MixiEmojiInputHelperDL%25E6%258E%25A8%25E7%25A7%25BB.png" width="400" /></a></div><br />
赤い線のところでアプリ名を変更。<br />
<br />
2つ目<br />
「DocomoEmojiInputHelper」→「docomo絵文字入力補助」<br />
アプリの詳細は<a href="https://market.android.com/details?id=com.hideo.android.docomoemojiinputhelper">こちら</a>から。<br />
<br />
デベロッパーコンソールの統計のキャプチャ画像<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi0Bk2UwH-4JX4-m_HTrUjadYfa78MXKGH_EAEXz9JwpfrUm7Fwsl4Uoya66efKbuYGY4vZC2J5SoQq5aZBeyNVlOPNIYOcyZ-afY0HOB6xzgSQKFmndY4bb0H51kQdTqmnMAVbm4AmcYs/s1600/DocomoEmojiInputHelperDL%25E6%258E%25A8%25E7%25A7%25BB.bmp" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="155" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi0Bk2UwH-4JX4-m_HTrUjadYfa78MXKGH_EAEXz9JwpfrUm7Fwsl4Uoya66efKbuYGY4vZC2J5SoQq5aZBeyNVlOPNIYOcyZ-afY0HOB6xzgSQKFmndY4bb0H51kQdTqmnMAVbm4AmcYs/s400/DocomoEmojiInputHelperDL%25E6%258E%25A8%25E7%25A7%25BB.bmp" width="400" /></a></div><br />
赤い線のところでアプリ名を変更。<br />
<br />
<br />
画像を見てもらえば、赤い線の前後でグラフの傾きが大きくなっていることが分かる。<br />
<br />
<br />
他のアプリでは同様の変化が見られなかったので、アプリ名の変更が直接的な要因だと考えられる。<br />
<br />
<br />
今回のアプリ名の変更は、どんなアプリなのか分かりやすくすることを心がけた。<br />
<br />
<br />
やはり、まだユーザーはマーケットで検索してアプリを探している人が大半なんだと思う。<br />
<br />
<br />
いろんなところでアプリの記事を紹介してもらったことはあるけれど、そこまで大きくダウンロードに影響はしなかった。(<a href="http://androider.jp/">アンドロイダー</a>だけは影響が大きかった。)<br />
<br />
<br />
なので、アプリ名はダウンロード数を増やすために結構重要な要素だなと分かった。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com4tag:blogger.com,1999:blog-3034960118667815461.post-26328242420089040952011-05-25T19:33:00.000+09:002011-05-25T19:33:32.309+09:00システム手帳アプリ「ジョルテ」のスケジュールが急に消えたときの対処Androidのスケジュール管理アプリとして一番人気あるのが「ジョルテ」<br />
Googleカレンダーとの同期機能があるのですごく便利です。<br />
まだダウンロードしていない方は<a href="https://market.android.com/details?id=jp.co.johospace.jorte">こちら</a>からダウンロードできます。<br />
<br />
最近、登録していたスケジュールが全て見れなくなってしまいました。<br />
なぜだろうかと、アプリの再インストールもしてみたけど全然ダメでした。<br />
<br />
PCでGoogleカレンダーを見ると、ちゃんとスケジュールが残ってる。<br />
なので、問題があるのはAndroidの端末の方。<br />
<br />
いろいろ探した結果、解決できました。<br />
<br />
解決方法を残しておきます。<br />
<br />
ホーム画面から<br />
「設定」→「アプリケーション」→「アプリケーションの管理」を選択します。<br />
すると、インストールしているアプリの一覧が表示されます。<br />
ここで、「メニュー」→「フィルタ」を押すと以下の画面のようになります。<br />
<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMj9HG9eaiAnTWKc2knmRjQ805K5aFZ9s9EmdYrvYaV81arS_T07OZowJmHBgyBCGSFy1BLQqAhbDd2ZsEvUfxyIpBJLHhGb_HffdSokiO4bh-2uedSEbD7rYgFMnuNUSXCylL5cyLxbE/s1600/%25E3%2582%25B8%25E3%2583%25A7%25E3%2583%25AB%25E3%2583%2586%25E3%2581%25AE%25E3%2582%25B9%25E3%2582%25B1%25E3%2582%25B8%25E3%2583%25A5%25E3%2583%25BC%25E3%2583%25AB%25E5%25BE%25A9%25E5%25B8%25B0%25E6%2596%25B91.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiMj9HG9eaiAnTWKc2knmRjQ805K5aFZ9s9EmdYrvYaV81arS_T07OZowJmHBgyBCGSFy1BLQqAhbDd2ZsEvUfxyIpBJLHhGb_HffdSokiO4bh-2uedSEbD7rYgFMnuNUSXCylL5cyLxbE/s400/%25E3%2582%25B8%25E3%2583%25A7%25E3%2583%25AB%25E3%2583%2586%25E3%2581%25AE%25E3%2582%25B9%25E3%2582%25B1%25E3%2582%25B8%25E3%2583%25A5%25E3%2583%25BC%25E3%2583%25AB%25E5%25BE%25A9%25E5%25B8%25B0%25E6%2596%25B91.png" width="223" /></a></div><br />
通常は「ダウンロード済み」になっているので、ここを「すべて」に変更します。<br />
<br />
すると、端末内のすべてのアプリケーションが表示されます。<br />
ずーっと下のほうまでスクロールすると、「カレンダーの保存」というアプリケーションがあるのでそれをタップします。<br />
<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjJtFrdCF1KdQPh6GfrmeRUn-gEQb5BLYT-HTWWnzc-ta4HdsoyjupqBvV0wUEbeQ8jeZ-9H8LnRAt1f7zNZwZ7F1vrQleytOakWAA0RupQEBjT6zL65ZiYJsX7sSDrs_9GkdnCoaJEIuY/s1600/%25E3%2582%25B8%25E3%2583%25A7%25E3%2583%25AB%25E3%2583%2586%25E3%2581%25AE%25E3%2582%25B9%25E3%2582%25B1%25E3%2582%25B8%25E3%2583%25A5%25E3%2583%25BC%25E3%2583%25AB%25E5%25BE%25A9%25E5%25B8%25B0%25E6%2596%25B92.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjJtFrdCF1KdQPh6GfrmeRUn-gEQb5BLYT-HTWWnzc-ta4HdsoyjupqBvV0wUEbeQ8jeZ-9H8LnRAt1f7zNZwZ7F1vrQleytOakWAA0RupQEBjT6zL65ZiYJsX7sSDrs_9GkdnCoaJEIuY/s400/%25E3%2582%25B8%25E3%2583%25A7%25E3%2583%25AB%25E3%2583%2586%25E3%2581%25AE%25E3%2582%25B9%25E3%2582%25B1%25E3%2582%25B8%25E3%2583%25A5%25E3%2583%25BC%25E3%2583%25AB%25E5%25BE%25A9%25E5%25B8%25B0%25E6%2596%25B92.png" width="223" /></a></div><br />
<br />
ここで、「データの消去」をタップし、データを削除すればOKです。<br />
<br />
これで、ジョルテとGoogleカレンダーの同期が正常に戻ります。<br />
<br />
筆者の環境ではこの方法で、以前のように同期が取れるようになりました。gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com3tag:blogger.com,1999:blog-3034960118667815461.post-48934052820541527472011-05-24T09:18:00.002+09:002011-06-03T11:42:45.417+09:00GreeEmojiInputHelperGreeEmojiInputHelper専用のページです。<br />
<div><br />
</div><div class="separator" style="clear: both; text-align: center;"></div><div><div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjcXeJ_nh8xTQfnej4-9MN8h0hGrUXdMGQCQgXqVusRmPCgucsvLeNDt6629wlVoHmqKxxQwE_bk79YkkCBSloGXG3cIlejZ0H_TjUBzoRZn9eOUy24VyWzO20F3Eulg-0-bKFIhXZPbO8/s1600/greeemojiinputhelpericon120.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjcXeJ_nh8xTQfnej4-9MN8h0hGrUXdMGQCQgXqVusRmPCgucsvLeNDt6629wlVoHmqKxxQwE_bk79YkkCBSloGXG3cIlejZ0H_TjUBzoRZn9eOUy24VyWzO20F3Eulg-0-bKFIhXZPbO8/s1600/greeemojiinputhelpericon120.png" /></a></div><br />
</div><div>GreeEmojiInputHelperはGreeの絵文字を入力できるマッシュルームアプリケーションです。<br />
<br />
ダウンロードは<a href="https://market.android.com/details?id=com.hideo.android.greeemojiinputhelper">こちら</a>からどうぞ。<br />
<br />
質問や要望などはお気軽にコメントにお願いします。</div>gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com62tag:blogger.com,1999:blog-3034960118667815461.post-81292826078336817382011-05-11T18:51:00.001+09:002011-06-03T11:41:44.665+09:00MobageEmojiInputHelperこのページはMobageEmojiInputHelper専用のページです。<br />
<br />
<div class="separator" style="clear: both; text-align: center;"><a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj5Gvhjh2CHimLPocCUy0Hqrx4nWoeIm9auplhDx4B92H5q2xl_qY8embJyNj5imFNEe_MA6JqcGMVNLseQL-7mVScbtm93ravD7ggPIORkpB34ID4191ojW3dClMIFpMmqMqHt740T6wc/s1600/mobageemojiinputhelpericon.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEj5Gvhjh2CHimLPocCUy0Hqrx4nWoeIm9auplhDx4B92H5q2xl_qY8embJyNj5imFNEe_MA6JqcGMVNLseQL-7mVScbtm93ravD7ggPIORkpB34ID4191ojW3dClMIFpMmqMqHt740T6wc/s1600/mobageemojiinputhelpericon.png" /></a></div><div class="separator" style="clear: both; text-align: left;"><br />
</div><div class="separator" style="clear: both; text-align: left;">MobageEmojiInputHelperはMobage(モバゲー)の絵文字入力を補助するマッシュルームアプリケーションです。</div><div class="separator" style="clear: both; text-align: left;"><br />
</div><div class="separator" style="clear: both; text-align: left;">ダウンロードは<a href="https://market.android.com/details?id=com.hideo.android.mobageemojiinputhelper">こちら</a>からどうぞ。</div><div class="separator" style="clear: both; text-align: left;"><br />
</div><div class="separator" style="clear: both; text-align: left;">質問や要望などはお気軽にコメントにお願いします。</div>gari_jphttp://www.blogger.com/profile/10312466706733230557noreply@blogger.com105