Desarrollador de aplicaciones de Android, selector de números personalizado para API nivel 8

StackOverflow https://stackoverflow.com//questions/23061544

  •  26-12-2019
  •  | 
  •  

Pregunta

Estoy intentando crear un selector de números personalizado para aplicaciones que requieren un mínimo de nivel API 8. Hasta ahora obtuve este código, es simple pero no sé cómo solucionar este error.

El código hasta ahora es este:

paquete com.ejemplo.symbol_temp;

import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class MainActivity extends ActionBarActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Integer counter=0;
        Button add,sub;
        final TextView display;

        add = (Button) findViewById(R.id.plus);
        sub = (Button) findViewById(R.id.minus);
        display = (TextView) findViewById(R.id.showtemperature);

        add.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
            counter++;
            display.setText( "" + counter);
            }
        });

        sub.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
            counter--;
            display.setText( "" + counter);
            }
        });

        }

}

y el XML es este:

<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.example.symbol_temp.MainActivity$PlaceholderFragment" >

    <TextView
        android:id="@+id/showtemperature"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:textAppearance="?android:attr/textAppearanceLarge" />

    <Button
        android:id="@+id/minus"
        style="?android:attr/buttonStyleSmall"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@+id/showtemperature"
        android:layout_centerHorizontal="true"
        android:text="+" 
        android:onClick="add"/>

    <Button
        android:id="@+id/plus"
        style="?android:attr/buttonStyleSmall"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/minus"
        android:layout_below="@+id/showtemperature"
        android:text="-" />

</RelativeLayout>

Obteniendo esto en LogCat:

04-14 13:31:59.222: E/AndroidRuntime(359): FATAL EXCEPTION: main
04-14 13:31:59.222: E/AndroidRuntime(359): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.symbol_temp/com.example.symbol_temp.MainActivity}: java.lang.NullPointerException
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.os.Handler.dispatchMessage(Handler.java:99)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.os.Looper.loop(Looper.java:123)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.ActivityThread.main(ActivityThread.java:4627)
04-14 13:31:59.222: E/AndroidRuntime(359):  at java.lang.reflect.Method.invokeNative(Native Method)
04-14 13:31:59.222: E/AndroidRuntime(359):  at java.lang.reflect.Method.invoke(Method.java:521)
04-14 13:31:59.222: E/AndroidRuntime(359):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
04-14 13:31:59.222: E/AndroidRuntime(359):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
04-14 13:31:59.222: E/AndroidRuntime(359):  at dalvik.system.NativeStart.main(Native Method)
04-14 13:31:59.222: E/AndroidRuntime(359): Caused by: java.lang.NullPointerException
04-14 13:31:59.222: E/AndroidRuntime(359):  at com.example.symbol_temp.MainActivity.onCreate(MainActivity.java:24)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
04-14 13:31:59.222: E/AndroidRuntime(359):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
04-14 13:31:59.222: E/AndroidRuntime(359):  ... 11 more

Creo que he cambiado algunas cosas, la línea número 24 es esta:

add.setOnClickListener(new View.OnClickListener() {

Gracias por su ayuda.

¿Fue útil?

Solución

De tu comentario y

tools:context="com.example.symbol_temp.MainActivity$PlaceholderFragment"

Supongo que las vistas pertenecen a fragment_main.xml.

Inflas el diseño incorrecto.Y estás buscando la vista en el diseño incorrecto.

Cambia esto

setContentView(R.layout.activity_main);

a

setContentView(R.layout.fragment_main);

También cambia esto

Integer counter=0;

a

int counter; // primitive data type
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
     counter =0;

Otros consejos

La variable de su contador se declara dentro del método, por eso, cuando lo intenta, mueva sus variables por encima del método OnCreate.

Note:
Esta respuesta se publica como respuesta para comentar publicado por persona que hizo esta pregunta.He publicado esto como respuesta para la brevedad

Utilice este método
protected void onSaveInstanceState(Bundle savedInstance) { super.onSaveInstanceState(savedInstance); savedInstance.putInt("myCounter",counter); }
luego en

  onCreate(Bundle savedInstanceState){ 
  if(savedInstanceState != null)
  counter = savedInstanceState.getInt("myCounter")}


de SavedInstance que es objeto de clase de paquete Puede recuperar su valor guardado y asignarlo en Crear.Recuerde verificar si el valor es nulo, porque si ejecuta su aplicación la primera vez que su contador puede no ser instanciado aún y lanzará excepción.
También cuando se retorces a SavedValues, asegúrate de no sobresucharlos.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top