Мое приложение на данный момент состоит из 2 действий.
, ОСНОВНАЯ активность с просмотром галереи
, FriendsListActivity с ListView
Когда пользователь отходит от FriendsListActivity с помощью кнопки «Назад» и возвращается к ОСНОВНОМУ действию, в режиме отладки продолжает появляться следующая ошибка.
DalvikVM [localhost: 8676] Тема [<1>
главная] (Приостановлено (исключение
RuntimeException))
ActivityThread.performResumeActivity (IBinder,
булево) строка: 2095
ActivityThread.handleResumeActivity (IBinder,
булево, булево) строка: 2110
BinderProxy (ActivityThread $ H) .handleMessage (Message)
линия: 954
ActivityThread $ H (Handler) .dispatchMessage (Message)
строка: 99 Looper.loop () строка: 123
Строка ActivityThread.main (String []):
3647 Method.invokeNative (Object,
Object [], Class, Class [], Class, int,
булево) строка: не доступно [родной
method] Method.invoke (Объект,
Объект ...) строка: 507
ZygoteInit $ MethodAndArgsCaller.run ()
строка: 839 ZygoteInit.main (String [])
линия: 597
NativeStart.main (String []) строка: не
доступно [нативный метод] Тема
[<8> Binder Thread # 2] (работает)
Нить [<7> Связующая нить # 1]
(Running)
С LogCat
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): ФАТАЛЬНО
ИСКЛЮЧЕНИЕ: главное 03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038):
java.lang.RuntimeException: невозможно
возобновить деятельность
{Com.package.MAIN / com.package.MAIN.MAIN}:
java.lang.NullPointerException 03-13
22: 01: 10,972:
ОШИБКА / AndroidRuntime (1038): в
android.app.ActivityThread.performResumeActivity (ActivityThread.java:2095)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.app.ActivityThread.handleResumeActivity (ActivityThread.java:2110)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.app.ActivityThread $ H.handleMessage (ActivityThread.java:954)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.os.Handler.dispatchMessage (Handler.java:99)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.os.Looper.loop (Looper.java:123)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.app.ActivityThread.main (ActivityThread.java:3647)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
java.lang.reflect.Method.invokeNative (Native
Метод) 03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
java.lang.reflect.Method.invoke (Method.java:507)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:839)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:597)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
dalvik.system.NativeStart.main (Native
Метод) 03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): вызвано:
java.lang.NullPointerException 03-13
22: 01: 10,972:
ОШИБКА / AndroidRuntime (1038): в
com.package.MAIN.MAIN.onResume (MAIN.java:91)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.app.Instrumentation.callActivityOnResume (Instrumentation.java:1149)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.app.Activity.performResume (Activity.java:3833)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): в
android.app.ActivityThread.performResumeActivity (ActivityThread.java:2085)
03-13 22: 01: 10.972:
ОШИБКА / AndroidRuntime (1038): ... 10
более
Дополнительная информация в состояниях панели «Переменные»:
это: ActivityThread
e: NullPointerException
причина: NullPointerException
detailMessage: null
stackTrace: null
r: ActivityThread $ ActivityClientRecord
активность: ГЛАВНАЯ
detailMessage после одного Eclipse Resume: Невозможно возобновить активность (MAIN)
Код из FriendsListActivity выглядит следующим образом
public class FriendsListActivity extends ListActivity {
// ===========================================================
// Fields
// ===========================================================
private ArrayList<Friend> friends = new ArrayList<Friend>();
private FriendsArrayAdapter friendsArrayAdapter;
private ListView listView;
// ===========================================================
// onCreate
// ===========================================================
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.friends_list);
registerForContextMenu(getListView());
setButtonNewFriendClickListener();
}
public void generateFriendsList() {
FriendsService fs = new FriendsService(this);
friends = fs.getFriendsList();
listView = (ListView) findViewById(android.R.id.list);
friendsArrayAdapter = new FriendsArrayAdapter(
this, R.layout.friend_list_item, friends);
listView.setAdapter(friendsArrayAdapter);
}
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
super.onCreateContextMenu(menu, v, menuInfo);
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.friends_context_menu, menu);
}
@Override
public boolean onContextItemSelected(MenuItem item) {
AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo();
FriendsService fs = new FriendsService(this);
Friend f = new Friend();
f = friends.get(info.position);
switch (item.getItemId()) {
case R.id.edit:
Intent i = new Intent(this, FriendEditActivity.class);
i.putExtra("userid", f.userId);
startActivity(i);
return true;
case R.id.delete:
fs.deleteFriend(f.userId);
generateFriendsList();
return true;
default:
return super.onContextItemSelected(item);
}
}
// ===========================================================
// onPause
// ===========================================================
protected void onPause() {
super.onPause();
finish();
}
// ===========================================================
// onResume
// ===========================================================
protected void onResume() {
super.onResume();
generateFriendsList();
}
// ===========================================================
// onStop
// ===========================================================
protected void onStop() {
super.onStop();
}
// ===========================================================
// onDestroy
// ===========================================================
@Override
protected void onDestroy() {
super.onDestroy();
}
// ===========================================================
// Activity methods
// ===========================================================
private void setButtonNewFriendClickListener() {
Button clickButton = (Button)findViewById(R.id.button_add_friend);
clickButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Intent i = new Intent(v.getContext(), FriendNewActivity.class);
startActivity(i);
}
});
}
AndroidManifest выглядит следующим образом
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
android:versionCode="1"
android:versionName="1.0" package="com.package.mypackage">
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<application android:icon="@drawable/icon" android:label="@string/app_name">
<activity android:name="com.package.mypackage.mypackage"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".FriendsListActivity"></activity>
<activity android:name=".FriendEditActivity"></activity>
<activity android:name=".FriendNewActivity"></activity>
<activity android:name=".TakePictureActivity"></activity>
<activity android:name=".FriendsService"></activity>
<activity android:name=".MyService"></activity>
</application>
<uses-sdk android:minSdkVersion="9" />
Основное действие выглядит следующим образом:
package com.package.mypackage;
import java.util.ArrayList;
import com.package.domain.Domain;
import com.package.service.MyService;
import com.package.viewadapter.myImageAdapter;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemLongClickListener;
import android.widget.Button;
import android.widget.Gallery;
import android.widget.Toast;
public class myActivity extends Activity {
// ===========================================================
// Fields
// ===========================================================
private MyImageAdapter myImageAdapter;
private ArrayList<Domain> domain = new ArrayList<Domain>();
// ===========================================================
// onCreate
// ===========================================================
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.main);
/* Set Buttons to listen for any click event. */
setButtonFriendsClickListener();
setButtonCameraClickListener();
setButtonPreferencesClickListener();
}
// ===========================================================
// onStart
// ===========================================================
@Override
public void onStart() {
super.onStart();
/* Find the gallery defined in the main.xml */
Gallery g = (Gallery) findViewById(R.id.gallery);
/* Show a Toast message when image is clicked */
g.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
MyImageAdapter image_ID = new MyImageAdapter(myActivity.this, position, null);
if (image_ID.getItemId(position) == 0) {
Toast test_toast = Toast.makeText(myActivity.this, "This is the New Image click", Toast.LENGTH_SHORT);
test_toast.show();
}
else {
Toast test_toast = Toast.makeText(myActivity.this, "The clicked image has image number " + image_ID.getItemId(position) + " in the imageadapter.", Toast.LENGTH_SHORT);
test_toast.show();
}
}
});
g.setOnItemLongClickListener(new OnItemLongClickListener() {
@Override
public boolean onItemLongClick(AdapterView<?> parent, View v, int position, long id) {
MyImageAdapter image_ID = new MyImageAdapter(myActivity.this, position, null);
Toast test_toast = Toast.makeText(myActivity.this, "The long clicked image has image number " + image_ID.getItemId(position) + " in the imageadapter.", Toast.LENGTH_SHORT);
test_toast.show();
return true;
}
});
}
// ===========================================================
// onPause
// ===========================================================
protected void onPause() {
super.onPause();
}
// ===========================================================
// onResume
// ===========================================================
protected void onResume() {
super.onResume();
generateMyGallery();
}
// ===========================================================
// onStop
// ===========================================================
protected void onStop() {
super.onStop();
}
// ===========================================================
// onDestroy
// Is also called when user changes from horizontal
// to vertical orientation and back
// ===========================================================
@Override
protected void onDestroy() {
super.onDestroy();
}
// ===========================================================
// Save and Restore UI states
// ===========================================================
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
}
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
}
// ===========================================================
// Main Activity methods
// ===========================================================
public void generateMyGallery() {
MyService cs = new MyService(this);
domain = cs.getDomainList();
// Add the new_image drawable to the ArrayList
Domain d = new Domain();
d.photoLocation = "drawable";
d.photoName = "new_image";
d.extra1 = "no_text";
d.extra2 = "no_text";
domain.add(0, d);
myImageAdapter = new MyImageAdapter(this, R.layout.text_overlay_image_view, domain);
/* Find the gallery defined in the main.xml */
Gallery g = (Gallery) findViewById(R.id.gallery);
g.setSpacing(10);
/* Apply a new (custom) ImageAdapter to it. */
g.setAdapter(myImageAdapter);
g.setSelection(1);
}
private void setButtonFriendsClickListener() {
Button clickButton = (Button)findViewById(R.id.button_friends_list);
clickButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
setContentView(R.layout.friends_list);
Intent myIntent = new Intent(v.getContext(), FriendsListActivity.class);
startActivity(myIntent);
}
});
}
private void setButtonCameraClickListener() {
Button clickButton = (Button)findViewById(R.id.button_take_picture);
clickButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
setContentView(R.layout.take_picture);
Intent myIntent = new Intent(v.getContext(), TakePictureActivity.class);
startActivity(myIntent);
}
});
}
private void setButtonPreferencesClickListener() {
Button clickButton = (Button)findViewById(R.id.button_preferences);
clickButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Intent myIntent = new Intent(v.getContext(), MyPreferencesActivity.class);
startActivity(myIntent);
}
});
}
};
У всех есть идеи, почему приложение вылетает.Любая помощь очень ценится.
Я обнаружил, что когда я заканчиваю () действие MAIN, когда запускаю FriendListActivity, и перезапускаю действие MAIN при закрытии FriendListActivity, то сбоя не происходит.Тем не менее, это в основном перезапускает приложение, и это не намерение.
Спасибо всем, я решил проблему.Это то, что я сделал.
.При перемещении всех действий, связанных с галереей, в onCreate, скрипа больше не происходило.Но затем после возврата к ГЛАВНОМУ действию оно не показывалось.
.Затем я переместил все onCreate (кроме super), generateGallery и onStart () в onResume.Теперь все работает отлично!