質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.60%

入れ子にしたLinearLayout内のviewのIDやtextを取得・変更したい

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 4,606

score 10

android studioでアプリケーションの開発をしています。(動作環境はAndroid8.0 API26)

まず初めにレイアウトをxmlで記述して表示した結果、想定通りのレイアウトを表示することができました。
動的にレイアウトを複数個 追加する必要があったため、LayoutInflater を使ってxmlファイルをレイアウトに追加する処理を書きました。
追加するxmlには 枠になるLinearLayout 内にLinearLayoutを複数配置してlayout_weight等でレイアウトを調整し、その中にボタンやテキストを配置しました。(下記にイメージ画像を添付します)

その結果、最深部にある TextView や ImageView の androidl:ID の動的な変更や、idを取得して setText が出来なくなってしまいました。(自分で学習した結果、getChildAt()ではLinearLayout内のLinearLayoutの子要素を取得できなかったためだと考えました。)

入れ子ではいけないのかと思い、Inflateを複数繰り返して入れ子にしていたLinearLayoutを表示してみましたが、layout_weight や layout_heightなどがなぜか無視されてしまいました。

入れ子上になっているレイアウトを複数個 動的追加するときの処理の書き方
このようなレイアウトを複数動的追加するときの実装方法
をご教授願います。

イメージ説明


追記
------------------ソースコード---------------------------
@Override
protected void onResume() {
super.onResume();

// inflateでsub.xml(上記のxml)を取得
LayoutInflater inflater = LayoutInflater.from(this);
LinearLayout addLayout = (LinearLayout) inflater.inflate(R.layout.sub0, null);

// addViewで追加
LinearLayout linearLayout = findViewById(R.id.food_lay);
linearLayout.addView(addLayout);

//画像出力処理?
ImageView imageView2 = findViewById(R.id.image);
imageView2.setImageResource(R.drawable.drink_milk_pack);

//ボタンの動作
//Button btclick = findViewById(R.id.btn_mainasu);
//ClickListener listener = new ClickListener();
//btclick.setOnClickListener(listener);



}

onResumeに記述し、別画面に遷移後戻ってきたときにxmlが動的に追加されるように処理しています。
追加時にはボタンが動作しますが2個目以降の追加時に動かなくなってしまいました(IDが重複するため?)
そのため動的なIDの変更やリスナクラス・画像の指定が必要なのかなと考えたのですが方法がわかりませんでした。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Tsukasa7613

    2019/01/30 11:15

    jimbe様
    コメントありがとうございます。
    アプリの内容としては、DBに格納してある食品データをリストにして表示・編集・追加するアプリを作成することが目的でした。リスト内のデータに食品名・賞味期限・在庫数(残量数)・残量を減らすためのボタンを実装するため一つのレイアウトを作成し、複数個動的追加する処理を考えていました。
    そのほか食品の詳細を表示するためにレイアウト自身にIDを持たせ、タップされたときに画面遷移を行ったり...と想定していた使用はいくらかあるのですが、その中でレイアウトを動的追加しつつIDを持たせて押されたときの処理が必要かなと悩んでいました。

    キャンセル

  • jimbe

    2019/02/04 16:26 編集

    サンプルを書いてみるべきか考えているうちに他に手が回ってしまいました, 失礼しました.
    お聞きするに, 動的追加をするのはリストを含む画面なのですね. ご質問に付けられたイメージ図は, リストの1行ということでしょうか.
    リストならば, アプリ側で XML を展開しなくても普通にビューとして表示できるかと思いますが, ViewType など使用しての複数のレイアウトを使ったリスト表示のご経験は御座いませんか?

    キャンセル

  • jimbe

    2019/02/04 16:37

    最初に「想定通りのレイアウトを表示することができ」たということで, その XML は残っていますでしょうか.
    宜しければそれにどこがどう動的に変わりたいのかをマーキングしてご提示頂けませんでしょうか.

    キャンセル

回答 1

+1

どのような回答をすれば要件を満たすのかわからないので、ひとまず適当にサンプルを作ってみました。「動的」という要素が出てきませんが、難しくするよりは孫レイアウトとなるxmlファイルを作成しておいて描画するのが簡単なのでは?というつもりで書いています。これが意図したものと異なるのであれば、そこから話を進めることができれば。

public class MainActivity extends AppCompatActivity {
    private int x = 0;
    private int y = 0;
    private int z = 0;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
    }

    @Override
    protected void onResume() {
        super.onResume();

        final LinearLayout parent = findViewById(R.id.food_lay);
        final LayoutInflater inflater = LayoutInflater.from(this);

        final LinearLayout subLayout0 =
                (LinearLayout) inflater.inflate(R.layout.sub0, null);
        parent.addView(subLayout0);

        final LinearLayout sub0 = findViewById(R.id.sub0);
        final LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
                ViewGroup.LayoutParams.MATCH_PARENT,
                ViewGroup.LayoutParams.MATCH_PARENT,
                1
        );

        final LinearLayout grandsonLayout0 =
                (LinearLayout) inflater.inflate(R.layout.grandson0, null);
        sub0.addView(grandsonLayout0, params);

        final LinearLayout grandsonLayout1 =
                (LinearLayout) inflater.inflate(R.layout.grandson1, null);
        sub0.addView(grandsonLayout1, params);

        final LinearLayout grandsonLayout2 =
                (LinearLayout) inflater.inflate(R.layout.grandson2, null);
        sub0.addView(grandsonLayout2, params);

        final ImageView imageView1 = grandsonLayout0.findViewById(R.id.imageView1);
        imageView1.setImageResource(R.drawable.drink_milk_pack);

        final TextView textView1 = grandsonLayout1.findViewById(R.id.textView1);
        textView1.setText(String.valueOf(x));

        final TextView textView2 = grandsonLayout1.findViewById(R.id.textView2);
        textView2.setText(String.valueOf(y));

        final TextView textView3 = grandsonLayout2.findViewById(R.id.textView3);
        textView3.setText(String.valueOf(z));

        Button btn_mainasu = grandsonLayout2.findViewById(R.id.btn_mainasu);
        btn_mainasu.setText("Count!!");
        btn_mainasu.setOnClickListener(new ClickListener(textView3));

        x++;
        y++;
    }

    class ClickListener implements View.OnClickListener {
        private TextView textView3;

        ClickListener(TextView v) {
            textView3 = v;
        }

        @Override
        public void onClick(View v) {
            z++;
            textView3.setText(String.valueOf(z));
        }
    }

    @Override
    protected void onPause() {
        super.onPause();
        LinearLayout parent = findViewById(R.id.food_lay);
        parent.removeAllViews();
        y = 0;
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        x = 0;
        z = 0;
    }
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/food_lay"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" />

sub0.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/sub0"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal"/>

grandson0.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</LinearLayout>

grandson1.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:id="@+id/textView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="30sp" />

    <TextView
        android:id="@+id/textView2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="30sp" />
</LinearLayout>

grandson2.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:id="@+id/textView3"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="30sp" />

    <Button
        android:id="@+id/btn_mainasu"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="30sp" />
</LinearLayout>

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/01/29 13:57

    keicha_hrs様
    回答ありがとうございます。サンプルプログラムを動かしてみました。質問内容でうまく言葉にできず、回答要件を提示できなくて済みませんでした。
    私がイメージしていたアプリではkeicha_hrs様から作成していだたいたレイアウトのsub0以下の要素を動的(他のボタンクリック時・onResumeで他の画面から戻ってきた時など)に3,4個複製させること、btn_mainasuボタンやレイアウトレイアウトのIDを取得してタッチ時の処理を行うことが目標でした。
    まとめるとxmlから生成したレイアウトを複製した際にIDの振り方・取得の仕方がわからないという質問でした。
    私側でもレイアウトを小分けにして表示させようとしてみましたが結局IDをgenerateして振った後のクリックの処理の書き方がわからずにいました。(OnClickメソッド内のクリックされた対象による分岐を増やさなければいけない?という考えが実装できませんでした。)
    孫の追加の方法は私のイメージ通りで、ソースは参考になる記述でした。ありがとうございました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.60%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る