android UI进阶之弹窗的使用

其实这是第二遍写这篇博客……浏览器崩溃了。。。我还以为博客园和CSDN的一样自动保存,竟然没有!好吧,没事,重新写过。

年就算过完啦。新年第一篇来讲下android中的PopupWindow。姑且就叫做弹窗吧,其实和AlertDialog一样,也是一种对话框,两者也经常混用,但是也各有特点。

下面就看看使用方法。首先初始化一个PopupWindow

 PopupWindow mPop = new PopupWindow(getLayoutInflater().inflate(R.layout.window, null),
 LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);

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

bt1.setOnClickListener(new OnClickListener(){

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

            }});

        bt2.setOnClickListener(new OnClickListener(){

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

            }});

        bt3.setOnClickListener(new OnClickListener(){

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

            }});

        bt4.setOnClickListener(new OnClickListener(){

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

            }});

        bt5.setOnClickListener(new OnClickListener(){

            @Override
            public void onClick(View v) {
                if (mPop != null) {
                    mPop.dismiss();
                }

            }});

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

private void initPopWindow() {
        if (mPop == null) {
            mPop = new PopupWindow(getLayoutInflater().inflate(R.layout.pop, null),
                    LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
        }
        if (mPop.isShowing()) {
            mPop.dismiss();
        }
    }

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

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

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

要做的很简单,看代码

public boolean onKeyDown(int keyCode, KeyEvent event){
        //截获按键事件
        if(keyCode == KeyEvent.KEYCODE_MENU){
                initPopWindow();
                mPop.showAtLocation(this.findViewById(R.id.rl),
                        Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0); //在屏幕底部
        }else if(keyCode == KeyEvent.KEYCODE_BACK){
            if(mPop.isShowing()){
                mPop.dismiss();
            }else{
                System.exit(0);
            }

        }
        return false;

    }

看下效果

图片似乎不是很给力,大家搞点漂亮点的图片就可以了。

我把这个代码全部贴出来

package com.notice.popWindow;

 import android.app.Activity;
 import android.os.Bundle;
 import android.view.Gravity;
import android.view.KeyEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.Button;
import android.widget.GridView;
import android.widget.PopupWindow;

public class PopWindow extends Activity {
     private GridView gv;
     private Button bt1;
     private Button bt2;
     private Button bt3;
     private Button bt4;
     private Button bt5;
     private int[] icons={R.drawable.browser,R.drawable.gallery,
                           R.drawable.camera,R.drawable.gmail,
                           R.drawable.music,R.drawable.market,
                           R.drawable.phone,R.drawable.messages,R.drawable.maps};
     private String[] items={"浏览器","图片","相机","时钟","音乐","市场","拨号","信息","地图"};
     private PopupWindow mPop;
     private View layout;
     private void initPopWindow() {
        if (mPop == null) {
            mPop = new PopupWindow(layout,
                    LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
        }
        if (mPop.isShowing()) {
            mPop.dismiss();
        }
    }
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        bt1 = (Button)findViewById(R.id.bt1);
        bt2 = (Button)findViewById(R.id.bt2);
        bt3 = (Button)findViewById(R.id.bt3);
        bt4 = (Button)findViewById(R.id.bt4);
        bt5 = (Button)findViewById(R.id.bt5);
        layout = View.inflate(this, R.layout.window, null);
        gv = (GridView) layout.findViewById(R.id.gv);
        MyAdapter adapter=new MyAdapter(this,items,icons);
        gv.setAdapter(adapter);

        bt1.setOnClickListener(new OnClickListener(){

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

            }});

        bt2.setOnClickListener(new OnClickListener(){

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

            }});

        bt3.setOnClickListener(new OnClickListener(){

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

            }});

        bt4.setOnClickListener(new OnClickListener(){

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

            }});

        bt5.setOnClickListener(new OnClickListener(){

            @Override
            public void onClick(View v) {
                if (mPop != null) {
                    mPop.dismiss();
                }

            }});

    }
    public boolean onKeyDown(int keyCode, KeyEvent event){
        //截获按键事件
        if(keyCode == KeyEvent.KEYCODE_MENU){
                initPopWindow();
                mPop.showAtLocation(this.findViewById(R.id.rl),
                        Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0); //在屏幕底部
        }else if(keyCode == KeyEvent.KEYCODE_BACK){
            if(mPop.isShowing()){
                mPop.dismiss();
            }else{
                System.exit(0);
            }

        }
        return false;

    }
}

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

<?xml version="1.0" encoding="utf-8"?>
 <GridView
       xmlns:android="http://schemas.android.com/apk/res/android"
      android:id="@+id/gv"
      android:background="@drawable/tbg"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:numColumns="3"
      android:gravity="center">
 </GridView>

只有一个GridView。main.xml就不贴了,就几个Button。

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

引用:

http://www.cnblogs.com/noTice520/archive/2011/02/15/1955541.html

时间: 2024-10-28 11:27:45

android UI进阶之弹窗的使用的相关文章

android UI进阶之实现listview中checkbox的多选与记录

今天继续和大家分享涉及到listview的内容.在很多时候,我们会用到listview和checkbox配合来提供给用户一些选择操作.比如在一个清单页面,我们需要记录用户勾选了哪些条目.这个的实现并不太难,但是有很多朋友来问我如何实现,他们有遇到各种各样的问题,这里就一并写出来和大家一起分享. ListView的操作就一定会涉及到item和Adapter,我们还是先来实现这部分内容. 首先,写个item的xml布局,里面放置一个TextView和一个CheckBox.要注意的时候,这里我设置了C

android UI进阶之实现listview的分页加载

 分享了下拉刷新,这是一个用户体验非常好的操作方式.新浪微薄就是使用这种方式的典型. 还有个问题,当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了.通过分页分次加载数据,用户看多少就去加载多少. 通常这也分为两种方式,一种是设置一个按钮,用户点击即加载.另一种是当用户滑动到底部时自动加载.今天我就和大家分享一下这个功能的实现. 首先,

【转】android UI进阶之自定义组合控件

[源地址]http://blog.csdn.net/notice520/article/details/6667827 好久没写博客了.实在是忙不过来,不过再不总结总结真的不行了.慢慢来吧,有好多需要去总结的,博客里还是记录ui方面的. 今天和大家分享下组合控件的使用.很多时候android自定义控件并不能满足需求,如何做呢?很多方法,可以自己绘制一个,可以通过继承基础控件来重写某些环节,当然也可以将控件组合成一个新控件,这也是最方便的一个方法.今天就来介绍下如何使用组合控件,将通过两个实例来介

Android UI组件进阶(2)——仿Windows对话框

Android UI组件进阶(2)--仿Windows对话框 在开始本章前先祝大家中秋节快乐哈,相信很多上班的朋友都是放三天假的哈! 有时间的话回家陪陪父母吧!树欲静而风不止,子欲养而亲不待!岁月不饶人! 好了,道理和祝福语就说到这里了,今天给大家准备的是模仿Windows风格对话框! 效果图: 相信大部分的AlertDialog都是下面这个样子的: 今天给大家讲解的对话框是下面这样的: 对比两种对话框,站在用户的角度,相信你更加钟情于第二种颜色鲜明的对话框 好了下面就开始讲解如何制作模仿win

Android更新Ui进阶精解(二)

<代码里的世界> 用文字札记描绘自己 android学习之路 转载请保留出处 by Qiao http://blog.csdn.net/qiaoidea/article/details/45115047 Android更新Ui进阶精解(一) android ui线程检查机制 Android更新Ui进阶精解(二) android 线程更新UI机制 1.回顾 第一篇讲了对Ui线程更新的方法和见解,然后接着讲了线程检查机制,这里来详细分析下更新Ui的核心--Android中消息系统模型.当然,这里要

Android UI组件进阶(1)——带进度条的按钮

Android UI组件进阶(1)--带进度条的按钮 本节引言: 这个系列是继Android UI组件实例大全后的进阶系列,在该系列中我们将进一步的学习 Android UI组件,建议阅读本系列前线学习下UI组件实例大全系列,掌握基本组件的使用; 当然你也可以直接学习本系列!好了,废话不多说,直接开始第一节吧!本节要演示的是: 带进度条的按钮!相信大家在360手机助手到看到这个东东吧: 本节要实现的就是下方这个点击后显示进度的按钮 效果图: 必备基础: 1.进度条的一些属性: backgroun

Android UI 优化——使用HierarchyViewer工具

进入正题,我们这一篇文章会提到为什么使用HierarchyViewer,怎么使用HierarchyViewer,后者内容会多一下. 为什么使用HierarchyViewer 不合理的布局会使我们的应用程序UI性能变慢,HierarchyViewer能够可视化的角度直观地获得UI布局设计结构和各种属性的信息,帮助我们优化布局设计.HierarchyViewer是我们优化程序的工具之一,它是Android自带的非常有用的工具,可以帮助我们更好地检视和设计用户界面(UI),绝对是UI检视的利器. 怎么

Android高手进阶教程(二十八)之---Android ViewPager控件的使用(基于ViewPager的横向相册)!!!

分类: Android高手进阶 Android基础教程 2012-09-14 18:10 29759人阅读 评论(35) 收藏 举报 android相册layoutobjectclassloaderencoding 大家好,相信大家用的ListView控件一定很多的,是竖向滑动的,复用convertView,我们可以加载成千上万的数据,但有时候我们会有 这个需求比如相册,我们想横向滑动,并且数据有好多,这时候ViewPager控件就派上用场了,ViewPager使用时候我们需要导入第三方包 an

Android UI相关开源项目库汇总

最近做了一个Android UI相关开源项目库汇总,里面集合了OpenDigg 上的优质的Android开源项目库,方便移动开发人员便捷的找到自己需要的项目工具等,感兴趣的可以到GitHub上给个star. 抽屉菜单 MaterialDrawer ★7337 - 安卓抽屉效果实现方案 Side-Menu.Android ★3865 - 创意边侧菜单 FlowingDrawer ★1744 - 向右滑动流动抽屉效果 SlidingRootNav ★1338 - 仿DrawerLayout的View