最近写程序第一次用到了PopupWindow,便简单了学习了一下。特此记下自己的收获。PopupWindow是一种悬浮框,比AlertDialog要灵活的多。先简单了实现一个PopWindow的效果,然后再一下相应的总结吧。因为有些东西,如果没有代码的话是很难说的清楚的。先说明,PopupWindow是位于android.widget.PopupWindow包下面的,方便你查看源码。

一、简单实现一个PopupWindow

先看一个实现的效果图吧。如下:

效果说明:最底部就是一个PopupWindow,只要点击popWindow按钮,就会从底部的位置弹出来。下面我们就开始写代码吧。

新建项目,然后修改它的activity_main.xml,代码如下:

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bgd"
android:orientation="vertical"> <TextView
android:id="@+id/tv"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="我是PupopWindow的背景"
android:textSize="30sp"
/> -->
<Button
android:id="@+id/btn_reflect"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="popWindow"
/> </LinearLayout>

代码超级简单,就不用我说了,然后再为PopupWindow写布局,新建pup.xml,代码如下:

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"> <Button
android:id="@+id/btn_pop"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="我是按钮"
/>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="我是PupopWindow"
android:textSize="30sp"/> </LinearLayout>

代码不解释了。接着呢,就是为PopupWindow准备动画了。首先在res下建立文件夹anim。然后再里面新建anim_enter.xml。代码如下:

 <?xml version="1.0" encoding="utf-8"?>
<translate
xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXDelta="0"
android:toXDelta="0"
android:fromYDelta="100%"
android:toYDelta="0"
android:duration="300"> </translate>

然后再在里面新建anim_exit.xml,代码如下:

 <?xml version="1.0" encoding="utf-8"?>
<translate
xmlns:android="http://schemas.android.com/apk/res/android"
android:fromXDelta="0"
android:toXDelta="0"
android:fromYDelta="0"
android:toYDelta="100%"
android:duration="300"> </translate>

最后在values文件夹下的styles.xml添加语句:

 <resources>

     <!--
Base application theme, dependent on API level. This theme is replaced
by AppBaseTheme from res/values-vXX/styles.xml on newer devices.
-->
<style name="AppBaseTheme" parent="android:Theme.Light">
<!--
Theme customizations available in newer API levels can go in
res/values-vXX/styles.xml, while customizations related to
backward-compatibility can go here.
-->
</style> <!-- Application theme. -->
<style name="AppTheme" parent="AppBaseTheme">
<!-- All customizations that are NOT specific to a particular API-level can go here. -->
</style>
<style name="pupopWindow_anim">
<item name="android:windowEnterAnimation">@anim/anim_enter</item>
<item name="android:windowExitAnimation">@anim/anim_exit</item>
</style> </resources>

绿色部分,即第19到22行就是添加的代码。这个style就是为PopupWindow准备的动画了,即进入和退出时的动画。

最后修改MainActiivty的代码,在这里面将PopWindow显示出来即可。代码如下:

 package com.fuly.kun;

 import android.os.Bundle;
import android.app.Activity;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.Button;
import android.widget.PopupWindow;
import android.widget.Toast; public class MainActivity extends Activity { private Button btnReflect;
private PopupWindow popWindow; protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); btnReflect = (Button) findViewById(R.id.btn_reflect); btnReflect.setOnClickListener(new OnClickListener() { public void onClick(View v) { showPupopWindow();//显示出popWindow
}
});
} /**
* 将PupopWindow显示出来
*/
private void showPupopWindow() {
//PupopWindow的view
View pupView = LayoutInflater.from(this).inflate(R.layout.pup, null); Button btn = (Button) pupView.findViewById(R.id.btn_pop);
btn.setOnClickListener(new OnClickListener() { public void onClick(View v) { Toast.makeText(getApplicationContext(), "我是popWindow的按钮", Toast.LENGTH_SHORT).show();
}
}); //实例化PupopWindow,参数中直接为其设置了view以及它的宽和高
popWindow = new PopupWindow(pupView, LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); //设置PupopWindow捕获焦点
popWindow.setFocusable(true); popWindow.setTouchable(true);//设置popWindow可点击 //为popWindow设置背景
ColorDrawable cd = new ColorDrawable(Color.parseColor("#FFFF00"));
popWindow.setBackgroundDrawable(cd); //为popWindow设置进入和退出动画
popWindow.setAnimationStyle(R.style.pupopWindow_anim);
//将popWindwo显示出来
popWindow.showAtLocation(this.findViewById(R.id.tv), Gravity.BOTTOM, 0, 0);
} }

代码注释很详细,逻辑也超级简单。运行程序,就是前面我们贴出来的效果了。

二、总结

总结一下在使用PopWindow时常用的方法吧,更详细的可以翻看API文档。如下:

  • showAsDropDown(View anchor):相对某个控件的位置(正左下方),无偏移
  • showAsDropDown(View anchor, int xoff, int yoff):相对某个控件的位置,有偏移
  • showAtLocation(View parent, int gravity, int x, int y):相对于父控件的位置(例如正中央Gravity.CENTER,下方Gravity.BOTTOM等),可以设置偏移或无偏移
  • setFocusable(true):设置捕获焦点,默认为false
  • setTouchable(true):设置PopupWindow可点击,默认为true。如果为false,则Touch事件或者点击事件会传递给下面的view,PopupWindow不处理。
  • setOutsideTouchable(true):设置PopWindow的外部区域可点击,默认为false。只有当PopupWindow没有获取焦点且是可点击的,设置这个值才有意义。
  • setTouchInterceptor(new OnTouchListener()):设置PopupWindow监听所有的触摸事件
  • 为PopupWindow设置背景:ColorDrawable cd = new ColorDrawable(Color.parseColor("#FFFF00"));
                          popWindow.setBackgroundDrawable(cd);

  • setAnimationStyle(R.style.pupopWindow_anim):为PopupWindow设置动画(进入动画和退出动画)
  • dismiss():退出

注意事项:

可能会出现问题,点击PupopWindow外部区域无效。此时给PupopWindow设置好背景就可以了。所以为了避免出现问题,一定要给其设置背景,哪怕是透明的。

PopupWindow学习笔记的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  3. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  4. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  5. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  6. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  7. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  8. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

  9. DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记

    今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...

随机推荐

  1. TXSQL:云计算时代数据库核弹头——云+未来峰会开发者专场回顾

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 5月23-24日,以"焕启"为主题的腾讯"云+未来"峰会在广州召开,广东省各级政府机构领导.海内外业 ...

  2. 深入理解JavaScript系列(38):设计模式之职责链模式

    介绍 职责链模式(Chain of responsibility)是使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系.将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象 ...

  3. Centos7 linux下 安装 Redis 5.0

    网上找了很多文章,发现不全而且有些问题,安装很多次之后,总结一篇可以使用的,记录之. 环境:Centos7+Redis 5.0,如果环境不符合,本篇仅供参考. 1.准备工作 作者习惯软件安装包放在单独 ...

  4. java 的底层通信--Socket

    以前一直不太重视java 基础的整理,感觉在实际开发中好像java 基础用处不大,感觉不理解一些底层的东西对开发工作影响也不大.不过,后来我发现,很多东西都是相互联系的,如果底层的东西你不理解,后面的 ...

  5. 九 ServerSocketChannel

    ServerSocketChannel是一个可以监听进来的TCP连接的通道,就像标准IO的ServerSocket一样.ServerSocketChannel类在java.nio.channels包中 ...

  6. nginx关于 error_page指令详解.md

    error_page指令解释 nginx指令error_page的作用是当发生错误的时候能够显示一个预定义的uri,比如: error_page 502 503 /50x.html; 这样实际上产生了 ...

  7. ASP.NET MVC中,前台DropDownList传值给后台。

    List<SelectListItem> ZH = new List<SelectListItem>(); ZH.Add(new SelectListItem { Text = ...

  8. SSIS 和 SSRS自制Template

    可以使用VS 制作一个SSIS 的Package. 路径:C:\Program Files\Microsoft Visual Studio 9.0\Common7\IDE\PrivateAssembl ...

  9. 解决Non-resolvable parent POM: Could not find artifact 出现的问题

    在编译spring boot 多模块项目的时候,往往出现 Non-resolvable parent POM: Could not find artifact 后面跟一串其它信息,网上大部分解决方案是 ...

  10. .NET开源工作流RoadFlow-流程运行-运行时监控

    流程实例参与者都可以随时查看流程实例的运行情况,如果是待办任务,则在待办事项列表的后面点查看,如果是已完成任务则可以在已办事项列表的后面点查看: 打开之后默认为列表方式显示流程的处理过程,还可以点图形 ...