У меня есть два файла main.xml в папках layout-land и layout-port, и когда ориентация телефона меняется, он вызывает перезагрузку main.xml.
@Override
public void onConfigurationChanged(Configuration configure){
super.onConfigurationChanged(configure);
setContentView(R.layout.main);
Работает нормально в портретной ориентации, но нажатие любой кнопки изображения на странице в альбомной ориентации приводит к сбою приложения. Все кнопки изображения при нажатии изменяют изображение с именем grid на другое изображение. Кнопки, открывающие другую страницу, отлично работают в обоих макетах. Вот пример кода.
final ImageView imageView = (ImageView)findViewById(R.id.grid);
// This is an imagebutton
findViewById(R.id.plank).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
imageView.setImageResource(R.drawable.gridplanks);
}
});
// This is a button that brings up a new page
findViewById(R.id.mcg).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
startActivity(new Intent("com.example.minecraftcraftingguide.MCG"));
}
});
Это то, что тебе нужно? Извините, новичок в программировании.
>09-18 22:20:46.688: ERROR/AndroidRuntime(334): FATAL EXCEPTION: main
09-18 22:20:46.688: ERROR/AndroidRuntime(334): java.lang.NullPointerException
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at com.example.minecraftcraftingguide.Menu$1.onClick(Menu.java:27)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at android.view.View.performClick(View.java:2485)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at android.view.View$PerformClick.run(View.java:9080)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at android.os.Handler.handleCallback(Handler.java:587)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at android.os.Handler.dispatchMessage(Handler.java:92)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at android.os.Looper.loop(Looper.java:123)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at android.app.ActivityThread.main(ActivityThread.java:3683)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at java.lang.reflect.Method.invokeNative(Native Method)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at java.lang.reflect.Method.invoke(Method.java:507)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
09-18 22:20:46.688: ERROR/AndroidRuntime(334): at dalvik.system.NativeStart.main(Native Method)