当前位置: 代码迷 >> Android >> Android面试时的有关问题,实现半透明的popupwindow
  详细解决方案

Android面试时的有关问题,实现半透明的popupwindow

热度:43   发布时间:2016-05-01 11:45:17.0
Android面试时的问题,实现半透明的popupwindow

昨天上午去了个面试,公司名我就不说了。面我那哥们问我有没有实现过半透明的popupwindow。哎,俺实在,没有做过那就是没有做过。估计那哥们也没打算要我,嫌我经验不够,我也没有舌灿莲花那种口才。公司老总说要求签卖身契,3年合同,3年之内辞职要赔钱。3年时间何其漫长,要是公司留得住人,不用签卖身契照样生意兴隆,人才(财)滚滚而来。现在打算去广州了,女朋友一个人在那边,男人嘛,该承担还是得承担,论坛里哪位兄弟公司需要招人,能不能推荐一下,最好在广州的,不胜感激,谢谢。
不罗嗦了,言归正传。。。
下午回来想想不爽,这个东西我还真要把它弄出来。网上搜了一下,没合适的,最多的就是两种:
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源码里面弄出来的。

?


? ?? ? 上面的代码就不贴了,我上传的项目文件里面也有。
? ?? ???下面是弹出popupwindow的图片,第一张是动画中,第二张是完全弹出的:

?

?

?



??


? ?? ?? ?弹出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="http://schemas.android.com/apk/res/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="http://schemas.android.com/apk/res/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画图,要是不懂的话。网上很多资料,搜一下就是了。我博客里面也有,http://blog.csdn.net/ymdcr/archive/2010/12/01/6048256.aspx
<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="http://schemas.android.com/apk/res/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>
复制代码



大概就是这些了。

还有一个关键的问题。弹出pop之后,back键无效了,必须在pop里面设置事件dismiss掉。下面是问题的描述,哪位解决了,告诉我一下,谢谢。我的邮箱:[email protected]

问题解决了,是因为没设置背景的原因。? ??
popupWindow.setBackgroundDrawable(new BitmapDrawable());
//把这一行放在
showAtLocation前面就行了,以前是放在后面的,粗心了。
popupWindow.showAtLocation(findViewById(R.id.parent), Gravity.CENTER
? ?? ?? ?? ?? ? | Gravity.CENTER, 0, 0);
??
网上也有很多人说,弹出pop之后,不响应键盘事件了,这个其实是焦点在pop里面的view去了。
以这个为例,焦点就在gridview上面去了。28楼的兄弟提示的,谢了。
在gridview加上
setOnKeyListener,就能解决。
  1. menuGrid.setOnKeyListener(new OnKeyListener() {
  2. ? ?? ?? ?? [email protected]
  3. ? ?? ?? ?? ?public boolean onKey(View v, int keyCode, KeyEvent event) {
  4. ? ?? ?? ?? ?? ? switch (keyCode) {
  5. ? ?? ?? ?? ?? ? case KeyEvent.KEYCODE_MENU:
  6. ? ?? ?? ?? ?? ?? ???if (popupWindow != null && popupWindow.isShowing()) {
  7. ? ?? ?? ?? ?? ?? ?? ?? ?popupWindow.dismiss();
  8. ? ?? ?? ?? ?? ?? ?? ?? ?System.out.println("menuGridfdsfdsfdfd");
  9. ? ?? ?? ?? ?? ?? ???}
  10. ? ?? ?? ?? ?? ?? ???break;
  11. ? ?? ?? ?? ?? ? }
  12. ? ?? ?? ?? ?
  13. ? ?? ?? ?? ?? ? return true;
  14. ? ?? ?? ?? ?}
  15. ? ?? ???});
复制代码
[ code]/**
? ???* ColorDrawable dw = new ColorDrawable(-00000);
? ???* popupWindow.setBackgroundDrawable(dw);
? ???* 本来看了个示例,加上上面这两行就不用调用dismiss,点击窗口之外的部位,或者按back键都能关闭窗口。 但是我这样写了,还是不行。
? ???* 而且竟然捕获不到键盘事件,杯具,希望哪个解决了这个问题告诉我,[email protected]
? ???*/
? ? /*
? ???* @Override public boolean onKeyDown(int keyCode, KeyEvent event) { switch
? ???* (keyCode) { case KeyEvent.KEYCODE_BACK: if (popupWindow != null) {
? ???* popupWindow.dismiss(); }
? ???*
? ???* Toast.makeText(this, "fd", 1000).show(); break;
? ???*
? ???* } return super.onKeyUp(keyCode, event); }
? ???*/[/code]

?

  相关解决方案