[转]Android_气泡效果
今天先看一个气泡窗口,先看一下效果图和目录结构,然后再上代码

通过第一幅图,我们可以看到一个气泡窗口,这个窗口的结构是里面有2个TextView和1个气泡的背景,这个2个TextView放在了overlay_pop.xml文件中,气泡窗口是这个layout的背景,overlay_pop.xml的代码如下:
- <?xml version="1.0" encoding="UTF-8"?>
- <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:background="@drawable/pub_pop_bg4"
- android:paddingLeft="10dp"
- android:paddingRight="10dp"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content" >
- <TextView android:id="@+id/bubble_text"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:textSize="18dp"
- android:textColor="#000" />
- <!-- 我知道了 -->
- <TextView android:id="@+id/bubble_btn"
- android:gravity="right"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_below="@id/bubble_text"
- android:textSize="20dp"
- android:textColorHighlight="#2151E0"
- android:text=""
- android:textColor="#1A75B9" />
- </RelativeLayout>
- 这是实现功能的全部代码:
- public class TestBubbleActivity extends Activity {
- /** 全局屏幕的高和宽 */
- private static int SCREEN_WIDTH = 0 ;
- private static int SCREEN_HEIGHT = 0;
- /**气泡显示的详细内容*/
- private TextView tvBubContent = null;
- /**显示 我知道了 的提示*/
- private TextView tvKnow = null;
- /**气泡view 里面包含2个TextView*/
- private View bubbleView = null;
- /**气泡dialog*/
- private Dialog bubbleAlert = null;
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- getDimension();
- bubbleView = getLayoutInflater().inflate(R.layout.overlay_pop, null);
- tvKnow = (TextView)bubbleView.findViewById(R.id.bubble_btn);
- tvKnow.setText(Html.fromHtml("<u>"+"我知道了"+"</u>"));
- tvBubContent = (TextView)bubbleView.findViewById(R.id.bubble_text);
- tvBubContent.setText("上次程序异常退出,正在传输历史数据...");
- tvKnow.setOnClickListener(new View.OnClickListener(){
- @Override
- public void onClick(View v) {
- bubbleAlert.cancel();
- }
- });
- int tmpWidth = SCREEN_WIDTH/5*3;
- int tmpHeight =SCREEN_HEIGHT/8;
- //设置TextView宽度
- tvKnow.setMinWidth(tmpWidth);
- tvBubContent.setMaxWidth(tmpWidth);
- //以指定的样式初始化dialog
- bubbleAlert = new Dialog(this,R.style.bubble_dialog);
- Window win = bubbleAlert.getWindow();//获取所在window
- LayoutParams params = win.getAttributes();//获取LayoutParams
- params.x = -(SCREEN_WIDTH/8);//设置x坐标
- params.y = -tmpHeight;//设置y坐标
- params.width = tmpWidth;
- win.setAttributes(params);//设置生效
- bubbleAlert.setCancelable(false);
- bubbleAlert.setContentView(bubbleView);
- bubbleAlert.show();
- }
- /**
- * 获取屏幕尺寸
- */
- private void getDimension(){
- /** 获取屏幕的宽和高 */
- DisplayMetrics dm = new DisplayMetrics();
- getWindowManager().getDefaultDisplay().getMetrics(dm);
- SCREEN_WIDTH = dm.widthPixels;
- SCREEN_HEIGHT = dm.heightPixels;
- }
- }
[转]Android_气泡效果的更多相关文章
- 不用图片,纯Css3实现超酷的类似iphone的玻璃气泡效果
最近在一个私活做手机项目时候,需要实现一个类似ios 6中短信那样的气泡效果. 这里分享下实现心得,希望能给大家一点启发. 首先分析下iphone的气泡效果有一下特点 1. 四面圆角 2. 界面上向下 ...
- HTML5实现微信聊天气泡效果
最近做一个HybridApp,前端有一个群聊的功能,于是就想模仿微信的聊天界面,先看效果图: HTML代码: <!DOCTYPE html> <html lang="en& ...
- canvas实现酷炫气泡效果
canvas实现动画主要是靠设置定时器(setinterval())和定时清除画布里的元素实现,canvas动画上手很简单,今天可以自己动手来实现一个酷炫气泡效果. 气泡炸裂效果(类似水面波纹) 代码 ...
- Android超简单气泡效果
阿里P7移动互联网架构师进阶视频(每日更新中)免费学习请点击:https://space.bilibili.com/474380680最近有用到水下气泡上升效果,因此在网上查了一下资料,结果还真找到了 ...
- Android实现三角形气泡效果方式汇总
在开发过程中,我们可能会经常遇到这样的需求样式: 这张图是截取京东消息通知的弹出框,我们可以看到右上方有个三角形的气泡效果,这只是其中一种,三角形的方向还可以是上.下.左.右. 通过截图可以发现,气泡 ...
- CSS3实现气泡效果
首先定义一个 <p class="speech"></p> 先给外层的容器添加样式: p.speech { position: relative; widt ...
- CSS3效果:实现气泡效果
首先定义一个 <p class="speech"></p> 先给外层的容器添加样式: p.speech { position: relative; widt ...
- css3实现气泡效果的聊天框
因为CSS3尚未形成标准,所以现行的浏览器对于css3支持不太一致,某些特性需要加上浏览器前缀 css属性的浏览器前缀 前缀 渲染引擎 使用该引擎的浏览器 -khtml- KHTML Konquero ...
- css实现聊天气泡效果
--------------------------------------- css功能强大,能实现很多炫 酷的效果,今天给大家分享 用css3绘制聊天气泡的方法: -------------- ...
随机推荐
- 关于MYSQL group by 分组按时间取最大值的实现方法!
类如 有一个帖子的回复表,posts( id , tid , subject , message , dateline ) , id 为 自动增长字段, tid为该回复的主题帖子的id(外键关联), ...
- linux下如何安装配置redis及主从配置
redis的优点:支持主从备份,操作指令丰富,支持异步的数据持久化 将 redis 安装到 /usr/local/webserver/redis 1.下载安装包 wget http://redis.g ...
- 【Linux】用grep在文档中查找内容
有时候,我们需要在文档中查找一些内容,常用grep.它在文档查找相关内容并输出匹配行. > 查找某关键字 在system.log中,查找包含keyword的行 grep 'keyword' sy ...
- c语言中函数调用的本质从汇编角度分析
今天下午写篇博客吧,分析分析c语言中函数调用的本质,首先我们知道c语言中函数的本质就是一段代码,但是给这段代码起了一个名字,这个名字就是他的的这段代码的开始地址 这也是函数名的本质,其实也就是汇编中的 ...
- VC++打开对话框选择一个文件夹路径 BROWSEINFO结构
typedef struct _browseinfoW { HWND hwndOwner; PCIDLIST_ABSOLUTE pidlRoot; LPWSTR pszDisplayName; // ...
- EI表达式和JSTL
JSP九大内置对象 WEB域内置对象(存值取值,传值数据用的) setAttribute/getAttribute; page 基本不用/ pageContext 只在本页面有效 ...
- linux下的基本网络配置
第一种:使用命令修改(直接即时生效,重启失效)#ifconfig eth0 192.168.0.1 netmask 255.255.255.0 up说明:eth0是第一个网卡,其他依次为eth1,et ...
- 7.mybatis一对多关联查询
和第5节一对一查询类似,但是不同的是,一对一使用的是association,而一对多使用collection. 实例: 1个班级Class,对应1个老师Teacher,对应多个学生Student 1. ...
- Eclipse小技巧--快速输入System.out.println();(转)
步骤1:指定“Content Assist”的快捷键,参考:善用 Eclipse 组合键,提高输入效率 步骤2:输入源代码是,先输入sysout,然后输入辅助快捷键:Alt+/,这样就可以自动生成:S ...
- iOS - OC NSUserDefaults 数据存储
前言 @interface NSUserDefaults : NSObject 用来保存应用程序设置和属性.用户保存的数据.用户再次打开程序或开机后这些数据仍然存在.如果往 userDefaults ...