不知道大家是否用过天天动听,对于它界面上的半透明Menu效果,笔者感觉非常漂亮。下面是天天动听半透明Menu的截图,欣赏下吧:

感觉还不错吧?那么如何实现这种半透明Menu效果呢?本文就重点讨论并给出这种Menu的具体代码实现过程。

首先分析下实现这种半透明Menu所需做的工作,并进行合理分解:

1.  利用Shaper设置一个半透明圆角背景。

2.  定义Menu布局,主要就GridView,把图标都放在这个GridView。

3.  Menu事件, 通过PopupWindow或者AlertDialog或者透明Activity显示到页面即可。

4.  按钮的监听事件,实例中没加。需要的话自己在Adapter里加。

比较简单,不多说了。

半透明圆角背景xml:

XML/HTML代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <shape android:shape="rectangle">
  3. <solid android:color="#b4000000" />
  4. <stroke android:width="2.0dip" android:color="#b4ffffff" android:dashWidth="3.0dip" android:dashGap="0.0dip" />
  5. <padding android:left="7.0dip" android:top="7.0dip" android:right="7.0dip" android:bottom="7.0dip" />
  6. <corners android:radius="8.0dip" />
  7. </shape>

Menu布局:

XML/HTML代码
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <LinearLayout
  3. android:orientation="vertical"
  4. android:layout_width="wrap_content"
  5. android:layout_height="fill_parent">
  6. <GridView android:gravity="center"
  7. android:layout_gravity="center"
  8. android:id="@+id/menuGridChange"
  9. android:background="@drawable/menu_bg_frame"
  10. android:padding="5.0dip"
  11. android:layout_width="fill_parent"
  12. android:layout_height="wrap_content"
  13. android:horizontalSpacing="10.0dip"
  14. android:verticalSpacing="3.0dip"
  15. android:stretchMode="columnWidth"
  16. android:columnWidth="60.0dip"
  17. android:numColumns="auto_fit"/>
  18. </LinearLayout>

主要类:

Java代码
  1. package com.yfz;
  2. import android.app.Activity;
  3. import android.app.AlertDialog;
  4. import android.app.AlertDialog.Builder;
  5. import android.content.Context;
  6. import android.graphics.drawable.BitmapDrawable;
  7. import android.os.Bundle;
  8. import android.util.Log;
  9. import android.view.ContextMenu;
  10. import android.view.Gravity;
  11. import android.view.LayoutInflater;
  12. import android.view.Menu;
  13. import android.view.MenuItem;
  14. import android.view.View;
  15. import android.view.ViewGroup;
  16. import android.view.ContextMenu.ContextMenuInfo;
  17. import android.widget.BaseAdapter;
  18. import android.widget.GridView;
  19. import android.widget.ImageView;
  20. import android.widget.LinearLayout;
  21. import android.widget.PopupWindow;
  22. import android.widget.TextView;
  23. import android.widget.LinearLayout.LayoutParams;
  24. public class MenuTest extends Activity {
  25. private String TAG = this.getClass().getSimpleName();
  26. private int[] resArray = new int[] {
  27. R.drawable.icon_menu_addto, R.drawable.icon_menu_audioinfo,
  28. R.drawable.icon_menu_findlrc, R.drawable.icon_menu_scan
  29. };
  30. private String[] title = new String[]{
  31. "添加歌曲", "歌曲信息", "查找歌词", "搜索歌词"
  32. };
  33. private static boolean show_flag = false;
  34. private PopupWindow pw = null;
  35. /** Called when the activity is first created. */
  36. @Override
  37. public void onCreate(Bundle savedInstanceState) {
  38. super.onCreate(savedInstanceState);
  39. setContentView(R.layout.main);
  40. }
  41. @Override
  42. public boolean onCreateOptionsMenu(Menu menu) {
  43. Log.e(TAG, "------  onCreateOptionsMenu ------");
  44. //用AlertDialog弹出menu
  45. //                View view = LayoutInflater.from(this).inflate(R.layout.menu, null);
  46. //                GridView grid1 = (GridView)view.findViewById(R.id.menuGridChange);
  47. //                grid1.setAdapter(new ImageAdapter(this));
  48. //                Builder build = new AlertDialog.Builder(this);
  49. //                build.setView(view);
  50. //                build.show();
  51. LayoutInflater inflater = (LayoutInflater)this.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  52. View view = inflater.inflate(R.layout.menu, null);
  53. GridView grid1 = (GridView)view.findViewById(R.id.menuGridChange);
  54. grid1.setAdapter(new ImageAdapter(this));
  55. //用Popupwindow弹出menu
  56. pw = new PopupWindow(view,LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);
  57. //NND, 第一个参数, 必须找个View
  58. pw.showAtLocation(findViewById(R.id.tv), Gravity.CENTER, 0, 300);
  59. return true;
  60. }
  61. @Override
  62. public boolean onOptionsItemSelected(MenuItem item) {
  63. return super.onOptionsItemSelected(item);
  64. }
  65. public class ImageAdapter extends BaseAdapter {
  66. private Context context;
  67. public ImageAdapter(Context context) {
  68. this.context = context;
  69. }
  70. @Override
  71. public int getCount() {
  72. return resArray.length;
  73. }
  74. @Override
  75. public Object getItem(int arg0) {
  76. return resArray[arg0];
  77. }
  78. @Override
  79. public long getItemId(int arg0) {
  80. return arg0;
  81. }
  82. @Override
  83. public View getView(int arg0, View arg1, ViewGroup arg2) {
  84. LinearLayout linear = new LinearLayout(context);
  85. LinearLayout.LayoutParams params = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
  86. linear.setOrientation(LinearLayout.VERTICAL);
  87. ImageView iv = new ImageView(context);
  88. iv.setImageBitmap(((BitmapDrawable)context.getResources().getDrawable(resArray[arg0])).getBitmap());
  89. LinearLayout.LayoutParams params2 = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
  90. params2.gravity=Gravity.CENTER;
  91. linear.addView(iv, params2);
  92. TextView tv = new TextView(context);
  93. tv.setText(title[arg0]);
  94. LinearLayout.LayoutParams params3 = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
  95. params3.gravity=Gravity.CENTER;
  96. linear.addView(tv, params3);
  97. return linear;
  98. }
  99. }
  100. }

到此,大家是不是觉得半透明Menu效果也是比较好实现的呢?可以根据自己的需要对此实例进行修改以求更美观好用。

实现Android半透明Menu效果的开发实例的更多相关文章

  1. Android音乐播放器的开发实例

    本文将引导大家做一个音乐播放器,在做这个Android开发实例的过程中,能够帮助大家进一步熟悉和掌握学过的ListView和其他一些组件.为了有更好的学习效果,其中很多功能我们手动实现,例如音乐播放的 ...

  2. Android手机拨打电话的开发实例

    一部手机最常用的功能就是打电话和发短信了,在Android开发中我们如何通过程序拨打电话呢?本文就给出一个用Android手机拨打电话的简单的实例. 下面是开发此实例的具体步骤: 一.新建一个Andr ...

  3. Android系统Google Maps开发实例浅析

    Google Map(谷歌地图)是Google公司提供的电子地图服务.包括了三种视图:矢量地图.卫星图片.地形地图.对于Android系统来说,可以利用Google提供的地图服务来开发自己的一些应用. ...

  4. android widget 开发实例 : 桌面便签程序的实现具体解释和源代码 (上)

    如有错漏请不吝拍砖指正,转载请注明出处,很感谢 桌面便签软件是android上经常使用软件的一种,比方比較早的Sticky Note,就曾很流行, Sticky Note的介绍能够參见 http:// ...

  5. Android开发实例之miniTwitter登录界面的实现

    原文: http://www.jizhuomi.com/android/example/134.html 本文要演示的Android开发实例是如何完成一个Android中的miniTwitter登录界 ...

  6. Android中半透明Activity效果另法

    Android中的Activity有没有类似于像Windows程序样的窗口式显示呢? 答案当然是有. 下图就是一个窗口式Activity的效果图: 下面就说说实现过程: 首先看看AndroidMani ...

  7. Android studio 下 JNI 开发实例

    在AS中进行 NDK 开发之前,我们先来简单的介绍几个大家都容易搞懵的概念: 到底什么是JNI,什么是NDK? 何为“交叉编译”? 先看什么是 JNI?JNI 的全称就是 Java Native In ...

  8. Android 应用开发实例之情景模式

    2013-07-01 Android 应用开发实例 1. 情景模式 使用TabHost来实现主界面的布局. 设置一组RadioButton来切换不同的情景模式. 对比普通情景模式,定时情景模式需要加上 ...

  9. 【Android开发日记】之基础篇(二)——Android的动画效果

          什么是动画,动画的本质是通过连续不断地显示若干图像来产生“动”起来的效果.比如说一个移动的动画,就是在一定的时间段内,以恰当的速率(起码要12帧/秒以上,才会让人产生动起来的错觉)每隔若干 ...

随机推荐

  1. 用命令行(CMD)中启动和关闭ORACLE服务

    lsnrctl start开启监听 lsnrctl stop停止监听 net start oracleserviceoracle开启oracle服务 net stop oracleserviceora ...

  2. [转载] python+Eclipse+pydev环境搭建

    转自:http://www.cnblogs.com/Bonker/p/3584707.html 编辑器:Python 自带的 IDLE 简单快捷, 学习Python或者编写小型软件的时候.非常有用. ...

  3. 《Python核心编程》 第五章 数字 - 课后习题

    课后习题  5-1 整形. 讲讲 Python 普通整型和长整型的区别. 答:普通整型是绝大多数现代系统都能识别的. Python的长整型类型能表达的数值仅仅与你机器支持的(虚拟)内存大小有关. 5- ...

  4. TortoiseHg简单的入门使用说明

    参考资料: 互普的 TortoiseHg使用说明_百度文库 Mercurial(Hg)基本操作 - Tim Gong - 博客园 Mercurial与TortoiseHg使用入门教程(转) - mee ...

  5. 用matlab绘制幂函数

    用matlab绘制幂函数 下周轮到我做论文汇报了,刚好前两天看了网格水印的文章,就决定汇报前两天看到的那篇论文了.在准备ppt的过程中,绘制了一些幂函数,感觉matlab真的是很强大啊,可以绘制各种曲 ...

  6. MVC中的ActionResult

    ActionResult是控制器方法执行后返回的结果类型,控制器方法可以返回一个直接或间接从ActionResult抽象类继承的类型,如果返回的是非ActionResult类型,控制器将会将结果转换为 ...

  7. LUA和C++绑定的一些天然的麻烦

    最近在看Luatinker的源代码,打算自己改(仿写)写搞一个简单的封装C++和LUA的结合的库,结果发现其实麻烦和困惑比想象的多. 比如这些点: 1)有时候使用模板的时候,引用会退化. classt ...

  8. [转]Freemarker数据类型转换

    转至:http://blog.sina.com.cn/s/blog_667ac0360102eaz8.html // 测试程序 package myTest; import java.io.Buffe ...

  9. OOP 6大基本原则

    1.开闭原则: 对扩展开发.对修改关闭. 2.里氏替换原则:子类替换父类(可以用父类对象的任何地方都可以用子类对象代替) 3.依赖倒置原则:程序要依赖于抽象接口,不要依赖于具体实现.简单的说就是要求对 ...

  10. 应用完全启动后, Spring执行自定义初始化

    项目中做敏感词过滤, 因为前台ajax校验要走service ,而后台统一过滤器要走interceptor , 所以把检查器提到一个工具类(HeXieWordFinder)里 这个工具类理应缓存数据库 ...