Qiita Teams that are logged in
You are not logged in to any team

Log in to Qiita Team
Community
OrganizationEventAdvent CalendarQiitadon (β)
Service
Qiita JobsQiita ZineQiita Blog
4
Help us understand the problem. What are the problem?

More than 3 years have passed since last update.

@tomato_sugar

Raspbery pi3上で動作するAndroid ThingsのアプリをAndroid Studioで作成

2017年6月24日に実施された「東北Tech道場 郡山道場 第3回」の作業内容をまとめます。半年近く経ってしまいましたが、何かQiitaに書いてほしいとの依頼を受けたので、個人的にまとめていた内容を投稿します。

この回では、Android Studioを使って簡単なAndroid Thingsのアプリを作成し、Raspbery pi3上で動作させました。

(1)プロジェクトの新規作成

  • まずは「Start a new Android Studio project」のクリック。
    1.png

  • 「Application name」と「Company domain」の入力。「Company domain」の方は、個人で作るので、とりあえず自分の名前を半角小文字、ピリオド区切りで入力。
    2.png

  • あとは基本的に「Next」「Next」「Next」「Finish」でOK。

  • すると、次のようにプロジェクトが作成され、エディタが表示される。
    3.png

(2)デザインの作成

  • MainActivityを選び、デザインエディタを表示する。
    4.png

  • TextViewとToggleButton4つをビューにドラッグして配置する。
    5.png

  • 垂直のGuidelineを3本追加。
    6.png

  • Guidelineを画面の25%、50%、75%に配置する。
    7.png

  • TextViewコントロールに制約をつける。制約をつけることで、端末の画面サイズや縦横が異なったときにレイアウトが崩れなくなる。
    8.png

  • ToggleButtonにも制約を付ける。それぞれ、左右のGuidelineに付ける。
    9.png

  • 一番左のToggleButtonは上をTextViewにつける。
    10.png

  • 真ん中のTextViewは左右下の端と、一番左のToggleButtonの下側に付ける。

  • ToggleButtonどうしに制約を付ける。①と②、②と③、③と④を結ぶ。
    11.png

  • 縦表示にするとこんな感じ。レイアウト崩れなければOK。
    12.png

(3) プロパティの設定

  • 各ToggleButtonのidを変更。左から、「tbRed」、「tbBlue」、「tbGreen」、「tbWhite」に変更する。
    制約を付けている関係で、idを変えようとすると警告ダイアログが出るので「Yes」を押す。
    真ん中のTextViewのidも「tvReslt」に変更する。プログラムで参照するものはデフォルトの名前だとわかりづらいので、変えた方がいい。
    13.png

  • TextViewのサイズを変更する。2つとも30以上がいい。
    14.png

  • 上のTextViewのTextプロパティは「Select LED Color」に、真ん中のTextViewのTextプロパティは「No Ligth Up」に変更する。

(4)色の変更

  • color.xmlに色を追加する。
    15.png

  • ToggleButtonのTextColorを変更する。
    16.png
    16_2.png

(5)MainActivity.javaの編集

  • 次の個所を入力する。
    17.png

  • イベントリスナー(ボタンクリックなどのイベントで呼ばれるメソッド)を追加する。下記を入力する。エラーが出るが気にしない。
    18.png

  • エラー個所を修正する。
    19.png

  • onCheckedChangedメソッドが追加されるので、コードを追加する。
    ※11行目あたり(public class MainActivity extends AppCompatActivity {と@Overrideの間)に

    private TextView tvReslt;

     を追加してからやること。

20.png

21.png

  • これは、「赤」ボタンのイベントリスナーなので、「青」、「緑」、「白」のイベントリスナーもコピーして作る。

  • イベントリスナーのセット。次の赤下線のコードを追加する。
    22.png

(6)「おまじない」の追加

-「build.gradle」に赤下線部を追加。
23.png

  • 「AndroidManifest.xml」に赤下線部を追加。 24.png

(7)Raspberry Pi3で実行する。

  • こんな感じになれば成功。Raspberry Pi3にマウスをつないでボタンをクリックすれば、中央のTextViewが変わるはず。

25.jpg

Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
4
Help us understand the problem. What are the problem?