简体   繁体   中英

Android app doesn't start up on the device in eclipse

Basically when i run the app, it crashes, this is my code, and i don't understand what am i doing wrong. i know it's something to do with the "answer" variable

sqlAnswer = (EditText)findViewById(R.id.ans1);

This is my code for MainActivity: i also took out the answer, because it comes up with an error, i think it's because the button that makes the calculation is not giving out the same output, and it's basically renaming a TextView from the XML.

public class MainActivity extends Activity implements OnClickListener {

Button sqlUpdate, sqlView;
EditText sqlNumber1, sqlNumber2, sqlAnswer;

@Override
protected void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    sqlUpdate = (Button) findViewById(R.id.bSQLUpdate);
    sqlNumber1 = (EditText)findViewById(R.id.num1input);
    sqlNumber2 = (EditText)findViewById(R.id.num2input);
    sqlAnswer = (EditText)findViewById(R.id.ans1);

    sqlView = (Button) findViewById(R.id.bSQLopenView);
    sqlView.setOnClickListener(this);
    sqlUpdate.setOnClickListener(this);

}

public void onClick(View arg0) {

    switch (arg0.getId()){
    case R.id.bSQLUpdate:
        boolean didItWork = true;
        try{
        String number_one = sqlNumber1.getText().toString();
        String number_two = sqlNumber2.getText().toString();
        String answer = sqlAnswer.getText().toString();

        DBA entry = new DBA(MainActivity.this);

        entry.open();

        entry.createEntry(number_one, number_two);

        entry.close();
        } catch (Exception e) {
            e.printStackTrace();
                            didItWork = false;
        }finally{
            if (didItWork){
                Dialog d = new Dialog(this);
                d.setTitle("It Worked");
                TextView tv = new TextView(this);
                tv.setText("Success!");
                d.setContentView(tv);
                d.show();
            }
        }
        break;
    case R.id.bSQLopenView:
        Intent i = new Intent("com.cmpcione.calculator.SQLVIEW");
        startActivity(i);
        break;
    }
}

public void sum(View v) {
    EditText number1input = (EditText)findViewById(R.id.num1input);
    EditText number2input = (EditText)findViewById(R.id.num2input);

    Integer num1=Integer.parseInt(number1input.getText().toString()),num2=Integer.parseInt(number2input.getText().toString());

    Integer ans1=num1+num2;

    TextView answer=(TextView)findViewById(R.id.ans1);

    answer.setText(ans1.toString());

}

The code for the class DBA:

public class DBA {

public static final String KEY_ROWID = "_id";
public static final String KEY_NUMBER1 = "num1input";
public static final String KEY_NUMBER2 = "num2input";
public static final String KEY_ANSWER = "ans1";


private static final String DATABASE_NAME = "CalculationsDB";
private static final String DATABASE_TABLE = "Calculation_table";
private static final int DATABASE_VERSION = 2;

private DbHelper ourHelper;
private final Context ourContext;
private SQLiteDatabase ourDatabase;

private static class DbHelper extends SQLiteOpenHelper{

    public DbHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
        // TODO Auto-generated constructor stub
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        //creates table and rows
        db.execSQL("CREATE TABLE " + DATABASE_TABLE + " (" +

                KEY_ROWID + " INTEGER PRIMARY KEY, " + 
                KEY_NUMBER1 + " TEXT NOT NULL, " + 
                KEY_NUMBER2 + " TEXT NOT NULL, " +
                KEY_ANSWER + " TEXT NOT NULL);" 
                );
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub
        db.execSQL("DROP TABLE IF EXISTS " + DATABASE_TABLE);
        onCreate(db);
    }

}

public DBA(Context c){
    ourContext = c;
}

public DBA open() {
    ourHelper = new DbHelper(ourContext);
    ourDatabase = ourHelper.getWritableDatabase();
    return this;
}

public void close() {
    ourHelper.close();

}

public long createEntry(String number_one, String number_two) {
    // TODO Auto-generated method stub
    ContentValues cv = new ContentValues();
    cv.put(KEY_NUMBER1, number_one);
    cv.put(KEY_NUMBER2, number_two);
    cv.put(KEY_ANSWER, answer);
    return ourDatabase.insert(DATABASE_TABLE, null, cv);

}

public String getData() {
    // TODO Auto-generated method stub
    String[] columns = new String[]{KEY_ROWID, KEY_NUMBER1, KEY_NUMBER2};
    //using the cursor to read from database
    Cursor c = ourDatabase.query(DATABASE_TABLE, columns, null, null, null, null, null);
    String result = " ";

    int iRow = c.getColumnIndex(KEY_ROWID);
    int iNumber1 = c.getColumnIndex(KEY_NUMBER1);
    int iNumber2 = c.getColumnIndex(KEY_NUMBER2);
    int iAnswer = c.getColumnIndex(KEY_ANSWER);

    for (c.moveToFirst(); !c.isAfterLast(); c.moveToNext()) {
        //it gets the string of our index then it gets the first number and then the last
        result = result + c.getString(iRow) + " " + c.getString(iNumber1) + " " + c.getString(iNumber2) + "\n";
    }
    return null;


}

}

The activity_main.xml is the following, i have a few buttons on here which you can see:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.cmpcione.calculator.MainActivity$PlaceholderFragment" >

<LinearLayout
    android:id="@+id/linearLayout1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_alignParentBottom="true"
    android:layout_alignParentLeft="true"
    android:layout_alignParentRight="true"
    android:layout_alignParentTop="true"
    android:orientation="vertical" >

    <TextView
        android:id="@+id/num1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/num1" />

    <EditText
        android:id="@+id/num1input"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:ems="10" >

    </EditText>

    <TextView
        android:id="@+id/num2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/num2" />

    <EditText
        android:id="@+id/num2input"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:ems="10" />

    <Button
        android:id="@+id/calc_sum"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="sum"
        android:text="@string/calc_sum" />

    <Button
        android:id="@+id/calc_sub"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="substract"
        android:text="@string/calc_sub" />

    <Button
        android:id="@+id/calc_mul"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="multiply"
        android:text="@string/calc_mul" />

    <Button
        android:id="@+id/calc_div"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="divide"
        android:text="@string/calc_div" />

    <TextView
        android:id="@+id/ans2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingBottom="5dp"
        android:text="@string/answer" />

    <Button
        android:id="@+id/bSQLUpdate"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Update Database" />

    <Button
        android:id="@+id/bSQLopenView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="View Database" />

</LinearLayout>

<TextView
    android:id="@+id/ans1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/linearLayout1"
    android:layout_marginBottom="132dp"
    android:layout_marginLeft="139dp"
    android:text="@string/ans" />

 </RelativeLayout>

The full list of logcat: it's starting with not being able to insert the numbers to the database:

04-11 17:57:48.177: E/AndroidRuntime(278): FATAL EXCEPTION: main
04-11 17:57:48.177: E/AndroidRuntime(278): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.cmpcione.calculator/com.cmpcione.calculator.MainActivity}: java.lang.ClassCastException: android.widget.TextView
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.os.Handler.dispatchMessage(Handler.java:99)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.os.Looper.loop(Looper.java:123)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.ActivityThread.main(ActivityThread.java:4627)
04-11 17:57:48.177: E/AndroidRuntime(278):  at java.lang.reflect.Method.invokeNative(Native Method)
04-11 17:57:48.177: E/AndroidRuntime(278):  at java.lang.reflect.Method.invoke(Method.java:521)
04-11 17:57:48.177: E/AndroidRuntime(278):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
04-11 17:57:48.177: E/AndroidRuntime(278):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
04-11 17:57:48.177: E/AndroidRuntime(278):  at dalvik.system.NativeStart.main(Native Method)
04-11 17:57:48.177: E/AndroidRuntime(278): Caused by: java.lang.ClassCastException: android.widget.TextView
04-11 17:57:48.177: E/AndroidRuntime(278):  at com.cmpcione.calculator.MainActivity.onCreate(MainActivity.java:27)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
04-11 17:57:48.177: E/AndroidRuntime(278):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)

ans1 is the id of TextView

<TextView
android:id="@+id/ans1"

So change this

sqlAnswer = (EditText)findViewById(R.id.ans1);

To

TextView sqlAnswer =(TextView)findViewById(R.id.ans1);

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM