1

私の写真を見て、そのようなレイアウトをデザインしたいと思います。以下のXMLコードを見てください。すでにデザインしていますが、横向きに回転すると、ボタンがショップエリアに収まらず(短い)、画像価格エリアの線形レイアウトが境界から外れています(長い)。すべての向きに合わせたいのですが、なぜボタンを使用しているのですか?実用的には、onClickListenerとして使用できるからです。

  1. すべての向きに合うようにこのレイアウトを設計するにはどうすればよいですか?

  2. XMLコードを使用してこのレイアウトを設計する方法があります(背景画像を使用しないでください)

ここに画像の説明を入力してください

 <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:background="@drawable/bar_all"
    android:gravity="center_vertical"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent" >

        <Button
            android:id="@+id/btn_all"
            android:layout_width="265dp"
            android:layout_height="match_parent"
            android:background="#00000000" />

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center_vertical"
            android:orientation="vertical" >

            <ImageButton
                android:id="@+id/btn_ic_mypage"
                android:layout_width="30dp"
                android:layout_height="30dp"
                android:layout_gravity="right"
                android:layout_marginRight="12dp"
                android:background="#00000000"
                android:scaleType="fitXY"
                android:src="@drawable/icon_mypage" />
        </LinearLayout>
    </LinearLayout>
</LinearLayout>
  1. 場所の背景画像の線形レイアウト
  2. プットボタンのリニアレイアウトがショップエリアをカバーします。onClickListenerの簡単なコーディング
  3. カバー$画像領域のリネアレイアウトと画像領域を配置します。
4

1 に答える 1

2

これがあなたが探しているコードです。

Also PL make sure you should avoid any length, height, width value is 20 dp,13 dp etc

このコードは、すべての画面サイズに適合します。

main.xml

   <?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:gravity="top">
    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/background_main"
        android:gravity="right|center_vertical">
        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:id="@+id/linearLayout3"
            android:orientation="vertical"
            android:layout_weight="1"
            android:gravity="center">
            <Button
                android:layout_height="match_parent"
                android:id="@+id/button_shop"
                android:layout_width="match_parent"
                android:background="@null"></Button>
        </LinearLayout>
        <LinearLayout
            android:id="@+id/linearLayout2"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:orientation="vertical"
            android:gravity="center">
            <Button
                android:background="@drawable/button"
                android:id="@+id/button_doller"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"></Button>
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

MainActivity.java

public class MainActivity extends Activity implements OnClickListener {

    private Button btnShop = null;
    private Button btnDoller = null;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        btnShop = (Button) findViewById(R.id.button_shop);
        btnShop.setOnClickListener(this);

        btnDoller = (Button) findViewById(R.id.button_doller);
        btnDoller.setOnClickListener(this);

    }

    @Override
    public void onClick(View v) {
        if (btnShop == v) {
            Toast.makeText(this, "shop button clicked", Toast.LENGTH_LONG)
                    .show();
        } else if (btnDoller == v) {
            Toast.makeText(this, "doller button clicked", Toast.LENGTH_LONG)
                    .show();
        }

    }
}

PS:画像を小さくしてから大きな画像サイズのアイコンを作成する場合は、ダミーのみを使用しました。

それが役に立てば幸い!!

于 2012-12-06T13:16:49.950 に答える