-5

互いに補完する、一方の側に鋭い角を持つ 2 つのボタンを作成する必要があります。このような: 互いを引き立たせる、片側の角がシャープな2つのボタン。

4

2 に答える 2

0

最初に頭に浮かぶこと:

従来の FrameLayout の代わりに「マージ」を使用して、2 つのボタンを少しオーバーラップさせます

子ビューはスタックに描画され、最後に追加された子が一番上になります。

編集: 押された状態、選択された状態のドローアブルを追加することを忘れないでください。境界線が適切に作成されていることを確認してください。これにより、選択/押されたときに動作が奇妙になりません。

于 2013-01-26T12:02:55.757 に答える
-1

最良の方法は、両方のボタンの画像とその上にある 2 つの透明なビューを含む水平 Linearlayout を使用することです。

コードに次のようなものが必要です。

xml レイアウト:

    <LinearLayout
    android:layout_width="match_parent"
    android:id="@+id/parent"
    android:layout_height="50dp" >

    <View
        android:id="@+id/button1"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1" />

    <View
        android:id="@+id/button2"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1" />
</LinearLayout>

活動コード:

    private LinearLayout mParent;

    @Override
    public void onCreate(Bundle bundle){
    super.onCreate(bundle);
    mParent = (LiearLayout) findViewById(R.id.parent);
    (findViewById(R.id.button1)).setOnClickListener(mListener);
    (findViewById(R.id.button2)).setOnClickListener(mListener);
     }
      private OnClickListener mListener = new OnClickListener(){
       public onClick(View view){
         //change parent color
       }

   } }

または、より正確なイベントを処理するために onTouchListener を使用することもできます。

于 2013-01-26T12:03:00.717 に答える