#android #android-activity #android-view
#Android #android-активность #android-просмотр
Вопрос:
Я просто пытаюсь использовать an intent
для запуска второго действия, и в onCreate
методе второго действия я не уверен, правильно ли я настраиваю свой setContentView()
вид…
onCreate():
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.fragment_display_information);
if (savedInstanceState == null) {
getSupportFragmentManager().beginTransaction()
.add(R.id.container, new PlaceholderFragment()).commit();
}
EditText toTestView = null,
fromTestView = null,
subjectTestView = null,
messageTestView = null;
String recievedToMessage = " ",
recievedFromMessage = " ",
recievedSubjectMessage = " ",
recievedMessage = " " ;
Intent i = getIntent();
Bundle e = i.getExtras();
if (e != null){
recievedToMessage = e.getString(MainActivity.TO_MESSAGE);
recievedFromMessage = e.getString(MainActivity.FROM_MESSAGE);
recievedSubjectMessage = e.getString(MainActivity.SUBJECT_MESSAGE);
recievedMessage = e.getString(MainActivity.MESSAGE);
//setContentView(R.layout.activity_display_information);
toTestView = (EditText) findViewById(R.id.recievedToText);
fromTestView = (EditText) findViewById(R.id.recievedFromText);
subjectTestView = (EditText) findViewById(R.id.recievedSubjectText);
messageTestView = (EditText) findViewById(R.id.recievedMessageText);
toTestView.setText("To: " recievedToMessage);
fromTestView.setText("From: " recievedFromMessage);
subjectTestView.setText("Subject: " recievedSubjectMessage);
messageTestView.setText(recievedMessage);
}
}
У меня есть 2-секундные XML-файлы activity, fragment_display_information.xml
и activity_display_information.xml
на данный момент, когда я пытаюсь перейти на вторую страницу моего приложения, я получаю Unortunately 'Appname' has stopped working.
сообщение, а в LogCat я получаю AndroidRuntime Error
сообщение View could not be found
LogCat:
06-17 07:59:03.020: E/AndroidRuntime(1216): FATAL EXCEPTION: main
06-17 07:59:03.020: E/AndroidRuntime(1216): Process: com.example.multipledatathroughactivitypractice, PID: 1216
06-17 07:59:03.020: E/AndroidRuntime(1216): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.multipledatathroughactivitypractice/com.example.multipledatathroughactivitypractice.DisplayInformation}: java.lang.IllegalArgumentException: No view found for id 0x7f050040 (com.example.multipledatathroughactivitypractice:id/container) for fragment PlaceholderFragment{b2cf4030 #0 id=0x7f050040}
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.ActivityThread.access$800(ActivityThread.java:135)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.os.Handler.dispatchMessage(Handler.java:102)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.os.Looper.loop(Looper.java:136)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.ActivityThread.main(ActivityThread.java:5017)
06-17 07:59:03.020: E/AndroidRuntime(1216): at java.lang.reflect.Method.invokeNative(Native Method)
06-17 07:59:03.020: E/AndroidRuntime(1216): at java.lang.reflect.Method.invoke(Method.java:515)
06-17 07:59:03.020: E/AndroidRuntime(1216): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
06-17 07:59:03.020: E/AndroidRuntime(1216): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
06-17 07:59:03.020: E/AndroidRuntime(1216): at dalvik.system.NativeStart.main(Native Method)
06-17 07:59:03.020: E/AndroidRuntime(1216): Caused by: java.lang.IllegalArgumentException: No view found for id 0x7f050040 (com.example.multipledatathroughactivitypractice:id/container) for fragment PlaceholderFragment{b2cf4030 #0 id=0x7f050040}
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:919)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:570)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1171)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.Activity.performStart(Activity.java:5241)
06-17 07:59:03.020: E/AndroidRuntime(1216): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2168)
06-17 07:59:03.020: E/AndroidRuntime(1216): ... 11 more
Комментарии:
1. Вы должны решить, какой вид показывать, никто не может вам сказать. Но, судя по названию, оно неправильное. Вы выполняете setContentView (R.layout. fragment_display_information); в вашей деятельности…
2. попробуйте этот способ .add(android.R.id.container, new PlaceholderFragment()).commit();
3. Удалить if (savedInstanceState == null) { getSupportFragmentManager().beginTransaction() .add(R.id.container, new PlaceholderFragment()).commit(); }
4. Добавлен Logcat извините за это @SimplePlan
5. на самом деле нет необходимости удалять блок if, поскольку activity сохранит состояние фрагмента, когда он находится в фоновом режиме, а когда дело дойдет до переднего плана, он просто восстановит состояние. Если вы удалите этот блок, будет 2 экземпляра fragment
Ответ №1:
Вам нужно удалить этот код
if (savedInstanceState == null) { getSupportFragmentManager().beginTransaction() .add(R.id.container, new PlaceholderFragment()).commit(); }
и измените это
setContentView(R.layout.activity_display_information);
Комментарии:
1. Большое вам спасибо, это заставило его работать! Для дальнейшего использования не могли бы вы объяснить мне, что на самом деле делает код, который я удалил, и почему он не работал?
2. Вы не должны удалять этот блок кода, иначе у вас будет несколько фрагментов, когда ваша активность перейдет в фоновый режим и вернется. В savedInstance уже будет экземпляр фрагмента.
3. Это не работает, если у меня есть
if
оператор в коде, хотя4. @bbesase если вы хотите использовать
Fragment
, добавьте его в свою активность, используяgetSupportFragmentManager().beginTransaction() .add(android.R.id.container, new PlaceholderFragment()).commit();
, а затем поместите весь свой код в свойFragment
. это добавитFragment
кandroid.R.id.container
5. @bbesase но если вам действительно не нужен этот
Fragment
блок, просто удалите его. поэтому я предложил удалить его.
Ответ №2:
Кажется, что вы раздуваете неправильный макет в activity при создании.Попробуйте, как показано ниже.
setContentView(R.layout.activity_display_information);