0

私のチップ計算機は、入力した2つのテキストフィールドでのみ機能します。メッセージを表示して、アプリが強制終了されないようにします...

これが私が試したJavaですが、機能しません

  package tip.calculator;


import android.os.Bundle;
import android.app.Activity;
import android.text.TextUtils;
import android.view.View.OnClickListener;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;
import android.view.View;
import android.widget.Button;




public class TipCalculator extends Activity 
{

private Button enter;
EditText myEditField ;
EditText myEditField2;
float percentage = 0;
float percentageInp = 0;
float billAmount = 0;
double output = 0; 
String output1 = "";
Button clearButton ;
TextView textView;

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    myEditField = (EditText) findViewById(R.id.percentText);
    enter = (Button)findViewById(R.id.button1);
    myEditField2 = (EditText) findViewById(R.id.billText);
    clearButton = (Button) findViewById(R.id.clearButton);


    enter.setOnClickListener(new OnClickListener() {


        public void onClick(View v) {

             TextView errors;
             textView = (TextView) findViewById(R.id.textView1);
             errors = (TextView) findViewById(R.id.errorText);    



             if((myEditField2 != null) && (!TextUtils.isEmpty(myEditField2.getText().toString()))){


                percentageInp = Float.parseFloat(myEditField.getText().toString());
                billAmount = Float.parseFloat(myEditField2.getText().toString());

                percentage = ((float)percentageInp /100);

                output = (double)(billAmount * percentage);

                double result = output * 100;
                result = Math.round(result);
                result = result / 100;

                output1 = Double.toString(result);

                textView.setText(output1 + " $");

             } else{
                //Toast.makeToast(.....).show(); //Inform user about the error
             }

        }
    });

    clearButton.setOnClickListener(new OnClickListener() {

        public void onClick(View arg0) {

            percentage = 0;
            output = 0;
            output1 = "";

            TextView textView = (TextView)findViewById(R.id.errorText);
            textView.setText("");

            TextView textView2 = (TextView)findViewById(R.id.percentText);
            textView2.setText("");

            TextView textView3 = (TextView)findViewById(R.id.billText);
            textView3.setText("");


            TextView textView1 = (TextView)findViewById(R.id.textView1);
            textView1.setText("");


            percentageInp = 0;
            billAmount = 0;

            myEditField.clearComposingText();
            myEditField2.clearComposingText();

        }


    });
}
}

これがスタックトレースで、更新されたJavaは上にあります

08-01 21:24:17.824: E/AndroidRuntime(19302): FATAL EXCEPTION: main
08-01 21:24:17.824: E/AndroidRuntime(19302): java.lang.ClassCastException: android.widget.RelativeLayout cannot be cast to android.widget.TextView
08-01 21:24:17.824: E/AndroidRuntime(19302):    at tip.calculator.TipCalculator$1.onClick(TipCalculator.java:48)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at android.view.View.performClick(View.java:3620)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at android.view.View$PerformClick.run(View.java:14292)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at android.os.Handler.handleCallback(Handler.java:605)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at android.os.Handler.dispatchMessage(Handler.java:92)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at android.os.Looper.loop(Looper.java:137)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at android.app.ActivityThread.main(ActivityThread.java:4507)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at java.lang.reflect.Method.invokeNative(Native Method)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at java.lang.reflect.Method.invoke(Method.java:511)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
08-01 21:24:17.824: E/AndroidRuntime(19302):    at dalvik.system.NativeStart.main(Native Method)
4

2 に答える 2

1

テキストフィールドのnullをチェックすることは問題ではありません。ただし、テキストの空の文字列とnullを確認する必要があります。この場合、 android.text.TextUtis.isEmpty()http://developer.android.com/reference/android/text/TextUtils.html#isEmpty (java.lang.CharSequence )が便利です。また、入力した文字列がフロートであることを確認する必要があります。したがって、try catchを実行して解析エラーをキャプチャし、テキストフィールドのandroid:inputTypeプロパティをnumberDecimalに設定して、入力がfloatであることを確認する必要もあります。

したがって:

  1. レイアウトにプロパティを追加android:inputType="numberDecimal" して、ユーザーが有効な10進数のみを入力できるようにします。
  2. すべての安全チェックを行う
    if((myEditField2!= null)&&(!TextUtils.isEmpty(myEditField2.getText()。toString()))){
        //ここでデータを使用します
    } そうしないと{
       Toast.makeToast(.....)。show()//エラーについてユーザーに通知
    }

1を行う場合は Float.parseFloat(myEditField.getText().toString()) 、トライキャッチで囲む必要がない場合があります。NumberFormatException

于 2012-08-02T02:56:15.973 に答える
0

編集テキストの文字列が空でないことを確認する場合は、次を使用できます。

if(et.getText().toString() != null){

}
于 2012-08-02T02:49:23.837 に答える