收藏 分销(赏)

android 游戏 制作半透明效果.doc

上传人:xrp****65 文档编号:6415307 上传时间:2024-12-08 格式:DOC 页数:6 大小:327KB 下载积分:10 金币
下载 相关 举报
android 游戏 制作半透明效果.doc_第1页
第1页 / 共6页
android 游戏 制作半透明效果.doc_第2页
第2页 / 共6页


点击查看更多>>
资源描述
实现半透明的popupwindow的源码   楼主 发表于 2011-5-14 12:43:45 | 查看: 2256| 回复: 36 1.设置半透明主题 2.设置window的alpha值 1. //                        WindowManager.LayoutParams lp = getWindow().getAttributes(); 2. //            lp.alpha = 0.5f; //0.0-1.0 3. //            getWindow().setAttributes(lp); 复制代码 发现这两种都不能满足要求,起码的颜色就不太对。想做好点,做成类似alertDialog的样子,带边框,弹出窗口带动画效果,之后背景置灰,那多帅。 看到那个仿uc浏览器的源码,是用alertdialog做的,达到那种效果,加点动画就行了。下图是从那个ucweb源码里面弄出来的。 2011-5-14 12:41 上传 下载附件 (426.79 KB)        上面的代码就不贴了,我上传的项目文件里面也有。         下面是弹出popupwindow的图片,第一张是动画中,第二张是完全弹出的: 2011-5-14 12:42 上传 下载附件 (422.22 KB)       2011-5-14 12:42 上传 下载附件 (457.53 KB)          弹出popwindow的代码如下,比较乱,多包涵: 1. popupWindow = new PopupWindow(menuView, LayoutParams.FILL_PARENT, 2.                                 LayoutParams.FILL_PARENT, true); 3.                 popupWindow.showAtLocation(findViewById(R.id.parent), Gravity.CENTER 4.                                 | Gravity.CENTER, 0, 0); 5.                 popupWindow.setAnimationStyle(R.style.PopupAnimation); 6.                 // 加上下面两行可以用back键关闭popupwindow,否则必须调用dismiss(); 7.                 ColorDrawable dw = new ColorDrawable(-00000); 8.                 popupWindow.setBackgroundDrawable(dw); 9.                 popupWindow.update(); 复制代码 下面是实现步骤:    1。背景置灰:      popupWindow = new PopupWindow(menuView, LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT, true);      第二三个参数必须是LayoutParams.FILL_PARENT,这样才能填充整个屏幕,达到背景置灰的目的。      整个popupwindow里面是一个GridView,图片什么的也是用的那个仿UC浏览器界面项目的,在此谢谢了。      关键的东西都在xml里面。 1. <?xml version="1.0" encoding="utf-8"?> 2. <LinearLayout xmlns:android=" 3.            android:orientation="vertical" android:layout_width="fill_parent" 4.             android:gravity="center" android:layout_height="fill_parent" 5.            android:layout_gravity="center" android:background="#b0000000" > 6.          <LinearLayout android:orientation="vertical" 7.                    android:layout_width="wrap_content" android:gravity="center" 8.                    android:layout_height="wrap_content" android:layout_gravity="center" 9.                    android:background="@drawable/downbutton_corner"> 10.                  <GridView android:id="@+id/gridview" android:layout_width="wrap_content" 11.                             android:layout_height="wrap_content" android:numColumns="4" 12.                             android:verticalSpacing="5dip" android:horizontalSpacing="5dip" 13.                             android:stretchMode="columnWidth" android:gravity="center" 14.                             android:layout_gravity="center" /></LinearLayout></LinearLayout> 复制代码 第一个linearlayout里面的android:background="#b0000000",就是全屏背景,网上搜的好多半透明都是“#e0000000”,我觉得那颜色太深,“#b0000000”更合适。 第二个linearlayout是popupwind的背景,里面的android:background="@drawable/downbutton_corner"是关键,边框,圆角都是里面定义的。 2。popupwindow的边框,圆角背景。downbutton_corne.xml 1. <shape xmlns:android=" 2.         android:shape="rectangle"> 3.         <gradient android:startColor="#c0000000" android:endColor="#c0000000" 4.                 android:angle="90" /><!--背景颜色渐变 --> 5.         <stroke android:dashWidth="2dp" android:dashGap="2dp" 6.                 android:width="2dp" android:color="#FF00ff00"></stroke> 7.         <!--描边 --> 8.         <corners android:bottomRightRadius="5dp" 9.                 android:bottomLeftRadius="5dp" android:topLeftRadius="5dp" 10.                 android:topRightRadius="5dp" /><!--设置圆角--> 11. </shape> 复制代码 这个涉及到shape画图,要是不懂的话。网上很多资料,搜一下就是了。我博客里面也有, <gradient android:startColor="#c0000000" android:endColor="#c0000000" android:angle="90" /><!--背景颜色渐变 --> 我就设置了一个固定的颜色"#c0000000"。android:angle="90"这个是设置颜色渐变方向,从上到下啊,从左到右啊,貌似只能90的倍数,也只有四个方向嘛。 <stroke ></stroke>,边框就是这个实现的。 dashWidth指的是边线的宽度 dashGap 指的是每条线之间的间距,(因为是边线是很多小横线组成的)。 3。淡入淡出动画 popupWindow.setAnimationStyle(R.style.PopupAnimation); 这条代码是设置style的,动画文件就是在style文件里面引入的。下面是淡入的动画,动画教程网上也很多。淡出的动画就这些参数值交换位置就是了。android:duration这个是持续时间,为了截图,我把它弄成5秒了。 1. <set xmlns:android=" 2.         <scale android:fromXScale="0.6" android:toXScale="1.0" 3.                 android:fromYScale="0.6" android:toYScale="1.0" android:pivotX="50%" 4.                 android:pivotY="50%" android:duration="5000" /> 5.         <alpha android:interpolator="@android:anim/decelerate_interpolator" 6.                 android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="5000" /> 7. </set> 复制代码
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服