tab

public class SenseSoccerScoreActivity extends Activity{
	public static final int MENU_SETUP_ID = 1;
	public static final int MENU_ABOUT_ID = 2;
	public static final int MENU_LEAVE_ID = 3;
	public static final int MENU_CHECK_UPDATE_ID = 5;
	public static final int MENU_EMPTY_FOCUS_ID = 4;
	public static final int MENU_HISTORY_MATCH = 6;
	public static final int MENU_RETURN = 7;
	public static final int MENU_FILTER_SETTING = 8;
	public static final int MENU_FUTURE_MATCH = 9;
	public static final int MENU_BACK_ID = 10;
	public static final int MENU_REFRESH_ID = 11;
	public static final int MENU_CLEAN_CACHE = 12;
 
        // ... 其它代码.
	/**
	 * 当点击menu按钮时,添加菜单
	 * 之前一般是覆盖 onCreateOptionsMenu 方法的,现在要覆盖 onPrepareOptionsMenu
	 */
    public boolean onPrepareOptionsMenu(Menu menu) {
		// *** 这里是实现的主要代码,先要清空菜单,然后再重新添加菜单
    	menu.clear(); // 清空menu
    	super.onPrepareOptionsMenu(menu);
 
		TabHost th = (TabHost) findViewById(R.id.tabhost);
 
		// 如果是关注赛事列表,需要添加清空菜单
		if(th.getCurrentTab() == 3){
			menu.add(0, MENU_SETUP_ID, 1, R.string.settingMenu)
                                .setIcon(android.R.drawable.ic_menu_preferences);
			menu.add(0, MENU_EMPTY_FOCUS_ID, 2, R.string.clearFocusMenu)
                                .setIcon(android.R.drawable.ic_menu_delete);
			menu.add(0, MENU_CHECK_UPDATE_ID, 3, R.string.text_check_update)
                                .setIcon(android.R.drawable.ic_menu_search);
			menu.add(0, MENU_ABOUT_ID, 4, R.string.aboutMenu)
                                .setIcon(android.R.drawable.ic_menu_help);
			menu.add(0, MENU_HISTORY_MATCH, 5, R.string.fullTimeMatch)
                                .setIcon(android.R.drawable.ic_menu_recent_history);
			menu.add(0, MENU_LEAVE_ID, 6, R.string.leaveMenu)
                                .setIcon(android.R.drawable.ic_menu_close_clear_cancel);
			return true;
		} else {
			menu.add(0, MENU_SETUP_ID, 1, R.string.settingMenu)
                               .setIcon(android.R.drawable.ic_menu_preferences);
			menu.add(0, MENU_CHECK_UPDATE_ID, 3, R.string.text_check_update)
                               .setIcon(android.R.drawable.ic_menu_search);
			menu.add(0, MENU_ABOUT_ID, 4, R.string.aboutMenu)
                               .setIcon(android.R.drawable.ic_menu_help);
			menu.add(0, MENU_HISTORY_MATCH, 5, R.string.fullTimeMatch)
                               .setIcon(android.R.drawable.ic_menu_recent_history);
			menu.add(0, MENU_LEAVE_ID, 7, R.string.leaveMenu)
                               .setIcon(android.R.drawable.ic_menu_close_clear_cancel);
			return true;
		}
    }
 
	/**
	 * 当点击相应的菜单后,执行响应的事件
	 */
	public boolean onOptionsItemSelected(MenuItem item){
		Intent intent = null;
        switch (item.getItemId()){
        	// 设置
        case MENU_SETUP_ID:
        	intent = new Intent();  
        	intent.setClass(this, SettingActivity.class);
            this.startActivity(intent);  
            break;
 
            // 清空关注赛事列表
        case MENU_EMPTY_FOCUS_ID:
        	MatchManager.getInstance(this).clearFocus();
        	updateFocusMatchUI();
            break;
 
            // 检查更新
        case MENU_CHECK_UPDATE_ID:
            ProgressDialog checkUpdateDialog = buildCheckUpdateView();
            checkUpdateDialog.show();
            break;
 
            // 关于
        case MENU_ABOUT_ID:
            AlertDialog dialog = buildAboutView();
            dialog.show();
            break;
 
        // ... 实现其它的,代码就省略了...      		
 
        return super.onOptionsItemSelected(item);
	}
}

  实现以上效果的思路是:覆盖 onPrepareOptionsMenu 而不是 onCreateOptionsMenu 方法的. 因为onCreateOptionsMenu的方法只会执行一次,就是第一次点击menu键时才会执行.而onPrepareOptionsMenu每一次点击menu键都会执行.这样,我们就可以先清空menu的内容,再重新添加menu.这就是实现在不同Tab中显示不同菜单(Menu)的原理.

1
2
3
4
5
6
7
8
   public boolean onPrepareOptionsMenu(Menu menu) {
        // *** 这里是实现的主要代码,先要清空菜单,然后再重新添加菜单
    	menu.clear(); // 清空menu
    	super.onPrepareOptionsMenu(menu);
 
        // 添加所需要的菜单...
        menu.add(....);
  }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值