Android

时间:2017-10-13 18:10:48

标签: android button click touch listener

假设我有几个按钮,他们的点击是由一个公共处理程序处理的,有没有办法定义一次监听器而没有为每个按钮定义onClick属性?

<Button android:onClick="handler" />

或许在浏览器或某些拦截器中的父代表团.....假设你有50个按钮,你在每个显式点击声明???

4 个答案:

答案 0 :(得分:2)

是的,你可以这样做。

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {
List<Button> buttons;
ViewGroup parentView;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    buttons = new ArrayList<>();
    parentView = (ViewGroup) findViewById(R.id.cord);


    //Replace the above line with the container view i.e.
    //Replace  parentView = (ViewGroup) findViewById(R.id.cord);
    // With parentView = (ViewGroup) findViewById(R.id.<YOUR MAIN VIEW/PARENT CONTAINER>);
    //R.id.cord is R.id.<YOUR MAIN VIEW/PARENT CONTAINER> for me because my Relative Layout 
    // container's name is cord.


    for(int i=0; i < parentView.getChildCount(); i++) {

        childView = parentView.getChildAt(i);
        //The if may change there are other options try them too.
        if(childView.getClass().getName().substring(35).equals("Button")){


            buttons.add((Button)parentView.getChildAt(i));
        }
        /*
        //Else part optional 
        //Remove comment to use
        else
            Log.e("Not","A Button");*/
    }

    for (int i =0;i<buttons.size();i++){
        buttons.get(i).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                //Do the work here
                Log.d("Button Clicked",Integer.toString(view.getId()));
            }
        });
    }





    }
}

这是一种可以解决问题的方法......

答案 1 :(得分:1)

最好的方法:让您的活动实施View.OnClickListener,然后按照以下方式编写onClick方法:

public void onClick(View v) {
    final int id = v.getId();
    switch (id) {
    case R.id.button1:
        // your code for button1 here
        break;
    case R.id.button2:
        // your code for button2 here
        break;
    // even more buttons here
    }
}

然后,在XML布局文件中,您可以使用属性android:onClick:直接设置单击侦听器

<Button
    android:id="@+id/button1"
    android:onClick="onClick"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Button 1" />

答案 2 :(得分:1)

是的,可以通过编程方式在活动级别实现。所以不需要定义&#34; onClick&#34; XML中的属性。

您定义了View.OnClickListener类。例如,

View.OnClickListener buttonListener = new View.OnClickListener() {
         public void onClick(View v) {
             // here you can define different code for different buttons
         };

然后将此监听器附加到一个地方的所有按钮

final Button button = findViewById(R.id.button_id);
     button.setOnClickListener(buttonListener);

答案 3 :(得分:1)

这里是我最终得到的解决方案,它仅适用于touchables,例如TextView并非可触摸:

在java中:

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

    final MainActivity activity = this;
    /* Any kind of ViewGroup that is 
       parent of the common listener views. In the example it is the rootView */
    View rootView = this.getWindow().getDecorView().getRootView();

    // Buttons are touchables
    ArrayList<View> touchables = rootView.getTouchables();

    // Define the common on click listener for the buttons
    View.OnClickListener listener = new View.OnClickListener() {
        public final void onClick(View view) {
            activity.onBtnClick( (Button) view );
        }
    };

    // Iterate trough touchables and if the View is a button assign the listener
    for (View v: touchables) {
        // TODO: omit button if that common listener isn't meant for it
        if(v instanceof Button) {
            v.setOnClickListener(listener);
        }
    }
}

// The listener callback
protected final void onBtnClick(Button btn) {
    String btnStringId = btn.getResources().getResourceEntryName(btn.getId());
}

在Kotlin:

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)

    /* Any kind of ViewGroup that is 
       parent of the common listener views. In the example it is the rootView */
    val rootView = window.decorView.rootView
    val touchables = rootView.touchables
    val listener = View.OnClickListener {
        onBtnClick(it as Button)
    }
    touchables.forEach { if (it is Button) {
        it.setOnClickListener(listener)
    }}
}

protected fun onBtnClick(btn: Button) {
    var btnStringId = btn.getResources().getResourceEntryName(btn.id)
}