不知道大家是否用过天天动听,对于它界面上的半透明Menu效果,笔者感觉非常漂亮。下面是天天动听半透明Menu的截图,欣赏下吧:
感觉还不错吧?那么如何实现这种半透明Menu效果呢?本文就重点讨论并给出这种Menu的具体代码实现过程。
首先分析下实现这种半透明Menu所需做的工作,并进行合理分解:
1. 利用Shaper设置一个半透明圆角背景。
2. 定义Menu布局,主要就GridView,把图标都放在这个GridView。
3. Menu事件, 通过PopupWindow或者AlertDialog或者透明Activity显示到页面即可。
4. 按钮的监听事件,实例中没加。需要的话自己在Adapter里加。
比较简单,不多说了。
半透明圆角背景xml:
XML/HTML代码
<?xml version="1.0" encoding="UTF-8"?> <shape android:shape="rectangle"> <solid android:color="#b4000000" /> <stroke android:width="2.0dip" android:color="#b4ffffff" android:dashWidth="3.0dip" android:dashGap="0.0dip" /> <padding android:left="7.0dip" android:top="7.0dip" android:right="7.0dip" android:bottom="7.0dip" /> <corners android:radius="8.0dip" /> </shape>
Menu布局:
XML/HTML代码
<?xml version="1.0" encoding="UTF-8"?> <LinearLayout android:orientation="vertical" android:layout_width="wrap_content" android:layout_height="fill_parent"> <GridView android:gravity="center" android:layout_gravity="center" android:id="@+id/menuGridChange" android:background="@drawable/menu_bg_frame" android:padding="5.0dip" android:layout_width="fill_parent" android:layout_height="wrap_content" android:horizontalSpacing="10.0dip" android:verticalSpacing="3.0dip" android:stretchMode="columnWidth" android:columnWidth="60.0dip" android:numColumns="auto_fit"/> </LinearLayout>
主要类:
Java代码
package com.yfz; import android.app.Activity; import android.app.AlertDialog; import android.app.AlertDialog.Builder; import android.content.Context; import android.graphics.drawable.BitmapDrawable; import android.os.Bundle; import android.util.Log; import android.view.ContextMenu; import android.view.Gravity; import android.view.LayoutInflater; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; import android.view.ContextMenu.ContextMenuInfo; import android.widget.BaseAdapter; import android.widget.GridView; import android.widget.ImageView; import android.widget.LinearLayout; import android.widget.PopupWindow; import android.widget.TextView; import android.widget.LinearLayout.LayoutParams; public class MenuTest extends Activity { private String TAG = this.getClass().getSimpleName(); private int[] resArray = new int[] { R.drawable.icon_menu_addto, R.drawable.icon_menu_audioinfo, R.drawable.icon_menu_findlrc, R.drawable.icon_menu_scan }; private String[] title = new String[]{ "添加歌曲", "歌曲信息", "查找歌词", "搜索歌词" }; private static boolean show_flag = false; private PopupWindow pw = null; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); } @Override public boolean onCreateOptionsMenu(Menu menu) { Log.e(TAG, "------ onCreateOptionsMenu ------"); //用AlertDialog弹出menu // View view = LayoutInflater.from(this).inflate(R.layout.menu, null); // GridView grid1 = (GridView)view.findViewById(R.id.menuGridChange); // grid1.setAdapter(new ImageAdapter(this)); // Builder build = new AlertDialog.Builder(this); // build.setView(view); // build.show(); LayoutInflater inflater = (LayoutInflater)this.getSystemService(Context.LAYOUT_INFLATER_SERVICE); View view = inflater.inflate(R.layout.menu, null); GridView grid1 = (GridView)view.findViewById(R.id.menuGridChange); grid1.setAdapter(new ImageAdapter(this)); //用Popupwindow弹出menu pw = new PopupWindow(view,LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT); //NND, 第一个参数, 必须找个View pw.showAtLocation(findViewById(R.id.tv), Gravity.CENTER, 0, 300); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { return super.onOptionsItemSelected(item); } public class ImageAdapter extends BaseAdapter { private Context context; public ImageAdapter(Context context) { this.context = context; } @Override public int getCount() { return resArray.length; } @Override public Object getItem(int arg0) { return resArray[arg0]; } @Override public long getItemId(int arg0) { return arg0; } @Override public View getView(int arg0, View arg1, ViewGroup arg2) { LinearLayout linear = new LinearLayout(context); LinearLayout.LayoutParams params = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); linear.setOrientation(LinearLayout.VERTICAL); ImageView iv = new ImageView(context); iv.setImageBitmap(((BitmapDrawable)context.getResources().getDrawable(resArray[arg0])).getBitmap()); LinearLayout.LayoutParams params2 = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); params2.gravity=Gravity.CENTER; linear.addView(iv, params2); TextView tv = new TextView(context); tv.setText(title[arg0]); LinearLayout.LayoutParams params3 = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); params3.gravity=Gravity.CENTER; linear.addView(tv, params3); return linear; } } }
到此,大家是不是觉得半透明Menu效果也是比较好实现的呢?可以根据自己的需要对此实例进行修改以求更美观好用。
以上就是对Android Menu 半透明效果的实现,后续继续补充相关资料谢谢大家对本站的支持!
本文向大家介绍基于popupWindow实现悬浮半透明效果,包括了基于popupWindow实现悬浮半透明效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了popupWindow实现悬浮半透明效果的具体代码,供大家参考,具体内容如下 如上图显示弹出一个半透明框 java代码: soft_calendar_popup.xml的内容: 以上就是本文的全部内容,希望对大家的学习有所帮助
本文向大家介绍js+html5实现半透明遮罩层弹框效果,包括了js+html5实现半透明遮罩层弹框效果的使用技巧和注意事项,需要的朋友参考一下 点击按钮,出现半透明遮罩层弹框,说说自己之前发过的愁吧 1、遮罩层半透明了 弹框也跟着半透明了 就像这样 绝望吧 是哪里错了呢?你的css是这样写的吧: 应该这样: 需要注意的是这几个参数的意思:RGB Red Green Bule 3色!及212, 0
如题,这个有趣效果是如何实现的? 截图如下。 1.隐藏前: 2.隐藏后:
本文向大家介绍php实现给图片加灰色半透明效果的方法,包括了php实现给图片加灰色半透明效果的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php实现给图片加灰色半透明效果的方法。分享给大家供大家参考。具体实现方法如下: 原理: 1.首先计算出原图片的尺寸 2.创建相同尺寸的半透明图片 3.使用 imagecopy()方法,把新创建的半透明图片与原图合并 具体实现代码如下: 希望本文
本文向大家介绍Android开发中Dialog半透明背景消失,包括了Android开发中Dialog半透明背景消失的使用技巧和注意事项,需要的朋友参考一下 近日,遇到一个Dialog半透明背景消失的问题,背景需求是自定义Dialog实现警告提示框: 进行页面操作及用户提示,一切显示正常,如图: 当按下屏幕电源按钮,再次点亮屏幕,发现Dialog半透明的灰暗背景消失了..... 解决方法:设置win
我想创建一个包含透明和半透明部分的图像,这样如果我给,比如说颜色x作为背景,透明部分将显示x颜色,半透明部分将显示颜色x的渐变阴影。 我需要这样一个图像在模板中使用,将由客户谁将有不同的颜色主题使用。 编辑:问题是如何创建既透明 编辑:我让我的问题更清楚了。在附加的图像中,有一个透明区域。想法是在图像中有一个透明区域和一个半透明区域(指向指针的区域,目前这不是半透明的),这样如果我给红色作为bg颜