日々精進

新しく学んだことを書き留めていきます

android

クラスのメンバとして定義されているEnumをKeepするproguardの設定など

proguard-project.txtの設定の一部。 # Enumをkeepする対応 -keep public class * extends java.lang.Enum # クラスのメンバとして定義されているEnumをKeepする対応 -keepattributes InnerClasses -keep public enum ParentClass$** { **[] $VALUES; public…

LinearLayoutの子Viewの順序を動的に入れ替える

一度removeしてから好きな位置にaddViewする。例は以下。 navigationBar.removeView(orderModeCheckbox); if (orderModeCheckbox.isChecked()) { navigationBar.addView(orderModeCheckbox, navigationBar.getChildCount()); // 一番最後に追加 } else { nav…

配列とArrayListではequalsの挙動が違い、配列をMapのKeyにしてはいけない

配列のequalsはObject.equalsをオーバーライドしないため、すべての同じIndexの要素が等価である場合のみtrueになる。 ArrayListはすべての同じIndexの要素のequalsメソッドの結果がtrueであればtrueになる。 MapのKeyに配列を使ってしまってハマった。。Arr…

画面の向きを現在の向きに固定する

現在の向きが縦でも横でも固定したいという場合。API Levelが18以上であれば、以下を実行するだけでいい。 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LOCKED); 17以下であれば以下のようにする。 switch (((WindowManager) getSystemService…

ビルドすると「Could not find com.google.android.gms:play-services」エラー

原因はGoogle Repository SDKがダウンロード出来ていないこと。 SDK managerからGoogle Repositoryの最新版をダウンロードすると直る。 参考: Gradle unable to resolve Play services dependency

Viewに枠線をつける

border.xmlのような名前で以下をXMLに定義する。 <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="rectangle" > <solid android:color="#ffffff" /> <stroke android:width="1dip" android:color="#4fa5d5"/> </shape> あとはこれをbackgroundに設定すればよい。

TableLayoutの2つ以上の列をstretchした上で同じ幅にする

例えば、xmlでTableLayoutにandroid:stretchColumns="0,2"を設定すると1列目と3列目の幅をできる限り広くしてくれる。 が、セル内のTextView等の幅が変化すると1列目と3列目の幅が同じでなくなってしまう。 これは、android:layout_width="0dp"をすべてのstr…

チェックボックスをタップした時にチェックを付けさせない

チェックボックスをタップした時にチェックを付けさせないとか意味分からないと思うが、 バリデーションエラーになった場合などでタップしてもチェックを付けたくない場合がある。 そういう場合はonCheckedChangedイベントの中でsetChecked(false)を実行する…

リソースフォルダに修飾子を複数付けるときの注意

修飾子は順序が決まっているので、その順序で付けないといけない。 例えば、drawable-hdpi-landはだめでdrawable-land-hdpiとしないといけない。 参考: android providing different drawable resources for orientations http://developer.android.com/gui…

setBackgroundDrawableがAPI level 16以上でdeprecatedになっている

API level 15以下と16以上の両方をサポートする場合は以下のように分岐させないといけない。 Utilクラスにこのメソッドを定義しておくとよい。 public static void setBackground(View view, Drawable drawable) { if (Build.VERSION.SDK_INT >= Build.VERSI…

build.gradleにcompile 'com.google.android.gms:play-services:5.0.89'を追加すると「Attribute “theme” has already been defined」エラー

原因はplay-servicesでAttribute “theme”が定義されているため。 compile 'com.google.android.gms:play-services:5.0.89' を compile 'com.google.android.gms:play-services:6.1.+' に変更すると直る 参考: Lollipop AppCompat-v7 21 - Attribute "theme"…

compile 'com.android.support:appcompat-v7:20.+'をbuild.gradleに追加すると「This support library should not use a lower version」エラー

原因はcompileSdkVersionで指定しているバージョンより古いバージョン用のsupport libararyを使用していたため。 compile 'com.android.support:appcompat-v7:20.+' を compile 'com.android.support:appcompat-v7:21.+' に修正すると直った。 参考: Androi…

CookieをSerializeする/SerializableなObjectをStringに変換する

Cookieを永続化することになったので調べた。android-async-httpのPersistentCookieStoreを使うと簡単に永続化できそうだけど、そのためにライブラリをインストールするのはイヤだったので自作しました。 CookieクラスはSerializableを継承していないので、S…

ImageButtonにadjustViewBounds="true"を設定しても画像のサイズが変化しない

ImageButtonではなく、ImageViewを使わないといけない。これは罠だ。。 画像を縦横比を保ったまま、横幅を画面いっぱいまで拡大するには、以下の設定にしてandroid:srcかsetImageBitmapメソッドで画像を渡せばよい。

AndroidでButtonにBitmap画像を設定する

ImageButtonを使う。 ImageButton#setImageBitmapにBitmapオブジェクトを渡せば良い。 参考: How can I set a bitmap on button?

エミュレータからHTTPリクエストを送信すると「No address associated with hostname」

原因はエミュレータのWIFIがOFFになっていたことだった。しょぼい。。 機内モードにする時に間違ってWIFIをOFFにしてしまっていたっぽい。皆さんもお気を付けください。

screen orientationの設定値とその効果一覧

画面を時計回りに90度回転して横向きにすると画面が逆さまになる不具合が発生した。原因はmanifestで横画面のactivityにandroid:screenOrientation="landscape"を設定していることだった。 landscapeは反時計回りに90度回転して横向きにした向きのことで、時…

タッチイベントの座標を親View内での座標に変換する

motionEvent.getX()はタップされたViewの座標系での座標だが、これを親Viewの座標系での座標に変換したい場合は以下のように計算すれば良い。 view.getLeft() + motionEvent.getX() iOSではconvertPoint:toView:で任意のViewの座標系に変換出来るんだけど、A…

macでバイナリファイルを比較する

以下コマンドで比較できる。 cmp file1 file2 とりあえず同じファイルかどうかを確認するならこれで十分。 参考: Mac Terminal Command -【cmp】 2つのファイルの中身が同じかどうか

adb install -rでapkを上書きインストールしようとするとINSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATESエラー

原因はインストール済みのアプリと上書きインストール使用としているアプリの証明書が違うため。 証明書の確認をするために実機からapkを抜き出したり、apkの署名やKeystoreの情報を確認したそのときのコマンドは以下。 Android 実機から apk を探して取得す…

build.gradleのデバッグ実行(未解決)

Android Studioの右上にある「Gradle」のタブから、Gradleタスクを右クリックしてDebug実行するとbuild.gradleをDebug実行できるという情報があったが、build.gradleに貼ったBreakpointで止まらず。。なぜだ。 参考: AndroidStudioでgradleの実行時にDebugg…

buildTypeまたはproductFlavor毎に異なるsigningConfigを設定する

以下のようにbuildTypeのsigningConfigにsigningConfigsの設定のうち使用するものを渡せば良い。productFlavorの場合も同様。 signingConfigs { debug { storeFile file("conf/debug.keystore") storePassword "android" keyAlias "androiddebugkey" keyPass…

ScheduledExecutorService#scheduleAtFixedRateはsequentialにタスクを実行する

ScheduledExecutorService#scheduleAtFixedRateを短い間隔で何度も実行した場合、各タスクは並列に実行するのかを調べた。 結果、並列に実行はしないことがわかった。タスクはQueueに積んで一つずつ実行する。 参考: Does scheduleAtFixedRate call a diffe…

local.propertiesにsigningConfigsを格納する

build.gradleやgradle.propertiesはSCMにコミットするのでパスワード等は書きたくない。 なのでlocal.propertiesにsigningConfigsの情報を格納することにした。 コードは以下。 signingConfigs { // 署名情報はlocal.propertiesに記述すること。 Properties …

keystoreのkeyAliasを調べる方法

以下コマンドで調べられる。 keytool -list -keystore /android.keystore.path 出力される文字列のうち、どの部分がkeyAliasに当たるかは下記参照。 もしandroid.keysotreのkey aliasを忘れてしまったなら - Qiita

Androidでビルド時に「Configuration with name 'default' not found」エラー

原因はライブラリへの参照を、通常のjarを取ってくる形式のものからプロジェクト参照に変更した時に、参照先のパスを間違えていたため。 具体的にはsettings.gradleに以下を追記した。 include ':library' project(':library').projectDir = new File(settin…

org.apache.http.impl.client.DefaultHttpClientを使って通信している時にInterruptedIOExceptionが発生する

原因は以下。 ScheduledExecutorServiceを使ってポーリングしてて、ポーリングを一度止める場合にScheduledExecutorService#shutdownNowを実行していた。 shutdownNowを実行するとThread.interrupted()がtrueになる HttpClientのコードの中にループをぐるぐ…

Android4.1〜4.4でDatePickerDialogのボタンが「完了」のみになる

DatePickerDialogのボタンはOKとキャンセルの二つのはずなのに完了しか表示されない。。。と思ったらAndroidのバグらしい。4.1〜4.4で発生する。 このバグはIssueTrackerに登録されているが何年も放置されているので直ることはないだろう。 https://code.goo…

Androidの回転制御 端末の自動回転設定がOFFの場合は回転させない

端末を回転させたら画面も回転させる場合、以下を実行していたがSCREEN_ORIENTATION_SENSORだと端末の自動回転設定をOFFにしても回転してしまう。 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR); SCREEN_ORIENTATION_UNSPECIFIEDだと自…

UI Automator ViewerでViewの構造を調べる

Hierarchy ViewerでViewの構造を調べようとすると、以下のエラーメッセージが出て調べられなかった。 [2015-06-10 14:29:03 - ViewServerDevice]Unable to debug device: ... [2015-06-10 14:29:04 - hierarchyviewer]Missing forwarded port for ... [2015-…