前人未踏の領域へ アプリ開発編

Android, iOSアプリ開発に関する調査メモ置き場。ほとんどAndroid。はてなダイアリーから移行したため古い記事にはアプリ以外も含まれます。

Android

Root要素が配列なJSONのパース

課題 APIのレスポンスのJSONがいきなり無名の配列になっていてGsonでパースする方法がわからない。 [ {hoge:1, fuga:"aaa"}, {hoge:2 fuga:"bbb"}, {hoge:3, fuga:"ccc"}, {hoge:4 fuga:"ddd"} ] 対応 受け入れクラスとしてクラスの配列を定義する @GET("/ho…

FragmentのonAttach(Activity)がAPI Level 23 で deprecatedに

onAttach (Activity activity) がdeprecatedになった。 代わりに onAttach (Context context) を使えとのこと。 @Override public void onAttach(Context context) { super.onAttach(context);Activity以外が渡されるケースもあるのだろうか。ちなみにgetAct…

Android Support Library to v23でApache HTTP Client が削除されている

課題 Android Support Library to v23でorg.apache.httpパッケージが削除されてしまい、コンパイルエラーになる 対策 org.apache.http.client.HttpClientをはじめとするhttpClient系のクラスは以前からdeprecatedとなっていたが、Support Library v23でコー…

RecyclerViewのTouchイベント処理にはaddOnItemTouchListenerを使った方がいい。

setOnTouchListenerがあるのだけど、子ビューのイベント定義がしてあると発動しないか、遅れる。継承クラスを作ってInterceptTouchEventを拾う方法もあるが、この場合はACTION_UPが発生しない。 addOnItemTouchListenerならonInterceptTouchEventもonTouchEv…

Unable to bind views forをくらう

課題 ButterKnifeを使ってViewHolderのbindを行ったところ、RuntimeExceptionが発生した。 java.lang.RuntimeException: Unable to bind views for $パッケージ名 at butterknife.ButterKnife.bind(ButterKnife.java:322) at butterknife.ButterKnife.bind(B…

ScrollViewのスクロール位置の再現

注意 この記事は何らかの(失念)実装ミスをした際に発生した副作用に対する誤った解決策であり、 この処理が必要になるのは別なところに記述ミスがある可能性が高いと思う。 基本的に戻るボタンで戻った際にスクロール位置の再現が必要になることはないと思…

CoordinatorLayoutとViewPagerの共存

課題 あるViewの下にViewPagerがある。ViewPager内のリストをスクロールした際に、その上のViewもスクロールさせたい。 対策 CoordinatorLayoutとAppBarLayoutと合わせて使う。

SwipeRefreshLayoutソースコード読み

子View検出 子Viewがいるかどうかの判断。最初に見つかったものを対象にしている。 なので、SwipeRefreshLayoutの直接の子ビューは1つしか対象にできない、ということが分かる。 逆に、addViewやremoveViewは使えるのかも。 private void ensureTarget() { …

SwipeRefreshLayoutのsetRefreshingが表示されない

課題 SwipeRefreshLayoutを使っているが、初期表示のタイミングでsetRefreshing(true)としてもローディングアニメーションが表示されない。 対応 Message queueを使用して処理の実行タイミングを遅らせる。 private SwipeRefreshLayout mSwipeRefreshLayout;…

Dateformatのフォーマットキャラクタについて

Dateformatのフォーマットで利用できるキャラクタはバージョンにより異なる。 The format methods in this class implement a subset of Unicode UTS #35 patterns. The subset currently supported by this class includes the following format characters…

RecyclerViewにフッターを表示する

課題 RecyclerViewの追加読み込み時にフッターを表示したい。 対策 リストの最後尾にFooter用のオブジェクトを追加し、ViewTypeで判別して出し分け。追加データ取得時に削除する。エレガントな方法ではないけれど、とりあえず思いつく簡単な方法。 任意の型…

RecyclerViewにオートスクロール機能をつける

課題 RecyclerViewでもオートスクロールを実現したい 対策 RecyclerView#addOnScrollListenerとLinearLayoutManager#findLastVisibleItemPositionを組み合わせる。LinearLayoutManagerにはfindLastVisibleItemPositionという一部が見えている最後のアイテム…

ActionBarにロゴを表示する。

課題 AppCompatActivityに変更したところ、ActionBarに表示していたロゴが表示されなくなった。どうすればよいか。 対策 ActionBarに対してロゴ出力設定を有効化する。 ActionBar actionBar = ((AppCompatActivity) getActivity()).getSupportActionBar(); i…

SwipeRefreshLayoutとRecyclerViewを同時に使用すると挙動がおかしくなる場合の対策

課題 SwipeRefreshLayoutとRecyclerView, GridView, ListViewを同時に使用した際、リストの先頭まで戻らないうちにスワイプリフレッシュが実行されてしまう。 対策 参考のURLを元に制御する。 RecyclerView#setOnScrollListenerは既にDeprecatedとなっている…

Android Studioのメモリを設定する

課題 Android Studioのメモリが不足するため設定を変更したい。 対応 studio.vmoptions(またはidea.vmoptions)を指定のフォルダにセットする。 設定ファイルは~/Library/Preferences/ 配下にAndroidStudioのバージョンに応じて個別に置かれるのでアップデー…

ソフトウェアキーボードのアクションを設定する

課題 検索フォームにて、ソフトウェアキーボードの改行ボタンに相当する部分を検索アイコンにしたい。 対応 EditTextなどの属性でimeOptionsを使う android:imeOptions="actionSearch" 参考 imeOptions 一覧 http://developer.android.com/#imeOptions

AndroidのUIテストとJavaテストを分ける。

課題 AndroidのUIテストとJavaのテストを分けて記述したい。 対応 testとandroidTestをうまく使う。それぞれがごっちゃになってるといろいろうまく行かない。 BuildValiantsを切り替える テストの目的に応じて変更する。 View > Tool Windows > BuildValiant…

testCompileとandroidTestCompileの違い。

課題 Androidの公式サイトを読んでいるとtestCompileとandroidTestCompileというのが2つ出てくるが、その違いは何か。どう使い分ければいいのか。 回答 src/test 以下に記述した内容はtestCompileに影響する。 src/androidTestに記述した内容はandroidTestC…

junit.framework.AssertionFailedError: No tests found が発生する

環境 Android Studio 1.3 RC4 Android SDK Tools 24.3.3 Android Support Library 22.2.1 Google Play Services 25.0.0 課題 Android StudioでJUnit4によるテストを書いてみたが、@Testアノテーションをつけたにも関わらず、実行するとテストが見つからない…

Google Play Servicesのオープンソースのライセンス情報を取得する。

Google Mapをアプリで使用する場合など、ライセンスを明記する必要があるが、そのテキストをGoogleが提供してくれている。 String licenseInfo = GoogleApiAvailability.getInstance().getOpenSourceSoftwareLicenseInfo(); 参考 https://developers.google.…

レイアウト属性を使って画面開発を効率化する

Android Studioでレイアウト設定をする際、Viewerでプレビューができるが、Java側からテキストを挿入したい場合は、デフォルトではvisibilityがGONEになるケースなど、プレビューに適さないケースが出てくる。そんなときにtoolsを使う事で layout.xmlなどで…

onCreateOptionsMenuの実行タイミングについて

onCreateOptionsMenuの実行タイミングがAndroidのバージョンによって異なっていたのでメモ。イベントはFragmentのもの。 5.0 onResumeの後 4.1.1 onAttachの後 2.3.3 onAttachの後 どのバージョンで変わったかは不明。 後で調べる。

ネストしたFragmentのバックスタック時挙動について

実装方法によっては発生しないのかもしれないけれど、自分の開発状況下で発生している問題について。 結論 子フラグメントをバックスタックから復元することはできる。しかし色々変更しすぎてもはや何が決め手になったかよくわからず。以下は本結論に繋がら…

Android Studioのライブテンプレート

Android Studioのライブテンプレートを仕様すると短いコード数で自動的にそれにあったコードを自動生成してくれる。 最新版では以下のとおり。スクショで失礼。toolsNsが個人的には便利。 もちろん自分でも作れるのでプロジェクトでお約束のコードは独自の名…

Gridビューの周囲の枠線を非表示にする

課題 Android2.3系の話なので最新端末では関係なかったりするがGridViewをセットするとアイテムの周囲にスペース確保され、ヘッダーのような横一杯に表示したいようなフルサイズの画像などを貼ろうとするとずれる結果となる。 対応 listSelectorが指定されて…

RecyclerViewを使う

とりあえず一覧を表示するサンプル。 ポイント レイアウトの種類はLaytoutManagerで管理 ViewHolderの利用が前提になっている setOnItemClickListenerがRecyclerViewには存在しないので、RecyclerView.Adapter内のViewHolderのコンストラクタか、同Adapterの…

Material Design Color paletteをAndroidで使う

お題 Android Material Designでカラーパレットが提供されており、名前も決めてくれているので それを使いたい。Colors.xmlになってれば楽チンである。 回答 Githubにあったので素直にもらう。ダウンロードしてそのまま使用する。 https://gist.github.com/k…

パッケージ名による外部アプリの起動

パッケージ名がわかっているケースで、アプリがインストールされていればアプリを起動し、 されていなければGoogle Playに遷移する。 String packageName = "jp.theylive.android.app"; //AndroidManifest.xmlのpackageNameに相当 PackageManager pm = mCont…

ImageViewのsetBackgroundResourceとsetImageDrawableについて

ImageViewにはViewから継承したsetBackgroundResourceの他にsetImage系のメソッドがあって、 この二つのメソッドを同時に使うといい感じに画像を重ねて表示してくれて便利だったのだけど、 2.3系の端末でテストしてたら片方しか表示されなかった。どうやらse…

Facebookログイン直後にProfileがnullになるケース。

現象 Facebookログイン時にFacebookCallbackのonSuccessが呼ばれ、AccessTokenが取得できているにも関わらず、Profile.getCurrentProfile()がnullになるケースがあった。 FacebookCallback<LoginResult> mFacebookCallback = new FacebookCallback<LoginResult>() { @Override public v</loginresult></loginresult>…