使用后退按钮时,将显示活动中的旧屏幕

时间:2013-09-21 23:40:29

标签: android android-listview android-activity android-ui

我想我不明白“后退按钮”之类的内容如何影响活动的行为。

这是我的主要活动屏幕截图:

enter image description here

如果用户点击右上角的书签图标,我的BookmarksActivity就会显示如下:

enter image description here

此处用户点击“添加”按钮添加书签,然后在我的BookmarksActivity类中调用finish(),屏幕返回到我的MainActivity ...

enter image description here

现在假设用户想要删除书签,他们会再次点击书签图标,向用户显示此屏幕:​​

enter image description here

现在,用户可以点击导致此屏幕的删除按钮:

enter image description here

现在用户希望通过按下后退按钮返回MainActivity的屏幕,这样就可以按照预期移除键盘,从而产生以下屏幕:

enter image description here

但是现在用户仍然希望返回主屏幕,所以他们再次单击“返回”按钮,但是不会在主屏幕上看到他们看到这一个!

enter image description here

现在我的SQLite数据库中没有书签,但正在显示一个书签。如果用户再次点击该返回按钮,他们最终会获得主活动屏幕...

enter image description here

...如果他们点击Bookamrk图标,您会看到没有书签:

enter image description here

感谢您对我的关注以及对问题的冗长描述。以下是我认为相关的代码片段:

这是删除发生的地方:

public class BookMarksBaseAdapter extends BaseAdapter  {

    ...

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    // TODO Auto-generated method stub
    View vi=convertView;
    if(convertView==null)
        vi = inflater.inflate(R.layout.bookmark, null);

    TextView    tv_bookmark_name    = (TextView)vi.findViewById(R.id.bookmark_name); 
    TextView    tv_bookmark_clock   = (TextView)vi.findViewById(R.id.bookmark_clock);
    Button      deleteButton    = (Button)vi.findViewById(R.id.btn_delete_bookmark);

    final bookMark bookmark = new bookMark(data.get(position).get_bookmark_name(), data.get(position).get_bookmark_track(), data.get(position).get_bookmark_clock(), 0);
    final String    bookmark_name = bookmark.get_bookmark_name();
    final int       ibookmark_clock = bookmark.get_bookmark_clock();

    // Setting all values in listview
    tv_bookmark_name.setText(bookmark_name);
    tv_bookmark_clock.setText(utils.milliSecondsToTimer(ibookmark_clock));
    deleteButton.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            Log.d( TAG, "delete button clicked line 73" ); 
            db.deleteBookmark(bookmark);
            v.getContext().startActivity(new Intent(v.getContext(), com.redcricket.myApp.BookMarksActivity.class));
        }
    });
    return vi;
}

以下是我的BookmarkActivity onCreate方法的摘录:

@Override
public void onCreate(Bundle savedInstanceState) {
    currentChapterTitle     = com.redcricket.myApp.MainActivity.getTrackTitle(0);
    currentTrack            = com.redcricket.myApp.MainActivity.getCurrentSongIndex();
    currentTrackPosition    = "00:00:00";

    db = new Databasehandler(this);
    db.getWritableDatabase();

    utils = new Utils();

    try {
        currentChapterTitle = com.redcricket.myApp.MainActivity.getCurrentTrackTitle();
    } catch (Exception e) {
        Log.d( TAG, "expection line 27" );
        e.printStackTrace();
    }

    try {
        icurrentTrackPosition = com.redcricket.myApp.MainActivity.getCurrentTrackPosition();
        currentTrackPosition = utils.milliSecondsToTimer(icurrentTrackPosition); 
    } catch (Exception e) {
        Log.d( TAG, "expection line 34" );
        e.printStackTrace();
    }

    super.onCreate(savedInstanceState);

    setContentView(R.layout.bookmarks);

    try {
        new_bookmark_name = (EditText) findViewById(R.id.new_bookmark_name);
    } catch (Exception e) {
        Log.d( TAG, "expection line 43" );
        e.printStackTrace();
    }

    try {
        new_bookmark_name.setText( currentChapterTitle );
    } catch (Exception e) {
        Log.d( TAG, "expection line 49" );
        e.printStackTrace();
    }

    try {
        new_bookmark_clock = (TextView) findViewById(R.id.new_bookmark_clock);
    } catch (Exception e) {
        Log.d( TAG, "expection line 55" );
        e.printStackTrace();
    }

    try {
        new_bookmark_clock.setText( currentTrackPosition );
    } catch (Exception e) {
        Log.d( TAG, "expection line 61" );
        e.printStackTrace();
    }

    try {
        addButton = (Button) findViewById(R.id.btn_add_new_bookmark);
    } catch (Exception e) {
        Log.d( TAG, "expection line 43" );
        e.printStackTrace();
    }
    addButton.setOnClickListener(this);     
    bookMarkList = db.getAllBookmarks();
    // add list
    bookmark_list=(ListView)findViewById(R.id.bookmarks_list);
    adapter=new BookMarksBaseAdapter(this, bookMarkList, this); 
            bookmark_list.setAdapter(adapter);

我必须在某处做错事。我试图覆盖onBackButton方法,并让它调用完,但这根本没有帮助。我最好的猜测是这一行错了:

            v.getContext().startActivity(new Intent(v.getContext(), com.redcricket.myApp.BookMarksActivity.class));

我按下删除按钮时调用它。

欢迎任何帮助。谢谢!

2 个答案:

答案 0 :(得分:1)

我假设Main是一个活动,书签是另一个活动,书签删除是另一个活动。除非你告诉某个活动没有历史记录或者在去另一个活动之前明确地完成它,否则它将保留在活动堆栈中。

在您的示例中,用户进入MainActivity - > BookMarkActivty然后通过后退按回到MainActivity,从堆栈中删除了BookMarkActivity。一切都很好。

在您的其他示例中,用户进入MainActivity - > BookMarkActivity - > DeleteActivity

这里的问题是他们点击删除你是在完成DeleteActivty还是开始新的BookMarkActivty?

看起来你正在开始一个新的BookMarkActivty,完成旧的BookMarkActivity并在删除过程之后最终得到一堆Main - DeleteBookMark - BookMark。

当他们选择删除时,请不要完成书签,并将删除活动设置为没有历史记录或删除后显式完成删除。

答案 1 :(得分:0)

卫生署!我想出了我需要做什么。我需要保存传递​​给Activity类构造函数的BookMarksBaseAdapter作为私有成员,如此...

公共类BookMarksBaseAdapter扩展了BaseAdapter {

private Activity  activity;
...

BookMarksBaseAdapter (Activity a, ArrayList<bookMark> d) {
    activity = a;
    data=d;
    inflater = (LayoutInflater)activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    utils = new Utils();
    db = new Databasehandler(a);
}

...然后当按下删除按钮时,我打电话给activity.finish() ...

deleteButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            db.deleteBookmark(bookmark);
            activity.finish();
        }
    });