按钮在自定义LinearLayout中无法单击

时间:2013-10-25 22:58:26

标签: android

我有一个包含framelayout的自定义视图。此framelayout包含两个可以滑动的视图(LinearLayout)。如果我滑动第一个,则第二个出现,反之亦然。其中一个视图有一个按钮,但我不知道为什么,这个按钮就像禁用。我无法点击它并且onClick方法无效。

这里是在自定义视图中膨胀的布局xml的结构:

<FrameLayout>

  <LinearLayout
      android:id="@+id/frontview"
  /> 
  <LinearLayout
      android:id="@+id/backview">
    <Button
       android:layout_height="wrap_content"
       android:layout_width="wrap_content"
       android:id="@+id/ButtonUpdate"
       android:text="@string/bUpdate"
       android:padding="5dp"
       android:clickable="true"
       style="?android:attr/borderlessButtonStyle"
        />
  </LinearLayout>

</FrameLayout>

这是我的自定义视图中的代码:

public class mView extends LinearLayout {

ImageView icon;
TextView current_data;
TextView previous_data;
TextView time ;
Button bUpdate;
EditText TextUpdate;

public mView(Context context) {
    super(context);
    init(context);
}

public mView(Context context, AttributeSet attrs) {
    super(context,attrs);
    init(context);

}

public mView(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
    init(context);
}

@Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
    // nothing
    }
}

public void init(Context pContext) {
    LayoutInflater inflater = (LayoutInflater) pContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    View ll = inflater.inflate(R.layout.list_item_data, this, true);

    /** We initialize the elements of our UI **/
    /**
     * First View
     */
    icon= (ImageView) ll.findViewById(R.id.ic_icon);
    current_data = ll.(TextView) findViewById(R.id.current_data);
    previous_data = ll.(TextView) findViewById(R.id.previous_data);
    time = (TextView) ll.findViewById(R.id.time);

    /**
     * Second View
     */
    bUpdate = (Button) ll.findViewById(R.id.ButtonUpdate);
    TextUpdate= (EditText) ll.findViewById(R.id.TextUpdate);
    bUpdate.setOnClickListener(new bUpdateClickListener());        
}

private class bUpdateClickListener implements OnClickListener {
    @Override
    public void onClick(View v) {
        // When the button is clicked, the front view re-appears and the backview disappears
        frontview
                .animate()
                .translationX(0);
        backview
                .animate()
                .translationX(-backview.getMeasuredWidth());

    }
}

使用onInterceptTouchEvent(MotionEvent ev)onTouchEvent(MotionEvent ev)正确处理滑动。

这里是MyActivity中使用的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="match_parent"
   android:layout_height="wrap_content"
   android:background="#ffffff">

   <LinearLayout
      android:orientation="vertical"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:background="#f6f6f6">

      <TextView
         android:id="@+id/infoimc"
         android:layout_width="wrap_content"
         android:layout_height="wrap_content"
         android:layout_marginLeft="18dp"
         android:layout_marginTop="8dp"
         android:text="@string/app_name"
         android:textColor="#000000"
         android:textSize="16dp"/>
      <View
         android:id="@+id/divider_infoimc"
         android:layout_width="match_parent"
            android:layout_height="1dip"
            android:layout_marginRight="18dp"
            android:layout_marginLeft="18dp"
            android:background="#99CC00"/>
      <com.example.essai.CustomGraph
         android:id="@+id/CustomGraph"
         android:layout_width="match_parent"
         android:layout_height="200dp"
         android:layout_gravity="center"
         android:visibility="visible"
         android:layout_marginTop="10dp"/>

   </LinearLayout>

   <FrameLayout
      android:layout_width="wrap_content"
      android:layout_height="80dp"
      android:layout_gravity="left|center_vertical">

   <com.example.essai.mView
      android:id="@+id/CustomView"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"/>

   </FrameLayout>

</LinearLayout>

和MyActivity.class:

public class MyActivity extends Activity {

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

}

我不知道按钮是否也必须在Activity中处理?

感谢您的帮助!

1 个答案:

答案 0 :(得分:2)

根本原因

根据API

  

FrameLayout旨在阻挡屏幕上要显示的区域   一个单个项目。

如果有更多项目,例如您的情况,则会发生“意外”事情:

  

子视图以堆栈形式绘制,包含最近添加的子视图   在顶部。

这意味着,您的frontview位于backview之上,由于frontview没有android:clickable="true",因此点击事件(按钮上)不会在下方委托

解决方案1 ​​

以编程方式重新排列子布局重力。

  

但是,您可以将多个子项添加到FrameLayout和控件中   它们在FrameLayout中的位置,通过为每个分配重力   孩子,使用android:layout_gravity属性。

只要您滑动它们,只需切换android:layout_gravity="top"android:layout_gravity="bottom"

解决方案2

以编程方式控制子布局的可见性。

当应显示backview时,请将frontview的可见性设置为View.GONE。并在相反的情况下将其设置为View.VISIBLE

解决方案3

FrameLayout更改为其他布局类型。

可能需要更多“摆弄”布局xmls ......

了解您最熟悉的内容并相应地选择解决方案:)