スキップしてメイン コンテンツに移動

Android ロックアプリを作る - 中間報告 -

Android のロックアプリを作っています。

電源ボタンを押して画面を消した場合、一定時間経過で画面が消えた場合に再度画面を表示させた時に表示されるアプリです。

標準では指の軌跡で端末ロックを解除します。

これを作りたいということで他のアプリをインストールしてみて動きを見てみました。


ロックアプリに求められるもの

  1. ホームボタン、バックボタンでアプリを終了させたくない
  2. 通知バーは非表示、もしくは開かないようにして他のアプリに遷移しないようにしたい
  3. 着信やアラームで端末画面がONになった場合は、そちらのアプリが優先されるべき

上記を解決する方法のヒント
  1. TYPE_SYSTEM_ALART もしくは TYPE_KEYGUARD
  2. FLAG_FULLSCREEN がうまく動作しないのでリフレクションで通知バーを閉じまくる
  3. SCREEN_OFF のブロードキャストでアプリを起動しておく
    SCREEN_ON のブロードキャストでアプリを起動すると着信、アラームよりも前面にロックアプリが表示されてしまう
その他
  1. SCREEN_ON,SCREEN_OFF はAndroidManifest.xml の intent-filter に記述してもレシーブできないのでServiceでレシーバーを登録、Service終了時にレシーバーを登録解除する
  2. タスクキラーなどでサービスが殺されるとロックアプリが無効になってしまう
  3. 通知バーを完全に非表示、開かなくする方法が見つかっていないため、通知バーから他のアプリが起動されることがある
  4. ロックアプリを解除せずに他のアプリが起動されているときにホームボタンを押すと挙動がおかしくなる
他にも気にすることがいっぱい




開発工数
※今回作ろうとしているロックアプリの場合です(仕様は秘密)
  1. 6人日程度(設計1人日、開発3人日、テスト2人日)
※私が開発する場合の見積もりです


受託開発で見積もる場合は
  1. 要件定義(外部設計)
  2. デザイン費(画像パーツ作成費用)
  3. 管理費
  4. その他(依頼内容によって増えるもの)
80万円~150万円程度になると思われます。
※無責任に計算した金額ですからね!




コメント

このブログの人気の投稿

Android ロックアプリを作る -調査編 -

Android 端末のスクリーンがOFFになると端末がロックされて、
スクリーンがONになるとロック画面が表示されます。

ロック画面は指の軌跡かパスワードを入力することで解除できます。

このロック画面をアプリとして作ってみたいと思い調査を始めることにしました。

調査の方針としては


色々なロックアプリをダウンロードしてみる。それぞれのパーミッションを見てみる。

という感じです。


色々なアプリをダウンロードしてみる。

まずはロックアプリ特集とかを探してみます。

Google 先生に聞いてみよう > Android ロックアプリ
結構出てきますね。


WidgetLocker LockscreenLockBot ProFロックスクリーン



それぞれのパーミッションを見てみる。

WidgetLocker Lockscreen



android.permission.VIBRATEandroid.permission.DISABLE_KEYGUARDandroid.permission.RECEIVE_BOOT_COMPLETEDandroid.permission.EXPAND_STATUS_BARandroid.permission.GET_TASKSandroid.permission.REORDER_TASKSandroid.permission.SET_PREFERRED_APPLICATIONSandroid.permission.WRITE_SETTINGSandroid.permission.WAKE_LOCKandroid.permission.CALL_PHONEandroid.permission.READ_SYNC_SETTINGSandroid.permission.GET_ACCOUNTSandroid.permission.READ_LOGSandroid.permission.SYSTEM_ALERT_WINDOWandroid.permission.WRITE_EXTERNAL_STORAGEandroid.permission.INTERNETandroid.permission.ACCESS_NETWORK_STATEandroid.permission.ACCESS_WIFI_STATEcom.android.vending.CHECK_LICENSE
LockB…

携帯電話、タブレットの判定にピクセルではなくインチを使う

色々な案件に関わっていると、スマートフォンなのかタブレットなのかの判定をするためにピクセルを使用しているソースを見ることが多くあります。

幅、高さのそれぞれのピクセル数がある値を超えたらタブレットと判定する。


これはだめですよね

HTC j butterfly  はタブレットと判定されることが多くあります。




ディスプレイは約5インチ
w x h : 1080px x 1920px

5インチなので画面サイズが大きいということでタブレットという判定でもいいかもしれない・・・と思ったりしますが7インチ以上をタブレットと判定したい。。。




ピクセル数は画面のサイズ(インチ)とは違います。1080px x 1920px は5インチであるとは限りません。

i9220++ スマートフォン Android 4.0 3G GPS 5.2 インチ800万画素携帯(ブラック)

5.2インチ 画面解像度:960 x 540 pixels QHD screen


HTC j butterfly よりも画面サイズ(インチ)は大きいけれど、ピクセル数は少なくなってます。


ピクセル数で判定するのではなく、インチで判定したほうが正確ですね。



プログラムで画面サイズ(インチ)を計算してみましょう。

ディスプレイ情報を取得する ピクセル数(width, height)を取得するdpi (xdpi, ydpi) を取得する1インチあたりのピクセル数(dot per inch なのでドット数?) インチ(width, height) を計算する画面サイズ(インチ)を計算する
こんな流れになります。他に簡単に取得できる方法があれば教えていただけるとうれしいです。

Activity#onCreateに書きました

// ディスプレイ情報を取得する
final DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);

// ピクセル数(width, height)を取得する
final int widthPx = metrics.widthPixels;
final int heightPx = metrics.heightPixels;

// dpi (xdpi, yd…

Mac の ターミナルから アプリをアンインストールする adb uninstall

ant uninstall でもいいんだけれど、ant プロジェクトじゃないこともあるのでメモ

adb uninstall パッケージ名
cVolume next をターミナルからアンインストールする場合
パッケージ名は jp.caldroid.cvolume40 なので

adb uninstall jp.caldroid.cvolume40
となる