我已经创建了一个包含两个按钮的布局,下一步和上一步。在按钮之间,我生成了一些动态视图。所以当我第一次启动应用程序时,我想禁用“Previous”按钮,因为不会有任何以前的视图。我还想禁用“下一步”按钮时,没有更多的视图显示。有办法禁用按钮吗?


当前回答

您只需在活动中编写一行代码

Button btn = (Button) findViewById(R.id.button1);
btn.setEnabled(false);

当你想要启用相同的按钮只需写

Button btn = (Button) findViewById(R.id.button1);
btn.setEnabled(true);

其他回答

就我而言,

myButton.setEnabled(false);
myButton.setEnabled(true);

工作正常,它是启用和禁用按钮,因为它应该。但是一旦按钮状态变为禁用,它就再也不会回到启用状态,尽管它是可点击的。我尝试使可绘制状态无效并刷新,但运气不佳。

myButton.invalidate();
myButton.refreshDrawableState();

如果你或任何人有类似的问题,什么工作对我是设置背景绘图再次。适用于任何API级别。

myButton.setEnabled(true);
myButton.setBackgroundDrawable(activity.getResources().getDrawable(R.drawable.myButtonDrawable));

你可以从xml中禁用一个按钮,但那不是动态的。动态禁用按钮的最佳方法是。

myButton.setEnabled(false);

你试过这个吗?

myButton.setEnabled(false); 

更新:感谢格温。几乎忘记了android:clickable可以在XML布局中设置,以确定一个按钮是否可以点击。

在Java中使用setEnabled方法即可。

myButton.setEnabled(false); 

在Kotlin

myButton.enabled = false

错误的方式在监听器中使用变量而不是参数!!

btnSend.setOnClickListener(new OnClickListener() {

    @Override
    public void onClick(View v) {
        btnSend.setClickable(false);

    }
});

正确的方式:

btnSend.setOnClickListener(new OnClickListener() {

    @Override
    public void onClick(View v) {

        /** check given view  by assertion or cast as u wish */
        if(v instance of Button) {

            /** cast */
            Button button = (Button) v;

            /** we can perform some check up */
            if(button.getId() == EXPECTED_ID) {

                /** disable view */
                button.setEnabled(false)            
                button.setClickable(false); 
            }

        } else {

             /** you can for example find desired view by root view  */
             Button bt = (Button) v.getRootView().findViewById(R.id.btId);

             /*check for button */
             if(bt!=null) {

                 /** disable button view */
                 ...
             } else {
                 /** according to @jeroen-bollen remark
                   * we made assumption that we expected a view
                   * of type button here in other any case  
                   */
                  throw new IllegalArgumentException("Wrong argument: " +
                         "View passed to method is not a Button type!");
             }
          }
       }
    });

编辑: 回复@jeroen-bollen

视图。OnClickListener 当单击视图时调用回调的接口定义。 使用方法定义 onClick(查看v);

当视图被单击时,视图类对象使回调方法onClick()发送作为参数本身,所以空视图参数不应该发生,如果它是一个断言错误,它可能发生,例如,当视图对象类被破坏的同时(例如由GC收集)或方法被篡改由于黑客

关于instanceof & null

JLS / 15.20.2。类型比较操作符实例 在运行时,instanceof操作符的结果为true 如果RelationalExpression的值不为空 并且引用可以转换为ReferenceType 而不引发ClassCastException。 否则结果为假。


来自作者的三个字

如果你问为什么?

主要是避免NullPointerException

更多的代码将节省您在代码中跟踪错误的时间,并减少异常的发生。

考虑下面的例子:

View.OnClickListener listener = new OnClickListener() {

    @Override
    public void onClick(View v) {
        btnSend.setClickable(false);

    }
});

btnSend.setOnClickListener(listener)
btnCancel.setOnClickListener(listener)