1

ボタンがクリックされるたびに、LinearLayout 内に複数のビュー (TextView、ProgressBar など) を持つ RelativeLayout を動的に作成して、前のビューの下に RelativeLayout を作成する方法をしばらく考えていました。誰でも私のコードを見て、この問題を解決するためにできることがあるかどうかを確認してください。

コードは次のとおりです。

activity_test_container.xml

<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:id="@+id/frag1ScrollView"         
 android:layout_width="fill_parent" 
 android:layout_height="wrap_content" >

<LinearLayout
android:id="@+id/testLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".TestContainerActivity" >

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >

    <TextView
        android:id="@+id/testContainerTextView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/testContainerTextView1"
        android:layout_marginBottom="16dp"
        android:text="TextView2" />

    <TextView
        android:id="@+id/testContainerTextView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:text="TextView1" />

    <Button
        android:id="@+id/testContainerButton1"
        style="?android:attr/buttonStyleSmall"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_toRightOf="@+id/testContainerTextView2"
        android:text="Button" />
</RelativeLayout>

</LinearLayout>

</ScrollView>

コンテナ.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/containerLayout"
    android:layout_width="match_parent"
    android:layout_height="80dp"
    android:paddingBottom="10dp"
    android:paddingLeft="10dp"
    android:paddingRight="10dp"
    android:layout_marginBottom="16dp"
    android:background="@color/display_panels" >

<ProgressBar
    android:id="@+id/containerProgressBar1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_alignParentLeft="true"
    android:layout_toLeftOf="@+id/containerImageButton2"
    android:max="100"
    android:progress="40" />

<TextView
    android:id="@+id/containerTextView4"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/containerTextView6"
    android:layout_alignLeft="@+id/containerProgressBar1"
    android:text=""
    android:textAppearance="?android:attr/textAppearanceSmall" />

<TextView
    android:id="@+id/containerTextView6"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/containerProgressBar1"
    android:layout_centerHorizontal="true"
    android:text=""
    android:textAppearance="?android:attr/textAppearanceSmall" />

<ImageButton
    android:id="@+id/containerImageButton2"
    style="?android:attr/buttonStyleSmall"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentRight="true"
    android:layout_below="@+id/containerTextView6"
    android:background="@color/display_panels"
    android:contentDescription="Okay icon"
    android:src="@drawable/ic_green_ok" />

</RelativeLayout>

TestContainerActivity.java

public class TestContainerActivity extends Activity implements OnClickListener {

LinearLayout containerLayout;
Button testButton;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_test_container);

    testButton = (Button)findViewById(R.id.testContainerButton1);
    containerLayout = (LinearLayout)findViewById(R.id.testLayout);

}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.test_container, menu);
    return true;
}


@Override
public void onClick(View v) {
    // TODO Auto-generated method stub
    if(v==testButton){

        createNewLayout();

    }
}

public void createNewLayout(){

        LayoutInflater layoutInflater = (LayoutInflater) getBaseContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        View addView = layoutInflater.inflate(R.layout.container, null);

        containerLayout.addView(addView);

}

}
4

1 に答える 1

2

問題が何であるかは完全にはわかりませんが、リスナーをボタンにアタッチする場所がわからないため、行がまったく表示されていないと思われます。クリック イベントを処理するには、View にOnClickListenerを設定する必要があります。これは一般的にボタンで行われますが、OnClickListeners は任意のビューに設定できるため、任意のサイズ/形状のウィジェットをクリック可能にすることができます。これはsetOnClickListener、ビューのメソッドで行われます。これを行うには複数の方法があります。次のように変更してみてくださいonCreate

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_test_container);

    testButton = (Button)findViewById(R.id.testContainerButton1);
    containerLayout = (LinearLayout)findViewById(R.id.testLayout);

    testButton.setOnClickListener(this);
}

onCreateリスナーを設定する別の方法は、Activity を使用するのではなく、リスナーを作成することです。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_test_container);

    testButton = (Button)findViewById(R.id.testContainerButton1);
    containerLayout = (LinearLayout)findViewById(R.id.testLayout);

    testButton.setOnClickListener(new View.OnClickListener() {  
        public void onClick(View v) {
            createNewLayout();
        }
    });
}

この場合、Activity に OnClickListener を実装させる必要はありません。通常、同様の機能を持つボタンが多数あり、それぞれのリスナーを作成するとパフォーマンスが低下する場合にのみ、そのようなことを行います。このようなより孤立したケースでは、パフォーマンスの違いはごくわずかであるため、個々のリスナーを設定することを好みますが、それは私の個人的な好みです。

お役に立てれば!あなたの問題が実際に別の場所に基づいている場合は、質問を修正してください。最善を尽くしてお手伝いします。また、Log クラスを使用して、実行に関する情報を LogCat 出力に投稿できることにも注意してください。デバッグに本当に役立ちます!リスナーにログを記録すると、createNewLayout()現在、これらのメソッドが呼び出されないため、ログが記録されないことがわかると思います。

于 2013-07-26T15:41:08.050 に答える