Android: невозможно остановить активность - PullRequest
2 голосов
/ 26 июня 2010

Я новичок в Android. У меня есть loginActivity, которое проверяет номер пользователя, а затем запускает «searchactivity».

Во время выполнения я вижу, что поисковая активность идет вверх (после проверки пользователя), но затем у Android возникают проблемы с остановкой loginActivity.

Я получаю исключение java.lang.runtimeexception: Невозможно остановить действие {com.insruance / com.insurance.LoginActivity}: android.app.SuperNotCalledException: Activity atroid.app.ActivityThread.performStopActivityInner (ActivityThread.java:3413) "

Буду очень признателен, если кто-то укажет на то, что я делаю неправильно.

Код:

public class LoginActivity extends Activity{

 DatabaseWrapper myDbHelper;
 private String agentNumber;
 private OnClickListener btnClickListner = new OnClickListener() 
 {  
  @Override
  public void onClick(View v) 
  {
   // TODO Auto-generated method stub   
   // = new DataBaseHelper();   
   try {

    Log.d("LoginActivity->onClick", "Before findByID");
    EditText editText = (EditText)findViewById(R.id.txtUserNumber);
    Log.d("LoginActivity->onClick", "After findByID");
    agentNumber = editText.getText().toString();
    String msg = "";
    AgentDbHelper agentHelper = new AgentDbHelper(myDbHelper.getDatabaseHandle());
    Log.d("LoginActivity->onClick", "Before agentIDExists");    
    if (agentHelper.agentIDExists(agentNumber))
     msg = "Login success";
    else
     msg = "Login failed";
    Log.d("LoginActivity->onClick", "After agentByID");
    myDbHelper.closeDatabase();
    myDbHelper = null;
    Toast.makeText(getBaseContext(), 
      "User " + agentNumber + " found!", 
      Toast.LENGTH_LONG).show();
    callSearchActivity();
   } 
   catch(SQLException sqlEx)
   {
    Log.d("login - onclick", sqlEx.toString());
   }
   catch (Exception e) {
    // TODO: handle exception
    Log.d("login - onclick", e.toString());
   } 
  }
 }; 

 private void callSearchActivity()
 {
  Intent intent = new Intent(getBaseContext(), SearchActivity.class);
  Bundle bun = new Bundle();
  bun.putString("agentNumber", agentNumber);
  intent.putExtras(bun);
  startActivity(intent);  
 }

 @Override
 public void onStop() {  
  try {
   Log.d("In LoginActivity->onStop", "about to close myDbHelper");
   if (myDbHelper != null)
   {
    myDbHelper.closeDatabase();
    Log.d("In LoginActivity->onStop", "after myDbHelper is closed");
   }
  } catch (Exception e) {
   // TODO Auto-generated catch block
   Log.d("In LoginActivity->onStop exeption", e.toString());
   //e.printStackTrace();
  }
 }
 @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        try {        
         setContentView(R.layout.login);
         Button loginButton = (Button)this.findViewById(R.id.btnLogin);
         loginButton.setOnClickListener(btnClickListner);
         myDbHelper = new DatabaseWrapper(this);
         myDbHelper.openDatabase();
        }
        catch(Exception e) {
      Log.e("ERROR", "ERROR IN CODE:"+e.toString());
     }

} }

1 Ответ

7 голосов
/ 26 июня 2010

Немного больше копания указало мне на это.

Я не вызывал super.onStop () в переопределенном onStop.

Я бы подумал, что Eclipse написал бы эту строку, когда создавал onStop для меня.

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