Activity Lifecycleの備忘録

Activity
概要

  • public class Activity
ループ概要

  • onCreate()で始まって、onDestroy()で終了する。

  • onStart()で目に見える処理が始まり、onStop()で終了する。

  • onResume()でユーザー対話式の処理が始まりonPause()で終了する。
ライフサイクル

Method Description Killable Next
onCreate()
--- No onStart()
onRestart()
--- No onStart()
onStart()
--- No onResume() / onStop()
onResume()
--- No onPause()
onPause()
--- --- onResume() / onStop()
onStop()
--- Yes onResume() / onDestroy()
onDestroy()
--- Yes ---

一覧
 public class Activity extends ApplicationContext {
protected void onCreate(Bundle savedInstanceState);

protected void onStart();

protected void onRestart();

protected void onResume();

protected void onPause();

protected void onStop();

protected void onDestroy();
}
onResume()の使用例

  • Timerなどに利用可能
onResume()のOverride
 @Override
public void onResume(){
super.onResume();
//Timer の起動を行う
}
Timer()の記述


(参考: https://developer.android.com/reference/android/app/Activity.html

---
【更新履歴】
180209:初期作成

【対応必要箇所】



広告

この広告は30日以上更新がないブログに表示されております。
新規記事の投稿を行うことで、非表示にすることが可能です。
posted by fanblog

2018年09月17日

Android Studio リリースノート(2018.09.14)

エミュレータ情報
概要

アンドロイドのエミュレータ 28.0.8 「カナリア」が利用可能となったようです。
簡単には、「速度向上」と「ユーザビリティの修正」といったところでしょうか。
ポイント

1. エミュレータの速度を向上。
 ・tmpディレクトリにファイルを保持しすぎると速度低下していた模様。
 ・ADB(恐らくAndroid Debug Bridge)に生存確認のチェックファイルを保存しないことで対応。
〇Windowsの場合:
  C:\Users\ \AppData\Local\Temp\AndroidEmulator\*
〇Mac/Linuxの場合:
  /tmp/android- /*

2. クイックブートのアイコンを英語圏のユーザでも理解できるように変更。
3. MIPSビルドは削除。

(Google Developersは こちら

---
【関連記事】


---
【更新履歴】
180917:初期作成



2018年09月16日

MediaPlayerの備忘録

MediaPlayer
概要

Android で「バックグラウンドで音楽を流したい」、「ミュージックプレイヤーを作りたい」など音楽を再生するニーズがあると思います。
音楽を流すためのクラスに「MediaPlayer」があります。
簡単に使い方をまとめます。

動作概要

公式の サイト にステートマシン図で動作紹介されています。
MediaPlayer.png


概要のみ簡単に説明します。
[状態一覧]
1. Idle:初期状態:MediaPlayer のインスタンス後の reset() を呼び出した状態。
2. End:終了:どのステートからでも呼ぶことができる。release() を呼び出した状態。
3. Initialized:初期化状態: setDataSource() を呼び出して、データベースにメディアデータソースをセットした状態。
4. Prepared:準備済み状態:音楽再生前の状態。prepare() 関数を呼び出した状態。
5. Preparing:準備中状態:初回の呼び出し時などに呼ばれる状態。
6. Started:開始:再生中。
7. Stoped:停止:音楽停止。
8. Paused:一時停止:一時停止。
9. PlaybackCompleted:再スタート:リスタート。

簡単なサンプル

下準備として、R.rawの配下に再生したい音楽を「music_sample」と名前を付けておいています。

_myMediaPlayer = MediaPlayer.create(getApplicationContext(),R.raw.music_sample);
_myMediaPlayer.start();
//_myMediaPlayer.stop();


start() で音楽が再生されたと思います。

(Google Developersは こちら

---
【関連記事】


---
【更新履歴】
180916:初期作成



2018年08月15日

Android 9 の特徴とAPI

Android 9 (API level 28)
概要

Android 9 (API Level 28) が公開されたので、その特徴をまとめようと思います。
追加された項目としては、大きく 3 点ありました。(原文は こちら

1. Indoor positioning with Wi-Fi RTT

Wi-FiのIEEE 802.11mcの Wi-Fi Round-Trip-Time(RTT)というプロトコルがサポートされました。
これは、屋内のGPSで位置情報を取得しにくい場合でも、Wi-Fiのアクセスポイントとの距離に基づいて位置情報を取得できる。この時、ユーザはアクセスポイントに接続していなくても、距離情報を取得することができる。このため、ユーザのプライバシーは保護しつつ、精度の高い位置情報を取得することができるようになる。
位置情報の取得精度としては、 1 ~ 2 m の誤差となるため、かなり高精度の位置情報を簡単に取得できるようになる。
例えば、道案内の精度向上やショッピングモールなどの屋内施設での道案内などに応用することができる。
うまく利用できれば、顧客の店内移動情報が取得できるのではないだろうか。
2. Display cutout support

iPhone X などの画面の上部が欠けている端末にも対応できるようになる。
アップルでは「センサーハウジング」と呼ばれ、X 開発者向けサイトでも、そのように紹介されるが、Googleでは「cutout」と表現するようだ。
関数の getDisplayCutout() で取得することができ、「LAYOUT_IN_DISPLAY_CUTOUT_MODE_DEFAULT」、「LAYOUT_IN_DISPLAY_CUTOUT_MODE_SHORT_EDGES」、「LAYOUT_IN_DISPLAY_CUTOUT_MODE_NEVER」の3種類が用意されている。(今回は詳しくは紹介しない。)
3. Notifications

通知機能の更新である。
プッシュ通知画面で、メッセージの返信を行うことが可能となった。

4. Multi-camera support and camera updates

マルチカメラに対応した。2 つ以上のカメラを内蔵する場合にも、制御することが可能である。

5. ImageDecoder for drawables and bitmaps

BitmapFactoryの代わりに、ImageDecoderを採用。

6. Animation

アニメーションの表示機構の導入。 GIF と WebP がAnimatedVectorDrawableのように動く。

7. HDR VP9 Video, HEIF image compression, and Media APIs

HDR VP9 や HEIF サポート。

8. Data cost sensitivity in JobScheduler

処理の向上など

(Google Developersは こちら

---
【関連記事】
SensorEventListenerの使い方備忘録

---
【更新履歴】
180815:初期作成

2018年07月19日

SenserEvent の各センサー

SenserEvent
概要

・SenserEventListenerで取得できる各センサーの値をまとめる。
・SenserEventListenerの使い方は、 こちら の記事で記載しているので、ご参考までに。

Sensor.TYPE_ACCELEROMETER

public final float[] 、単位[m/s^2]
加速度センサー。 float 配列で、各値は以下の通り。

  • values[0]:
    x軸方向の加速度(デバイスの画面と向かい合った時の横方向。)
    例えば、左から右にデバイスを移動させるとプラスの加速度

  • values[1]:
    y軸方向の加速度(デバイスの画面と向かい合った時の縦方向。)
    重力加速度分はデフォルト値から引かれている。
    例えば、デバイスを下から上へ移動させるとプラスの加速度。

  • values[2]:
    z軸方向の加速度(デバイスの画面と向かい合った時の前後方向。)
    手前方向がプラスの加速度。

Sensor.TYPE_PRESSURE

public final float[] 、単位[hPa]
気圧。 float 配列で、各値は以下の通り。

  • values[0]:
    気圧


Sensor.TYPE_RELATIVE_HUMIDITY

public final int[] 、単位[%]
相対湿度。 float 配列で、各値は以下の通り。

  • values[0]:
    湿度



event.getAction()

主要な取得可能な値


基本的には、配列に各軸の値が入っている。

(Google Developersは こちら

---
【関連記事】
SensorEventListenerの使い方備忘録

---
【更新履歴】
180623:初期作成
180719:項目追加



2018年05月27日

MotionEventの使い方備忘録

MotionEvent
概要

・android.view.MotionEvent配下のリスナー
・入力イベントの取得
・・タッチ入力など

クラス図
android_hardware.png


呼び出し方

onCreate() 内で利用定義

<対象パーツ(スクリーン、ボタンなど)>.setOnTouchListener(new View.OnTouchListener(){
 public boolean onTouchEvent(MotionEvent event) {

 }
});

ここで、対象物を指定して、タッチ入力の取得が行える。
event に入力状況が保存されている。
例えば、以下のように値を取得することで、画面に「触れた」「放した」、指を「スライドさせた」などの動作を取得することができる。

event.getAction()

主要な取得可能な値

event から取得できる値を記載する。
マルチタッチに対応しており、複数の指の座標の取得が可能。
ただし、タッチ位置を取得するgetX()などの値には、1つの座標のみが取得可能。
スクリーンに初めに触れた指から0→1...と順に値が振られる。
スクリーンからすべての指を放した際に、振られた値はリセットされる。
(※マルチタッチ時は例外。放した指の値のみ解放される。)

  1. デバイス情報:getDevice
    例えば、amazonのfire8で取得される情報は以下のようなものである。

    Input Device(int) : 入力したデバイスのID。機器ごとに決まる。

    Descriptor(string) : 入力デバイスのディスクリプター

    Generation : デバイスの世代情報。fire8は"28"

    Location : fire8は"built-in"

    Keyboard Type : キーボード情報。タッチ入力の場合?"none"

    Has Vibrator : バイブ機能。タッチ入力の場合?"false"

    Source : タッチスクリーンの入力可能情報。
    ・AXIS_X: x方向(横、水平)のサイズ
    ・AXIS_Y: y方向(縦、垂直)のサイズ
    ・AXIS_PRESSURE: 感圧?
    ・AXIS_SIZE:
    ・AXIS_TOUCH_MAJIR:
    ・AXIS_TOUCH_MINOR:
    ・AXIS_TOOL_MAJIR:
    ・AXIS_TOOL_MINOR:


  2. x方向のタッチ位置:getX
    引数にintの値を入力することで、マルチタッチ時に複数の座標を取得することができる。
    例)event.getX(1)

  3. y方向のタッチ位置:getY

  4. タッチし始めた時間を取得:getDownTime
    デバイス内部のシステム起動時間

  5. タッチ動作:getAction
    それぞれ頭の[(int)]が返値。MotionEventの該当動作も記載。

    ・[0] MotionEvent.ACTION_DOWN : 指一本のみ触れた

    ・[1] MotionEvent.ACTION_UP : 指一本のみで触れていた場合、指を放した

    ・[2] MotionEvent.ACTION_MOVE : 指一本のみで触れていた場合、指を動かした

    ・[?] MotionEvent.ACTION_CANCEL : タッチ操作では呼ばれない?

    ・[5] ??? : 発生トリガー不明(複数本の指で触れていた時に、放すと取得されることもある)

    ・[6] ??? : 発生トリガー不明(複数本の指で触れていた時に、放すと取得されることもある)

    ・[261] ??? : 2本の指で触れた

    ・[262] ??? : 2本の指で触れていたときに、指を1本放した

    ・[517] ??? : 3本の指で触れた

    ・[518] ??? : 3本の指で触れていたときに、指を1本放した

    ・[773] ??? : 4本の指で触れた

    ・[774] ??? : 4本の指で触れていたときに、指を1本放した

    ・[1029] ??? : 5本の指で触れた

    ・[1030] ??? : 5本の指で触れていたときに、指を1本放した

    ・[1285] ??? : 6本の指で触れた

    ・[1541] ??? : 7本の指で触れた

    ・[1797] ??? : 8本の指で触れた

    ・[2053] ??? : 9本の指で触れた

    ・[2309] ??? : 10本の指で触れた

    など

恐らく、メインに利用するのは、このような値であろうと思われる。
基本的な使い方はgoogleのページに記載されているので、そちらを確認してもらった方が確実とは思う。

(Google Developersは こちら

---
【更新履歴】
180527:初期作成
180602:getActionの追記
180916:クラス図追加


ロリポップ!レンタルサーバー !はあなたの「やってみたい!」を応援します!

ロリポップ!なら、ホームページ、ブログ、ネットショップ…

これらが今すぐ、そして簡単にできちゃう!

マニュアルやライブチャットを完備しているので、ホームページ初心者でも安心。

これだけついてるのに月額100円(税抜)〜ととってもお得。

もちろん無料のお試し期間も10日間あるので安心ですね。


▼ロリポップ!レンタルサーバーはこちら

2018年05月06日

Intentの備忘録

Intent
概要

・android.content.Intent配下のリスナー
methods

    Androidでオブジェクト間の情報のやり取りを行う関数。
    画面遷移やバッテリ情報の取得が可能。

    IntentFilter intentFilter = new IntentFilter(Intent.ActionBatteryChanged);
    Intent intent = this.RegisterReceiver(null, intentFilter);
    int batteryLevel = intent.GetIntExtra(BatteryManager.ExtraLevel, -1);


    バッテリーの残量表示の例。

    (Google Developersは こちら

    ---
    【更新履歴】
    180506:初期作成

    ---
    【追記予定】
    Intentの追記
    IntentFilterの新規作成



2018年04月28日

SQLiteDatabaseの使い方備忘録

SQLiteDatabase
概要

・android.database.sqlite配下のリスナー
methods

    データベースの作成準備。
    データベースの要素の設定。

    public static class FeedEntry implements BaseColumns {
      public static final String TABLE_NAME = "entry";
      public static final String COLUMN_NAME_TITLE = "title";
      public static final String COLUMN_NAME_SUBTITLE = "subtitle";
    }


  • execSQL
    データベースの作成/追加/更新/削除 に使用する関数。
    Stringを引数とすることで挿入することができる。

    String SQL_CREATE_ENTRIES =
      "CREATE TABLE " + FeedEntry.TABLE_NAME + " (" +
      FeedEntry._ID + " INTEGER PRIMARY KEY," +
      FeedEntry.COLUMN_NAME_TITLE + TEXT_TYPE + "," +
      FeedEntry.COLUMN_NAME_SUBTITLE + TEXT_TYPE + " )";
    db.execSQL(SQL_CREATE_ENTRIES);


    引数を変更することで、データベースの削除をすることも可能。

    String SQL_DELETE_ENTRIES =
      "DROP TABLE IF EXISTS " + FeedEntry.TABLE_NAME;
    db.execSQL(SQL_DELETE_ENTRIES);


    ただし、これではデータベース自体を削除するため、行の削除は後述の delete を使用する。

  • delete
    データベースの行データの削除を行う。

    delete(String table, String whereClause, String[] whereArgs)



  • (Google Developersは こちら

    ---
    【更新履歴】
    180426:初期作成



2018年02月10日

Kotlinの備忘録

Kotlin
概要

  • 2011年7月にリリースされた比較的新しい言語
特徴

  • Java仮想マシン上で動作
  • Javaコードと相互運用が可能
  • 型の省略が可能
変数定義

  • var
    再代入可能

  • val
    再代入不可

すっきりしたコードを書く場合は、 valをメインに利用する方がよいと思われる。
switch(java):when(kotlin)

  • Kotlinにはswitchがないが、代わりにwhenを利用する
Java
 switch(value) {
case: 0
//value == "0"
break;
case: 1
//value == "1"
break;
default:
//
break;
}
Kotlin
 when (value) {
0 -> {
//value == "0"
}
1 -> {
//value == "1"
}
else -> {
//
}
}

if文

  • Kotlinには三項演算子がない
  • Kotlinのif文は式である
Java
 int value = 0;
if( n > 0 ){
value = 1
} else {
value = 2
}
Kotlin
 val value = if (n > 0) {
1
} else {
2
}



---
【更新履歴】
180208:初期作成

【対応必要箇所】



2017年12月03日

SensorEventListenerの使い方備忘録

SensorEventListener
概要

・android.hardware配下のリスナー

methods

  • onAccuracyChanged

    センサーの精度が変更されたときにのみ 呼び出される関数。

    基本的には扱うことはない と考えてよい。

    @Override
    public void onAccuracyChanged(Sensor sensor, int accuracy){
        //処理の記載
    }

  • onSensorrChangedd

    センサーイベントが発生 したときに呼び出される。

    センサー値取得後の処理 を記載。

    @Override
    public void onSensorChanged(SensorEvent event){
        //処理の記載
    }


使い方

・androidStudioのメイン画面のxmlに追加してテストしてみたい場合。

・amazon Fire8で動作確認済みの3つのセンサーをswich文で切り替え。
⇒swich文を修正で対応可能

sensorEventListenerにオーバーロードで処理を実行
private final SensorEventListener listener = new SensorEventListener() {
  @Override
    public void onSensorChanged(SensorEvent sensorEvent) {
      switch (sensorEvent.sensor.getType()){
        case Sensor.TYPE_LIGHT:
          //処理を記載
          break;
        case Sensor.TYPE_ACCELEROMETER:
          //処理を記載
          break;
        case Sensor.TYPE_GYROSCOPE:
          //処理を記載
          break;
        default:
          //処理を記載
          break;
      }
    }

    @Override
    public void onAccuracyChanged(Sensor sensor, int i) {

    }
  };

ButtonのclickListenerなどに以下を記入でSenser起動
  List<Sensor> sensorList = sensorManager.getSensorList(Sensor.<<利用したいセンサー>>);
  if(sensorList.size()>0){
    Sensor s = sensorList.get(0);
    sensorManager.registerListener(this.listener,s,sensorManager.<<描画速度>>);
  }


指定可能センサー一覧
※※※ 使用機種によって異なる ※※※

〇対応しているセンサー一覧の取得
List<Sensor> deviceSensors = mSensorManager.getSensorList(Sensor.TYPE_ALL);

〇センサー一覧

  • Sensor.TYPE_ACCELEROMETER

  • Sensor.TYPE_MAGNETIC_FIELD

  • Sensor.TYPE_GYROSCOPE

  • Sensor.TYPE_LIGHT

  • Sensor.TYPE_PRESSURE

  • Sensor.TYPE_PROXIMITY

  • Sensor.TYPE_GRAVITY

  • Sensor.TYPE_LINEAR_ACCELERATION

  • Sensor.TYPE_ROTATION_VECTOR

  • Sensor.TYPE_ORIENTATION

  • Sensor.TYPE_RELATIVE_HUMIDITY

  • Sensor.TYPE_AMBIENT_TEMPERATURE

  • Sensor.TYPE_MAGNETIC_FIELD_UNCALIBRATED

  • Sensor.TYPE_GAME_ROTATION_VECTOR

  • Sensor.TYPE_GYROSCOPE_UNCALIBRATED

  • Sensor.TYPE_POSE_6DOF

  • Sensor.TYPE_STATIONARY_DETECT

  • Sensor.TYPE_MOTION_DETECT

  • Sensor.TYPE_HEART_BEAT

  • Sensor.TYPE_LOW_LATENCY_OFFBODY_DETECT

  • Sensor.TYPE_ACCELEROMETER_UNCALIBRATED


描画速度

設定
遅延時間(ms)
備考
SensorManager.SENSOR_DELAY_FASTEST
0
ほぼリアルタイム
SensorManager.SENSOR_DELAY_GAME
20
ゲームなどの用途
SensorManager.SENSOR_DELAY_UI
60
通常App
SensorManager.SENSOR_DELAY_NORMAL
80
デフォルト



・遅延を減らせば減らすほど、消費電力もその分増えていくため、目的に沿った速度を選択。

・センサーごとに消費電力も取得できるため、パフォーマンス設定時には参考に。


(Google Developersは こちら

---
【更新履歴】
171203:初期作成

【対応必要箇所】(171205現在)
□androidHardware章の作成
□android機種ごとのセンサー対応表作成

posted by androidprogramblog at 21:00 | Android Studio
Mobilize your Site
スマートフォン版を閲覧 | PC版を閲覧
Share by: