AndroidStudio(java環境)で入力された値が数字であるかを判定して数字ならそのまま計算処理に回し、数字以外なら初期値0として計算処理を行うプログラムを課題で作っています。
下コードではEditTextから値を取ってくる時に初期化されていないと言われるためSpannableStringBuilderを使って無理やりしています。このやり方が良いかは別として//---から//---部分のコードが冗長ですし同じことを繰り返しているのでメソッドを用いて簡潔に処理したいです。色々試しましたが上手くいかないためご教授頂けたらと思います。
public class MainActivity extends AppCompatActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout linearLayout = new LinearLayout(this); linearLayout.setOrientation(LinearLayout.VERTICAL); setContentView(linearLayout); final TextView textView = new TextView(this); textView.setText("answer"); linearLayout.addView(textView, new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); final EditText et1 = new EditText(this); et1.setText(""); final EditText et2 = new EditText(this); et2.setText(""); final EditText et3 = new EditText(this); et3.setText(""); final EditText et4 = new EditText(this); et4.setText(""); linearLayout.addView(et1, new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); linearLayout.addView(et2, new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); linearLayout.addView(et3, new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); linearLayout.addView(et4, new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); Button calcSum=new Button(this); calcSum.setText("Sum"); linearLayout.addView(calcSum,new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); calcSum.setOnClickListener(new View.OnClickListener(){ @Override public void onClick(View v){ Calculater calc=new Calculater(); //ここからの処理を短くしたいです SpannableStringBuilder sb=(SpannableStringBuilder)et1.getText(); if(CheckNumber(sb.toString()))calc.a=Integer.parseInt(sb.toString()); sb=(SpannableStringBuilder)et2.getText(); if(CheckNumber(sb.toString()))calc.b=Integer.parseInt(sb.toString()); sb=(SpannableStringBuilder)et3.getText(); if(CheckNumber(sb.toString()))calc.c=Integer.parseInt(sb.toString()); sb=(SpannableStringBuilder)et4.getText(); if(CheckNumber(sb.toString()))calc.d=Integer.parseInt(sb.toString()); //ここまで calc.ans=0; calc.CalcSum(); String ans=calc.GetAnswerString(); textView.setText(ans); } }); Button calcMax=new Button(this); calcMax.setText("Max"); linearLayout.addView(calcMax,new LinearLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT)); calcMax.setOnClickListener(new View.OnClickListener(){ @Override public void onClick(View v){ Calculater calc=new Calculater();
//ここも同様かと思いますが
SpannableStringBuilder sb=(SpannableStringBuilder)et1.getText();
if(CheckNumber(sb.toString()))calc.a=Integer.parseInt(sb.toString());
sb=(SpannableStringBuilder)et2.getText();
if(CheckNumber(sb.toString()))calc.b=Integer.parseInt(sb.toString());
sb=(SpannableStringBuilder)et3.getText();
if(CheckNumber(sb.toString()))calc.c=Integer.parseInt(sb.toString());
sb=(SpannableStringBuilder)et4.getText();
if(CheckNumber(sb.toString()))calc.d=Integer.parseInt(sb.toString());
//ここまで
calc.ans=0;
calc.CalcMax();
String ans=Integer.toString(calc.ans);
textView.setText(ans);
}
});
}
private boolean CheckNumber(String _num){
try {
Integer.parseInt(_num);
return true;
}catch (NumberFormatException e){
return false;
}
}
}
別クラスCalculater.java
public class Calculater {
int a=0;
int b=0;
int c=0;
int d=0;
int ans=0;
public String GetAnswerString(){
return Integer.toString(ans);
}
public int CalcSum() {
ans = a + b + c + d;
return ans;
}
public int CalcMax(){
ans=a;
if(a<b){ans=b;}
if(b<c){ans=c;}
if(c<d){ans=d;}
return ans;
}
}
あなたの回答
tips
プレビュー