在fragment中添加点击事件,给Linearlayout添加点击监听

按钮初始化 和 添加点击事件  都必须在onActivityCreated()里面执行。


XML

  

    

fragment

public class Fragment extends Fragment {
    @Override  
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        return inflater.inflate(R.layout.fragment, container, false);  
    }
    @Override  
    public void onActivityCreated(Bundle savedInstanceState) {  
        super.onActivityCreated(savedInstanceState);  
        Button button = (Button) getActivity().findViewById(R.id.button);  
        button.setOnClickListener(new OnClickListener() {  
    @Override  
    public void onClick(View v) {  
                Toast.makeText(getActivity(), "Clicked", Toast.LENGTH_LONG).show();  
            }  
        });  
    }  
}
代码中最关键的要注意: 
在onCreateView中返回Fragment的布局文件 

在onActivityCreated中通过getActivity()获取到Fragment关联的Activity,在onActivityCreated中为按钮添加监听事件。 


给Linearlayout添加点击事件:

View home = layout.findViewById(R.id.LinearLayout_home); 
home.setOnClickListener(new  View.OnClickListener() {
public void onClick(View v) {
 int i = 0;
  }

 });

需要注意的是new的是View.OnClickListener(),而不是OnClickListener()。否则找不到OnClickListener函数。

另补充下http://bbs.csdn.net/topics/360078789看的一个说明:

如果你的linearlayout中的孩子们都监听了click事件了,linearlayout是拿不到事件的。

在Android系统的中,硬件触发的事件最开始是Activity拿到的,然后它向里面的View一级级的dispatch,所以最里层的view最后拿到了事件,而它又没有孩子了,它就开始处理了(也就是响应事件)。在孩子的事件处理函数中,如果返回了false,它的父容器还是能再次拿到了事件的。如果返回了true,也就是告诉它的父容器,这事我管了,你就别过问了。

linearlayout的孩子们估计都有自己的Click事件处理函数了吧?

Click事件其实一种封装的事件,而不是我说的“硬件触发的事件”,“硬件触发的事件”指的是MouseUp, MouseDown,MouseMove和MouseCancel。View类中对于Click事件默认都是采取返回了false。所以你的linearlayout是拿不到事件的,因为它的孩子已经处理过了。

但是有一种解决方案:你可以重写linearlayout的onInterceptTouchEvent()方法,它会在事件传给孩子之前被调用。


转自 http://blog.csdn.NET/wletv/article/details/8786244



你可能感兴趣的:(开发记录)