最も簡単なオプションはおそらくあなたが提案したものです - xmlレイアウトファイルにすべてのレイアウトを追加し、個々のレイアウトの可視性を "GONE"に設定する。より多くのレイアウトを追加したい場合は、リソースを節約し、アクティビティが作成されたときにすべてのイメージをロードしないようにプログラムで作成することができます。
スクロールビューには、すべてのレイアウト(私に垂直な線形レイアウトのように見えます)を配置して、表示が設定されているとレイアウトが枠外に移動しないようにしたいと思うでしょう。
ボタンには、表示されていない次のレイアウトが表示され、もう一度レイアウトを隠すボタンが必要です。
あなたのXMLが(私は垂直リニアレイアウトを使用し、あなたが使用したい任意のレイアウトにこれを投げる)次のようになります。
<Button
android:text="Button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/button"
android:onClick="addLayout" />
<LinearLayout
android:orientation="vertical"
android:layout_weight="1"
android:visibility="gone"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/layout1">
<TextView
android:text="TextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textView"
android:layout_gravity="center_horizontal" />
<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:srcCompat="@mipmap/ic_launcher"
android:id="@+id/imageView" />
<Button
android:text="hide"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/button2"
android:onClick="hideParent (MainActivity)" />
</LinearLayout>
<LinearLayout
android:orientation="vertical"
android:layout_weight="1"
android:visibility="gone"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/layout2">
<TextView
android:text="TextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textView"
android:layout_gravity="center_horizontal" />
<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:srcCompat="@mipmap/ic_launcher"
android:id="@+id/imageView" />
<Button
android:text="hide"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/button3"
android:onClick="hideParent (MainActivity)" />
</LinearLayout>
<LinearLayout
android:orientation="vertical"
android:layout_weight="1"
android:visibility="gone"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/layout3">
<TextView
android:text="TextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textView"
android:layout_gravity="center_horizontal" />
<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:srcCompat="@mipmap/ic_launcher"
android:id="@+id/imageView" />
<Button
android:text="hide"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/button4"
android:onClick="hideParent (MainActivity)" />
</LinearLayout>
私は周りのすべてのscrollLayoutををラップするために役立つかもしれない、言ったようにこれは単なる基本的な考えです。あなたのメインは、次のようになります。助け
LinearLayout[] layouts;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
layouts = new LinearLayout[3];
layouts[0] = (LinearLayout) findViewById(R.id.layout1);
layouts[1] = (LinearLayout) findViewById(R.id.layout2);
layouts[2] = (LinearLayout) findViewById(R.id.layout3);
}
public void hideParent(View v) {
((LinearLayout)v.getParent()).setVisibility(View.GONE);
}
public void addLayout(View v) {
for (int i = 0; i <= 2; i++) {
if (layouts[i].getVisibility() == View.GONE) {
layouts[i].setVisibility(View.VISIBLE);
break;
}
}
}
希望は、コーディングの実際の方法は、あなたが達成したいレイアウトの柔軟性と数に大きく依存します。
ありがとうございました!これは私が欲しかったものです。ちょうど1つの修正:forループは 'for(int i = 0; i <3; i ++)' –
私は助けることができてうれしいです。うん、あなたは正しい、ありがとう、それを編集したばかり。 –