package lab.sodino.menutest;
import android.content.Context;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.util.AttributeSet;
import android.view.InflateException;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;
/**
* @author Sodino E-mail:sodinoopen@hotmail.com
* @version Time:2011-1-26 下午04:42:04
*/
public class MenuAct extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
public boolean onCreateOptionsMenu(Menu menu) {
super.onCreateOptionsMenu(menu);
MenuInflater inflater = new MenuInflater(getApplicationContext());
inflater.inflate(R.menu.menu, menu);
setMenuBackground();
return true;
}
public boolean onOptionsItemSelected(MenuItem item) {
String info = "";
switch (item.getItemId()) {
case R.id.menu_add:
info = "Add";
break;
case R.id.menu_delete:
info = "Delete";
break;
case R.id.menu_home:
info = "Home";
break;
case R.id.menu_help:
info = "Help";
break;
default:
info = "NULL";
break;
}
Toast toast = Toast.makeText(this, info, Toast.LENGTH_SHORT);
toast.show();
return super.onOptionsItemSelected(item);
}
// 关键代码为重写Layout.Factory.onCreateView()方法自定义布局
protected void setMenuBackground() {
MenuAct.this.getLayoutInflater().setFactory(new android.view.LayoutInflater.Factory() {
/**
* name - Tag name to be inflated.<br/>
* context - The context the view is being created in.<br/>
* attrs - Inflation attributes as specified in XML file.<br/>
*/
public View onCreateView(String name, Context context, AttributeSet attrs) {
// 指定自定义inflate的对象
if (name.equalsIgnoreCase("com.android.internal.view.menu.IconMenuItemView")) {
try {
LayoutInflater f = getLayoutInflater();
final View view = f.createView(name, null, attrs);
new Handler().post(new Runnable() {
public void run() {
// 设置背景图片
view.setBackgroundResource(R.drawable.menu_background);
}
});
return view;
} catch (InflateException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
return null;
}
});
}
}
分享到:
相关推荐
jQuery.menu-1.0 插件利用 jQuery 的强大功能,实现了动态菜单的各种效果,如滑动展开、淡入淡出等,同时支持多级菜单和自定义样式。 在使用 "jQuery.menu-1.0" 时,首先需要确保在网页中引入了 jQuery 库和该插件...
此外,还需要通过CSS控制菜单的外观,包括字体、颜色、背景等。 3. **jQuery实现**:在JavaScript文件中,我们主要关注两个部分:菜单的初始化和滚动事件的监听。初始化时,可以设置菜单的初始状态,如显示/隐藏、...
本文将深入探讨如何使用CSS创建多种Menu样式,并结合实例解析`cssmenu`的实现。 1. **基础概念** - CSS(层叠样式表):是一种样式表语言,用于定义HTML或XML(包括如SVG、MathML等各种XML方言)文档的呈现。 - ...
在`res/values/styles.xml`中创建一个新的主题,如`PopupTheme`,并设置相应的属性,如背景颜色、文字颜色、阴影效果等。 ```xml <item name="android:popupBackground">@drawable/popup_background ...
标题 "1698997419587711_css-menu-1.rar" 暗示我们关注的是一个与CSS相关的资源,特别是关于菜单设计的。描述中的内容相同,没有提供额外信息,但我们可以从压缩包内的文件名 "css-menu-1.html" 推测这是一个关于CSS...
- `css` 文件夹中的样式表用于定义菜单的外观,包括字体、颜色、边距、背景等。开发者可以根据自己的设计需求进行修改。 - 使用预处理器如 SASS 或 LESS 可以提高 CSS 的可维护性和复用性。 6. **JavaScript 交互...
本文介绍了element-ui tooltip修改背景颜色和箭头颜色的实现,分享给大家,具体如下: 分享 placement=left popper-class=draw_share_atooltip> <div class=iconfont></div> //箭头颜色 .el-tooltip__...
对于Menu控件,我们可以通过设置`ControlTemplate`属性来自定义其整体样式,包括菜单项的外观、展开动画等。 2. **图片替换背景色** 为了使Menu更美观,开发者可能使用了图片作为背景,而不是传统的颜色填充。这...
自定义`MenuBar`的样式可能涉及到调整其高度、背景色、边框等。同时,`MenuBar`可以通过`menu`属性关联一个`Menu`,实现下拉菜单的效果。 ```qml MenuBar { height: 30 background: Rectangle { color: "white" }...
这意味着`MenuItem`的背景、边框、高亮色等可能会用到动态资源或者色彩转换器,使得开发者可以轻松更改主题色彩。 4. **图标支持**: - 文件列表中包含`.ico`文件,这些通常是图标资源,用于在`MenuItem`上显示。`...
你可以为所有的菜单项设定一个默认的背景色,然后当鼠标悬停在某个菜单项上时,更改其背景色。例如: ```css .menu li { background-color: #f8f8f8; /* 默认背景色 */ } .menu li:hover { background-color: #...
透明Menu的第一步是修改应用的主题,使其背景变为透明。在`res/values/styles.xml`文件中,创建一个新的主题,并将`android:windowBackground`属性设置为透明色。例如: ```xml ...
在MFC中,菜单通常通过`CMenu`类来操作,而菜单栏则由`CFrameWnd`或其派生类(如`CMDIFrameWnd`, `CDialog`等)管理。默认情况下,菜单栏的颜色、样式和尺寸是由操作系统或主题决定的,但我们可以通过重载一些关键...
在这个JS菜单中,CSS被用来控制菜单的样式,如背景色、字体、边框等,使其能够与网页的整体设计无缝融合。开发者可以通过自定义CSS样式来调整菜单的视觉效果,以满足特定的设计需求。 开源软件是指源代码可以被自由...
我们可以通过`StaticMenuItemStyle`、`DynamicMenuItemStyle`等属性来指定不同状态(如鼠标悬停、选定等)的菜单项样式。例如,可以设置字体大小、颜色、背景色,甚至添加边框和阴影效果。此外,还可以使用CSS类来...
- 可以通过修改`style.xml`文件中的主题或者使用自定义样式来改变菜单项的外观,如字体大小、颜色、背景等。 7. **适配不同设备** - 考虑到不同设备的屏幕尺寸和方向,可能需要对菜单进行适当的调整。例如,对于...
包括颜色、字体、边距、背景图像等,如header_bg.gif、vertical.gif等图片资源用于美化菜单的背景和图标。通过编辑CSS,我们可以自定义菜单的样式,使其与网站的整体设计保持一致。 2. **icons.gif**:这是一个包含...
标题 "menu-slider-and-modal-javascript" 指的是一个JavaScript项目,主要关注的是网页上的滑动菜单和模态对话框的实现。这个项目的核心是创建一个具有交互性的登录页面,其中包括了两个重要的用户界面元素:侧滑...
8. **样式自定义**:为了使TabMenu符合应用的整体风格,我们需要自定义其样式,包括字体颜色、背景色、选中状态的高亮效果等。这可以通过修改`style.xml`文件中的主题和样式定义来实现。 9. **手势库支持**:对于更...
- **CSS样式**:为了实现“各种样式”,开发者通常会结合CSS来定制菜单的外观,包括颜色、字体、边框、背景等。 - **图标集成**:图标可以增强菜单的可识别性和美观度。这可能通过内联SVG、字体图标库(如Font ...