активность Android падает без причины? может быть, из-за setcontentview?

#android-activity #crash

#android-активность #сбой

Вопрос:

у меня проблема с разработкой Android (кстати, я новичок)..

я пытаюсь выполнить это руководство: http://developer.android.com/training/basics/firstapp/starting-activity.html , за исключением того, что моя проблема заключается в том, что второе действие систематически выходит из строя, и я не знаю почему..

когда я комментирую строку: setContentView(textView1): второе действие не завершается сбоем, но текст не отображается. так что, я думаю, в этом и заключается моя проблема, но я искал часами, и, похоже, я не могу понять это: -s

вот мой код :

(основное действие) XML-макет : :

     <RelativeLayout "
    android:id="@ id/texttoto"
    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.toto.MainActivity$PlaceholderFragment" >

    <TextView
        android:id="@ id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

    <Button
        android:id="@ id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@ id/editText_mail"
        android:layout_alignLeft="@ id/editText_mail"
        android:onClick="test_trucs"
        android:text="@string/test" />

    <EditText
        android:id="@ id/txttopass"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@ id/textView1"
        android:layout_below="@ id/textView1"
        android:layout_marginTop="15dp"
        android:ems="10"
        android:hint="@string/texttopass" >
    </EditText>

</RelativeLayout>
 

** (второе действие) XML-макет: *: *

  <RelativeLayout "
    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.toto.Blabla$PlaceholderFragment" >

    <TextView
        android:id="@ id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

</RelativeLayout>
 

****MainActivity.JAVA:****

     package com.toto;

import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.app.ActionBarActivity;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends ActionBarActivity {
    public final static String EXTRA_MESSAGE = "com.toto.MESSAGE";

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

        if (savedInstanceState == null) {
            getSupportFragmentManager().beginTransaction()
                    .add(R.id.container, new PlaceholderFragment())
                    .commit();
        }
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {

        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    /**
     * A placeholder fragment containing a simple view.
     */
    public static class PlaceholderFragment extends Fragment {

        public PlaceholderFragment() {
        }

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                Bundle savedInstanceState) {
            View rootView = inflater.inflate(R.layout.fragment_main, container, false);
            return rootView;
        }
    }
    /** mettre les class ICI **/
    public void test_trucs(View view) {
        Intent intent = new Intent(this, Blabla.class);
        EditText editText = (EditText) findViewById(R.id.txttopass);
        String message = editText.getText().toString();
        intent.putExtra(EXTRA_MESSAGE, message);
        startActivity(intent);
    }

}
 

****Blabla.JAVA:****

 package com.toto;

import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v7.app.ActionBarActivity;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

public class Blabla extends ActionBarActivity {

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

        if (savedInstanceState == null) {
            getSupportFragmentManager().beginTransaction()
                    .add(R.id.container, new PlaceholderFragment()).commit();
        }

      // Get the message from the intent
      Intent intent = getIntent();
      String message = intent.getStringExtra(MainActivity.EXTRA_MESSAGE);
      // Create the text view
      TextView textView1 = new TextView(this);
      textView1.setTextSize(40);
      textView1.setText(message);

      // Set the text view as the activity layout
      setContentView(textView1);

    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {

        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.blabla, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    /**
     * A placeholder fragment containing a simple view.
     */
    public static class PlaceholderFragment extends Fragment {

        public PlaceholderFragment() {
        }

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                Bundle savedInstanceState) {
            View rootView = inflater.inflate(R.layout.fragment_blabla,
                    container, false);
            return rootView;
        }
    }

}
 

лог-кот показывает это :

 06-19 15:35:47.982: E/AndroidRuntime(22378): FATAL EXCEPTION: main
06-19 15:35:47.982: E/AndroidRuntime(22378): Process: com.toto, PID: 22378
06-19 15:35:47.982: E/AndroidRuntime(22378): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.toto/com.toto.Blabla}: java.lang.NullPointerException
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2184)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2233)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.ActivityThread.access$800(ActivityThread.java:135)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.os.Handler.dispatchMessage(Handler.java:102)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.os.Looper.loop(Looper.java:136)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.ActivityThread.main(ActivityThread.java:5001)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at java.lang.reflect.Method.invokeNative(Native Method)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at java.lang.reflect.Method.invoke(Method.java:515)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at dalvik.system.NativeStart.main(Native Method)
06-19 15:35:47.982: E/AndroidRuntime(22378): Caused by: java.lang.NullPointerException
06-19 15:35:47.982: E/AndroidRuntime(22378):    at com.toto.Blabla.onCreate(Blabla.java:39)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.Activity.performCreate(Activity.java:5231)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
06-19 15:35:47.982: E/AndroidRuntime(22378):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2148)
06-19 15:35:47.982: E/AndroidRuntime(22378):    ... 11 more
 

я знаю, что это, вероятно, самая новая вещь, но, пожалуйста, будьте снисходительны..

заранее спасибо за помощь!

Комментарии:

1. Можете ли вы точно указать, какая это строка -> Blabla.java:39)

2. Спасибо , что обратили внимание на мою проблему .

Ответ №1:

Вы вызываете setContentView дважды, первый:

 setContentView(R.layout.activity_blabla);
 

Этого нет в руководстве. Я не уверен, что именно вызывает исключение NullPointer, но кажется, что вызов этого дважды может вызвать проблемы.

Если вы хотите использовать более сложный макет (R.layout_blabla) и показать сообщение, как это похоже на ваш случай, поскольку текстовое представление находится в этом макете, ссылайтесь на него из onCreate с помощью findViewById вместо создания нового TextView

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

    if (savedInstanceState == null) {
        getSupportFragmentManager().beginTransaction()
                .add(R.id.container, new PlaceholderFragment()).commit();
    }

  // Get the message from the intent
  Intent intent = getIntent();
  String message = intent.getStringExtra(MainActivity.EXTRA_MESSAGE);
  // Create the text view
  TextView textView1 = (TextView)findViewById(R.id.textView1)
  textView1.setTextSize(40);
  textView1.setText(message);

  // Set the text view as the activity layout
  setContentView(textView1);

}
 

Комментарии:

1. Да!! это было так . чтобы не использовать setContentView дважды и не создавать textview1, потому что он уже есть в макете. большое спасибо, чувак! теперь я чувствую себя примерно так : 38.media.tumblr.com/871077f6830726fec33a94ead171517d /… благодаря вам 🙂

2. на самом деле, я только что понял, что была вторая вещь, которую я должен был исправить: сначала я создал textview1 в fragment_blabla.xml . в то время как я должен был создать его в activity_blabla.xml . это тоже было частью проблемы.