Drupad Singh
Drupad Singh

Reputation: 56

my app crashes whenever i click the button

whenever i click the increment button while running the app on my device my app forces unexpectedly this is my activity_main.xml code

    <ScrollView
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_height="match_parent"
    android:layout_width="match_parent"
    tools:context=".MainActivity"
    >
    <RelativeLayout
        android:padding="20dp"
        android:layout_height="match_parent"
        android:layout_width="match_parent"
        android:orientation="vertical"
        android:gravity="center_vertical"
        >
        <EditText
            android:id="@+id/name_text_field"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="Name"
            android:inputType="textCapWords"
            ></EditText>
        <TextView
            android:layout_centerVertical="true"
            android:id="@+id/heading1"
            style="@style/HeaderTextStyle"
            android:text="Toppings"
            android:layout_below="@id/name_text_field"
            />
        <CheckBox
            android:layout_below="@id/heading1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/whipped_cream"
            android:textSize="16sp"
            android:paddingLeft="24dp"
            android:layout_marginTop="20dp"
            android:text="Whipped Cream"
            />
        <CheckBox
            android:layout_marginTop="20dp"
            android:layout_below="@id/whipped_cream"
            android:id="@+id/chocolate"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="chocolate"
            android:textSize="16sp"
            android:paddingLeft="24dp"
            />
        <TextView
            android:layout_below="@id/chocolate"
            android:id="@+id/quantity_text_view"
            style="@style/HeaderTextStyle"
            android:text="Quantity"
            android:layout_marginBottom="20dp"
            />
        <Button
            android:layout_below="@id/quantity_text_view"
            android:id="@+id/decrement_button"
            android:layout_width="48dp"
            android:layout_height="48dp"
            android:onClick="decrement"
            android:text="-"
            />
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="48dp"
            android:paddingLeft="10dp"
            android:layout_below="@id/quantity_text_view"
            android:paddingRight="10dp"
            android:textSize="15sp"
            android:layout_toRightOf="@id/decrement_button"
            android:id="@+id/initial_qty"
            android:gravity="center_vertical"
            android:text="1"
            />
        <Button
            android:layout_toRightOf="@id/initial_qty"
            android:layout_below="@id/quantity_text_view"
            android:id="@+id/increment_button"
            android:onClick="increment"
            android:layout_width="48dp"
            android:layout_height="48dp"
            android:text="+"
            />
        <Button
            android:id="@+id/submit_button"
            android:layout_marginTop="20dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="order"
            android:onClick="submitOrder"
            android:gravity="center_vertical"
            android:layout_below="@id/decrement_button"
            />
        <TextView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="20dp"
            android:gravity="center_vertical"
            android:id="@+id/order_summary_text_view"
            android:textAllCaps="true"
            android:textStyle="bold"
            android:textSize="16sp"
            android:layout_below="@id/submit_button"
            />
    </RelativeLayout>

</ScrollView>

and this is my MainActivity.java file

package com.orton.birthdaycard;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.Editable;
import android.util.Log;
import android.view.View;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.TextView;
import java.text.NumberFormat;
public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);
    }
    int quantity=1;
    private void increment(View view)
    {
        if(quantity==100)
            return;
        else
        quantity++;
        displayQuantity(quantity);
    }
    private void decrement(View view)
    {
        if(quantity==1)
            return;
        else
            quantity--;
        displayQuantity(quantity);
    }
    private void displayQuantity(int qty)
    {
        TextView quantityTextView=(TextView) findViewById(R.id.initial_qty);
        quantityTextView.setText(String.valueOf(quantity));
        Log.v("MainActivity","the quantity is " + quantity);
    }
    int basePrice;
    private int calculatePrice(boolean hasWhippedCream,boolean hasChocolate)
    {
        basePrice = 5;
        if(hasWhippedCream==true)
            basePrice += 1;
        if(hasChocolate==true)
            basePrice +=2 ;
        return basePrice=basePrice*quantity;

    }
    String priceMessage="";
    private void submitOrder(View view)
    {
        EditText nameField = (EditText) findViewById(R.id.name_text_field);
        String name = nameField.getText().toString();

        CheckBox whippedCream  = (CheckBox) findViewById(R.id.whipped_cream);
        boolean hasWhippedCream = whippedCream.isChecked();
        CheckBox chocolate = (CheckBox) findViewById(R.id.chocolate);
        boolean hasChocolate = chocolate.isChecked();

        int price=calculatePrice(hasWhippedCream,hasChocolate);
        String orderSummary=createOrderSummary(name,price,hasWhippedCream,hasChocolate);
        displayMessage(orderSummary);
    }
    private void displayMessage(String orderSummary)
    {
        TextView summary= (TextView) findViewById(R.id.order_summary_text_view);
        summary.setText(""+orderSummary);
    }
    private String createOrderSummary(String name, int price, boolean hasWhippedCream, boolean hasChocolate)
    {
        String priceMessage = "Name :" + name;
        if(hasWhippedCream)
        priceMessage += "\nWhipped Cream Added" ;
        if(hasChocolate)
            priceMessage += "\nChocolate Added" ;
        priceMessage+="\nQuantity : "+quantity;
        priceMessage+="\nTotal : $"+price;
        priceMessage+="Thank You!" ;
        return priceMessage;
    }

}

this is debugging report 05-23 22:14:45.695 29736-29736/com.orton.birthdaycard E/AndroidRuntime: FATAL EXCEPTION: main Process: com.orton.birthdaycard, PID: 29736 java.lang.IllegalStateException: Could not find method increment(View) in a parent or ancestor Context for android:onClick attribute defined on view class android.support.v7.widget.AppCompatButton with id 'increment_button' at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.resolveMethod(AppCompatViewInflater.java:327) at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:284) at android.view.View.performClick(View.java:5612) at android.view.View$PerformClick.run(View.java:22285) at android.os.Handler.handleCallback(Handler.java:751) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:154) at android.app.ActivityThread.main(ActivityThread.java:6123) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:757)

Upvotes: -1

Views: 92

Answers (2)

Quick learner
Quick learner

Reputation: 11457

Do this

increment_button.setOnClickListener(new View.OnClickListener() {
             public void onClick(View v) {
                 // Perform action on click
             }
         });

instead of android:onClick="increment"

Upvotes: 0

Luiz Fernando Salvaterra
Luiz Fernando Salvaterra

Reputation: 4182

Your method must use the public modifier:

public void increment(View view)
    {
        if(quantity==100)
            return;
        else
        quantity++;
        displayQuantity(quantity);
    }

Upvotes: 2

Related Questions