2012-10-18 5 views
1

저는 Java와 Android를 처음 접했습니다. 실린더의 액체 양을 계산 한 다음 텍스트 뷰 상자에 결과를 반환하는 앱을 만들려고합니다. 그러나 지금 계산 버튼을 클릭하면 충돌이 발생하고 내가 무엇을 놓치고 있는지 알 수 없습니다. 모든 것이 잘 컴파일됩니다. 여기 android.widget.Button의 치명적인 예외

package com.somename.fuel.volume.calculator; 

import android.os.Bundle; 
import android.view.View; 
import android.widget.Button; 
import android.widget.EditText; 
import android.widget.TextView; 
import android.app.Activity; 

public class CalculateCylinder extends Activity { 

EditText length, width, height, depth; 
TextView result; 
Button calculate; 
double firstNum, secNum, thirdNum, volume, area; 
double liqVolume; 
double radius; 
double a, l, aSide,aTop,b,Arc,FluidSurfaceAreaTotal,r,d,v,h,fsal; 

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

    calculate = (Button) findViewById(R.id.buttonCylCalc); 

    length = (EditText) findViewById(R.id.editCylLength); 
    height = (EditText) findViewById(R.id.editCylHeight); 
    depth = (EditText) findViewById(R.id.editCylDepth); 
    result = (TextView) findViewById(R.id.buttonCylResult); 

    calculate.setOnClickListener(new View.OnClickListener() { 

     public void onClick(View v) { 
      // TODO Auto-generated method stub 
      //Toast.makeText(getApplicationContext(), (CharSequence) result, Toast.LENGTH_LONG).show(); 
      try { 
       calculate(); 
      } catch (Exception e) { 
       e.printStackTrace(); 
      } 
      result.setText((CharSequence) result); 
     } 

     public TextView calculate() throws Exception { 
      // TODO Auto-generated method stub 
      double firstNum = Double.valueOf(length.getText().toString()); 
      double secNum = Double.valueOf(height.getText().toString()); 
      double thirdNum = Double.valueOf(depth.getText().toString()); 

      radius = (secNum/2); 
      area = ((secNum*secNum)*3.14); 
      //liqVolume = (firstNum) * (radius*radius)(acos(radius-depth/radius)) 
      // Cubic Volume 

      v = aSide * l; 
      // Fluid surface Area, Side 
      aSide = (r*r)*(3.14/2 -Math.acos(1-h/r)) - (r-h)*Math.sqrt(h*(2*r-h)); 
      // Fluid Surface Area Top 
      aTop = 2*Math.sqrt((r*r)-((r-h)*(r-h) * l)); 
      // Fluid Surface Area Bottom 
      b = fsal*l; 
      // Fluid Surface Area Total 
      FluidSurfaceAreaTotal = 2*aSide+aTop+b; 
      // Cylinder Radius 
      r = d/2; 
      // Cylinder Diameter 
      d = 2*r; 
      if (h <= r) 
       // Fluid Side Arc Length 
       fsal = 2*r*Math.acos((r-h)/r); 

      else if (h > r) 
       fsal = 2*r*(3.14-Math.acos((h-r)/r)); 
      return result; 
      } 


    }); 
} 

} 

는 로그 캣입니다 :

10-18 05:24:38.893: E/AndroidRuntime(964): FATAL EXCEPTION: main 
10-18 05:24:38.893: E/AndroidRuntime(964): java.lang.ClassCastException: android.widget.Button 
10-18 05:24:38.893: E/AndroidRuntime(964): at com.dbryant423.fuel.volume.calculator.CalculateCylinder$1.onClick(CalculateCylinder.java:55) 
10-18 05:24:38.893: E/AndroidRuntime(964): at android.view.View.performClick(View.java:2408) 
10-18 05:24:38.893: E/AndroidRuntime(964): at android.view.View$PerformClick.run(View.java:8816) 
10-18 05:24:38.893: E/AndroidRuntime(964): at android.os.Handler.handleCallback(Handler.java:587) 
10-18 05:24:38.893: E/AndroidRuntime(964): at android.os.Handler.dispatchMessage(Handler.java:92) 
10-18 05:24:38.893: E/AndroidRuntime(964): at android.os.Looper.loop(Looper.java:123) 
10-18 05:24:38.893: E/AndroidRuntime(964): at android.app.ActivityThread.main(ActivityThread.java:4627) 
10-18 05:24:38.893: E/AndroidRuntime(964): at java.lang.reflect.Method.invokeNative(Native Method) 
10-18 05:24:38.893: E/AndroidRuntime(964): at java.lang.reflect.Method.invoke(Method.java:521) 
10-18 05:24:38.893: E/AndroidRuntime(964): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
10-18 05:24:38.893: E/AndroidRuntime(964): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
10-18 05:24:38.893: E/AndroidRuntime(964): at dalvik.system.NativeStart.main(Native Method) 

나는이에 수학을하는 방법을 알아낼하려고 내 머리를 wracking 있었고, 나는 답을 찾을 수 없었습니다 왜 그것이 부서 지는지. 나는 어딘가에 놓친 것이 아마도 단순 할 것이라고 확신한다. 다른 파일에서 더 많은 정보가 필요하면 알려주십시오. 그러나이 파일은 문제가있는 유일한 파일 인 것처럼 보입니다. 또한 아직 사용하지 않은 변수가 있다는 것을 알고 있습니다.

답변

0
result.setText((CharSequence) result); 

이 줄 원인 예외 당신이 안드로이드 View 클래스 CharSequence에 클래스를 캐스팅하기 때문이다.

가능한 해결 방법 : 방법의

변경 반환 형식 public TextView calculate()

public String calculate() 
결과 fsal

방법 public String calculate()반환 문자열에서 지금

그리고

에 버튼의 Click()은 같은 것입니다 ,

calculate.setOnClickListener(new View.OnClickListener() { 
     public void onClick(View v) { 
      // TODO Auto-generated method stub 
      //Toast.makeText(getApplicationContext(), (CharSequence) result, Toast.LENGTH_LONG).show(); 
      String resultValue = ""; 
      try { 
      resultValue = calculate(); 
      } catch (Exception e) { 
       e.printStackTrace(); 
      } 
      result.setText(resultValue); 
     } 
+0

좋아, 그게 작동하지 않았다. 먼저 "v"의 값을 반환하고 그 값을 onClick 메서드의 setText로 설정해야합니다. 문자열의 계산 유형을 변경할 때 "형식 불일치가 발생하여 문자열을 두 개로 변환 할 수 없습니다." – poboy975

+0

'calculate()'의 반환 값을 Double에서 String으로 변경하기 전에 – user370305

+0

글쎄,이'String 최종 결과는 더 이상 오류가 없으며 결과는 0.0 또는()를 반환합니다. 마지막 결과는 Double.valueOf (v) .toString(); \t \t \t \t result.setText (finalresult); NaN .... 그래서 나는 그것이 작동하고 있다고 생각하지만, 어딘가에 나의 수학이 있습니다. 도움을 주셔서 감사합니다. – poboy975

0
result = (TextView) findViewById(R.id.buttonCylResult); 

제대로 캐스팅하고 있습니까? 명명을 기반으로, 나는 당신이 TextView에 단추에서 캐스팅한다고 말할 수 있습니다. 변경하려고 시도,

result = (Button) findViewById(R.id.buttonCylResult); 
+0

글쎄, 나는 버튼에 캐스팅합니다, 그것은 textView 상자보다 더 우수합니다. 그러나 차이를 만드는 것 같지 않습니다. 나, 버튼으로 변경, 여전히 나에게 0.0 또는 NaN 결과를 제공합니다. 그것은 중요하지 않겠지 만? 나는 문자열을 보낼 것이고, textView와 Button 모두 텍스트를 받아 들일 것이다. – poboy975

관련 문제