`

android UI进阶之弹窗的使用

阅读更多

其实这是第二遍写这篇博客……浏览器崩溃了。。。我还以为博客园和CSDN的一样自动保存,竟然没有!好吧,没事,重新写过。
年就算过完啦。新年第一篇来讲下android 中的PopupWindow。姑且就叫做弹窗吧,其实和AlertDialog一样,也是一种对话框,两者也经常混用,但是也各有特点。
下面就看看使用方法。首先初始化一个PopupWindow

  1. PopupWindow mPop = new PopupWindow(getLayoutInflater().inflate(R.layout.window, null),
  2. LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
复制代码

实现PopupWindow的构造函数,第一个参数导入布局,后面两个指定宽和高。弹窗一般有两种展示方法,用showAsDropDown()和showAtLocation()两种方法实现。一般参数有两种,有偏移和无偏移。

  1. bt1.setOnClickListener(new OnClickListener(){

  2. @Override
  3. public void onClick(View v) {
  4. initPopWindow();
  5. mPop.showAsDropDown(v);//以这个Button为anchor(可以理解为锚,基准),在下方弹出

  6. }});

  7. bt2.setOnClickListener(new OnClickListener(){

  8. @Override
  9. public void onClick(View v) {
  10. initPopWindow();
  11. mPop.showAsDropDown(v,20,-20);//横轴偏移20,纵轴-20,一个状态栏的长度

  12. }});

  13. bt3.setOnClickListener(new OnClickListener(){

  14. @Override
  15. public void onClick(View v) {
  16. initPopWindow();
  17. mPop.showAtLocation(PopWindow.this.findViewById(R.id.rl),
  18. Gravity.CENTER, 0, 0);//在屏幕居中,无偏移

  19. }});


  20. bt4.setOnClickListener(new OnClickListener(){

  21. @Override
  22. public void onClick(View v) {
  23. initPopWindow();
  24. mPop.showAtLocation(PopWindow.this.findViewById(R.id.rl),
  25. Gravity.TOP | Gravity.LEFT, 20, 20);//在屏幕顶部|居右,带偏移

  26. }});

  27. bt5.setOnClickListener(new OnClickListener(){

  28. @Override
  29. public void onClick(View v) {
  30. if (mPop != null) {
  31. mPop.dismiss();
  32. }

  33. }});
复制代码

其中initPopWindow()方法来初始化一个弹窗

  1. private void initPopWindow() {
  2. if (mPop == null) {
  3. mPop = new PopupWindow(getLayoutInflater().inflate(R.layout.pop, null),
  4. LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
  5. }
  6. if (mPop.isShowing()) {
  7. mPop.dismiss();
  8. }
  9. }
复制代码

这里定义了4个按钮来呈现展示效果,一个按钮用来关闭,来看下第三个按钮点击效果,就不一一截图了,大家可以自己试下。

  看过我以前这系列博客的朋友就会发现,PopupWindow里面的布局就是抽屉里面用的布局,后面的背景就是上篇博客讲的可延伸图像。为什么用这个呢,我们来看下UC的menu效果

可能这个是用AlertDialog做的,但是用PopupWindow也非常方便。很多的应用都使用了这样的menu。这里我就不去仿照UC来做了,就用上面那个布局,原理是一样的,换换图片就行。
要做的很简单,看代码

  1. public boolean onKeyDown(int keyCode, KeyEvent event){ //截获按键事件
  2. if(keyCode == KeyEvent.KEYCODE_MENU){
  3. initPopWindow();
  4. mPop.showAtLocation(this.findViewById(R.id.rl),
  5. Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0); //在屏幕底部
  6. }
  7. else if(keyCode == KeyEvent.KEYCODE_BACK){
  8. if(mPop.isShowing()){
  9. mPop.dismiss();
  10. }else{
  11. System.exit(0);
  12. }
  13. }
  14. return false;
  15. }
复制代码

看下效果

图片似乎不是很给力,大家搞点漂亮点的图片就可以了。
我把这个代码全部贴出来


  1. package com.notice.popWindow;

  2. import android .app.Activity;
  3. import android .os.Bundle;
  4. import android .view.Gravity;
  5. import android .view.KeyEvent;
  6. import android .view.View;
  7. import android .view.View.OnClickListener;
  8. import android .view.ViewGroup.LayoutParams;
  9. import android .widget.Button;
  10. import android .widget.GridView;
  11. import android .widget.PopupWindow;

  12. public class PopWindow extends Activity {
  13. private GridView gv;
  14. private Button bt1;
  15. private Button bt2;
  16. private Button bt3;
  17. private Button bt4;
  18. private Button bt5;
  19. private int[] icons={R.drawable.browser,R.drawable.gallery,
  20. R.drawable.camera,R.drawable.gmail,
  21. R.drawable.music,R.drawable.market,
  22. R.drawable.phone,R.drawable.messages,R.drawable.maps};
  23. private String[] items={"浏览器","图片","相机","时钟","音乐","市场","拨号","信息","地图"};
  24. private PopupWindow mPop;
  25. private View layout;
  26. private void initPopWindow() {
  27. if (mPop == null) {
  28. mPop = new PopupWindow(layout,
  29. LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
  30. }
  31. if (mPop.isShowing()) {
  32. mPop.dismiss();
  33. }
  34. }
  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. bt1 = (Button)findViewById(R.id.bt1);
  41. bt2 = (Button)findViewById(R.id.bt2);
  42. bt3 = (Button)findViewById(R.id.bt3);
  43. bt4 = (Button)findViewById(R.id.bt4);
  44. bt5 = (Button)findViewById(R.id.bt5);
  45. layout = View.inflate(this, R.layout.window, null);
  46. gv = (GridView) layout.findViewById(R.id.gv);
  47. MyAdapter adapter=new MyAdapter(this,items,icons);
  48. gv.setAdapter(adapter);

  49. bt1.setOnClickListener(new OnClickListener(){

  50. @Override
  51. public void onClick(View v) {
  52. initPopWindow();
  53. mPop.showAsDropDown(v);//以这个Button为anchor(可以理解为锚,基准),在下方弹出

  54. }});

  55. bt2.setOnClickListener(new OnClickListener(){

  56. @Override
  57. public void onClick(View v) {
  58. initPopWindow();
  59. mPop.showAsDropDown(v,20,-20);//横轴偏移20,纵轴-20,一个状态栏的长度

  60. }});

  61. bt3.setOnClickListener(new OnClickListener(){

  62. @Override
  63. public void onClick(View v) {
  64. initPopWindow();
  65. mPop.showAtLocation(PopWindow.this.findViewById(R.id.rl),
  66. Gravity.CENTER, 0, 0);//在屏幕居中,无偏移

  67. }});


  68. bt4.setOnClickListener(new OnClickListener(){

  69. @Override
  70. public void onClick(View v) {
  71. initPopWindow();
  72. mPop.showAtLocation(PopWindow.this.findViewById(R.id.rl),
  73. Gravity.TOP | Gravity.LEFT, 20, 20);//在屏幕顶部|居右,带偏移

  74. }});

  75. bt5.setOnClickListener(new OnClickListener(){

  76. @Override
  77. public void onClick(View v) {
  78. if (mPop != null) {
  79. mPop.dismiss();
  80. }

  81. }})


  82. public boolean onKeyDown(int keyCode, KeyEvent event)
  83. //截获按键事?
  84. if(keyCode == KeyEvent.KEYCODE_MENU)
  85. initPopWindow()
  86. mPop.showAtLocation(this.findViewById(R.id.rl)
  87. Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0); //在屏幕底?
  88. }else if(keyCode == KeyEvent.KEYCODE_BACK)
  89. if(mPop.isShowing())
  90. mPop.dismiss()
  91. }else
  92. System.exit(0)



  93. return false


  94. }
复制代码

其中的MyAdapter类可以去看我以前的一篇写抽屉的博客,代码都在里面。然后就是window.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <GridView
  3. xmlns:android ="http://schemas.android .com/apk/res/android "
  4. android :id="@+id/gv"
  5. android :background="@drawable/tbg"
  6. android :layout_width="wrap_content"
  7. android :layout_height="wrap_content"
  8. android :numColumns="3"
  9. android :gravity="center">
  10. </GridView>
复制代码

只有一个GridView。main.xml就不贴了,就几个Button。
当然弹窗的作用不仅限于menu,你还可以用他做的更多来为你UI增色。今天就写到这了,哎,写了好久。有问题可以留言交流

分享到:
评论
1 楼 shuyahui2010 2011-07-27  
楼主能不能发个代码给我,急着用,3Q,shuyahui1015@163.com

相关推荐

Global site tag (gtag.js) - Google Analytics