Android带三角形的弹窗,Android实现三角形气泡效果方式汇总

在开发过程中,我们可能会经常遇到这样的需求样式:

7cff9715383e3164aac93dd7f5aad3c7.png

这张图是截取京东消息通知的弹出框,我们可以看到右上方有个三角形的气泡效果,这只是其中一种,三角形的方向还可以是上、下、左、右。

通过截图可以发现,气泡由正三角形和圆角长方形组成,于是可以通过组合来形成三角形气泡的效果,下面我们通过三种方式进行实现。

实现方式:

1、通过.9图进行实现;

2、通过shape方式实现;

3、通过自定义view的方式实现;

实现逻辑:

1、通过.9图进行实现

这种方式就不用说了吧,找你们UI小姐姐切一个.9图,使用即可,不过这种方式的图片需要占一定体积哦。

2、通过shape方式实现

正三角形

android:fromDegrees="45"

android:pivotX="-40%"

android:pivotY="80%">

android:width="15dp"

android:height="15dp" />

倒三角形

android:fromDegrees="45"

android:pivotX="135%"

android:pivotY="15%">

android:width="15dp"

android:height="15dp" />

左三角形

android:fromDegrees="-45"

android:pivotX="85%"

android:pivotY="-35%">>

android:width="15dp"

android:height="15dp" />

右三角形

android:fromDegrees="-45"

android:pivotX="15%"

android:pivotY="135%">>

android:width="15dp"

android:height="15dp" />

上面就是通过shape方式实现各个方向的代码,这种方式缺点比较明显,如果要变化不同的角的位置需要再写不同的布局。

3、通过自定义view的方式实现

由于是比较简单这里就不讲解每个怎么搞了,可以复制过去直接用

添加自定义属性

自定义代码文件

public class TriangleView extends View {

private static final int TOP = 0;

private static final int BOTTOM = 1;

private static final int RIGHT = 2;

private static final int LEFT = 3;

private static final int DEFUALT_WIDTH = 10;

private static final int DEFUALT_HEIGHT = 6;

private static final int DEFUALT_COLOR = R.color.FFF;

private Paint mPaint;

private int mColor;

private int mWidth;

private int mHeight;

private int mDirection;

private Path mPath;

public TriangleView(final Context context) {

this(context, null);

}

public TriangleView(Context context, @Nullable AttributeSet attrs) {

this(context, attrs, 0);

}

public TriangleView(final Context context, final AttributeSet attrs, final int defStyleAttr) {

super(context, attrs, defStyleAttr);

init();

TypedArray typedArray = context.getTheme().obtainStyledAttributes(attrs, R.styleable.TriangleView, 0, 0);

mColor = typedArray.getColor(R.styleable.TriangleView_trv_color, ContextCompat.getColor(getContext(), DEFUALT_COLOR));

mDirection = typedArray.getInt(R.styleable.TriangleView_trv_direction, mDirection);

typedArray.recycle();

mPaint.setColor(mColor);

}

private void init() {

mPaint = new Paint();

mPaint.setAntiAlias(true);

mPaint.setStyle(Paint.Style.FILL);

mPath = new Path();

mDirection = TOP;

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

mWidth = MeasureSpec.getSize(widthMeasureSpec);

mHeight = MeasureSpec.getSize(heightMeasureSpec);

final int widthMode = MeasureSpec.getMode(widthMeasureSpec);

final int heightMode = MeasureSpec.getMode(heightMeasureSpec);

if (mWidth == 0 || widthMode != MeasureSpec.EXACTLY) {

mWidth = (int) PixelUtil.dp2px(DEFUALT_WIDTH);

}

if (mHeight == 0 || heightMode != MeasureSpec.EXACTLY) {

mHeight = (int) PixelUtil.dp2px(DEFUALT_HEIGHT);

}

setMeasuredDimension(mWidth, mHeight);

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

switch (mDirection) {

case TOP:

mPath.moveTo(0, mHeight);

mPath.lineTo(mWidth, mHeight);

mPath.lineTo(mWidth / 2, 0);

break;

case BOTTOM:

mPath.moveTo(0, 0);

mPath.lineTo(mWidth / 2, mHeight);

mPath.lineTo(mWidth, 0);

break;

case RIGHT:

mPath.moveTo(0, 0);

mPath.lineTo(0, mHeight);

mPath.lineTo(mWidth, mHeight / 2);

break;

case LEFT:

mPath.moveTo(0, mHeight / 2);

mPath.lineTo(mWidth, mHeight);

mPath.lineTo(mWidth, 0);

break;

default:

break;

}

mPath.close();

canvas.drawPath(mPath, mPaint);

}

}

布局文件添加

android:layout_width="10dp"

android:layout_height="6dp"

app:trv_color="@color/FFF"

app:trv_direction="top" />

通过自定义的方式可以搞定四个方向,而且在代码中也可以使用,动态添加,动态改变颜色,还是比较好的方式。

到此这篇关于Android实现三角形气泡效果方式汇总的文章就介绍到这了,更多相关Android 三角形气泡 内容请搜索云海天教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持云海天教程!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/296805.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ecno是什么的缩写_美国的英文缩写是什么简写

利坚合众国简称美国,它的英文也是有简写的,就算我们不知道它的全称其缩写也不会忘记。以下是学习啦小编给大家带来美国的英文缩写,以供参阅。美国的英文简写美国的英文缩写:the United States of America (U.S.A.)美国的英文缩写&…

GDI+ 设置文本对齐方式

可通过以下语句来设置文本的对齐方式:StringFormat sF new StringFormat()sF.Alignment StringAlignment.Far; sF.LineAlignment StringAlignment.Far;代码:、View Code privatevoidForm1_Paint(objectsender, PaintEventArgs e) { …

那些视觉上骗了你的东西,你上当了吗?

全世界只有3.14 % 的人关注了爆炸吧知识世界上最离谱的错觉图,看完我瞎了还能不能好好的玩耍了啊!1

微服务组件记事本:本地搭建Skywalking

最近一直在研究微服务,完全避免不了的是各种中间件的使用,打算把过程简要记录下来,过程很简单,也不会有原理和源代码级别的讲解,只是做下简单的知识备份。今天开始研究下链路追踪Skywalking,还记得之前在《…

linux nodejs 采集器,Linux记录-jstack采集namenode gc信息

#!/bin/bash#以hdfs用户执行jstack每分钟采集一次namenode gc日志#mkdir -p /tmp/jstackcd /log/hadoop/jstack_nnpid$(jps | grep -i "namenode" | awk NR1{print $1})dir/log/hadoop/jstack_nn/jstack_nn_date "%Y-%m-%d-%H"if [ ! -d ${dir} ]thenmkdir…

1.1-1.5-vim编辑器

vim是vi的升级版共有3种工作模式:1一般模式 2编辑模式 3命令模式a在光标后插入 i在光标前插入 o在光标下插入新行A在光标行末插入 I在光标行首插入 O在光标上插入新行$光标移动到行尾 0光标移动到行首gg光标到第一行 G光标到最后一行…

UI设计师应了解最终用户的十件事

Ubuntu Unity 刚度过了它的首个周年纪念日,Windows 8也即将发布,这一切都在清晰地说明所有的用户界面并非平等。事实上,创造一个可以改变计算机使用方式、出色的设计是很有可能的——但如果不重视用户体验,这个设计在证明它出色之…

优化见解

所谓的最优化,那就是实现资源的充分利用。而充分利用资源的方法,并不是让优势资源发挥更大潜力,而是让不同资源得到适当地配置,否则也达不到最优化。这就好比摩托车的能效是发挥到极致了,但并不表示整个过程就是极致。…

python路径长度限制_[windows] python 帮忙打开文件名太长限制

不知道你是否有遇到,在windows复制/移动文件的时候发生路径太长以致于无法复制/移动的情况?不知道你是否有遇到,在windows复制/移动文件的时候发生路径太长以致于无法复制/移动的情况?我大概每年发生个四、五次,在备份…

马斯克发布脑机接口重大突破:蓝牙连接,一小时植入,已获FDA认证,人体实验在即...

全世界只有3.14 % 的人关注了爆炸吧知识综合整理自:机器之心、量子位、智东西编辑:知识君伊隆 马斯克神秘的脑机接口公司 Neuralink,终于向人们展示了自己首款可以「进入人体」的产品。今日,在 Neuralink 总部的发布会活动上&…

如何在android客户端中做到自动检查数据更新?,UpdateHelper

软件简介UpdateHelper 是一个为了简化Android App的迭代升级开发的AndroidLibrary,任何一个项目只要引入这个library便集成了在线检查新版本的功能以及下载APK功能,仅需两行代码即可搞定。UpdateHelpers要怎么使用?1.首先服务器端需要提供一个…

【另类见解】那些要保证缓存和数据库数据一致性的最后怎么了?

“现在如果说不出几句如何保证数据一致性方案的话,觉得出去面试都丢人,尤其是缓存和数据库的数据一致性“全程无图,请谨慎阅读缓存对于程序性能而言,无疑是个杀手锏,但不是完美的解决方案。关键在于缓存的物理位置和数据真实保存的…

redhat enterprise linux 5 上安装openoffice3.0 1

1.首先根据自己的计算机情况去下载相应的openoffice.org3.1 for liunx中文版 网址:http://zh.openoffice.org/new/zh_cn/downloads.html 2.解压缩软件,在终端进入RPMS文件中,安装 Java-runtime 支持包。 jre-6-linux-i586.rpm #ta…

3部世界顶级宇宙纪录片,献给对宇宙万物充满好奇的大人孩子~

全世界只有3.14 % 的人关注了爆炸吧知识宇宙深邃美丽,是黑夜的荧光,是夏天里冒着凉气的西瓜,总是诱人地勾起一代又一代人探索的欲望。对于宇宙思索与探索,人类的脚步从未停止。正是人类对宇宙的好奇,撑起了人类发展的大…

再生希尔伯特空间_向量、函数向量、再生核希尔伯特空间、核技巧

参考引用:A Story of Basis and Kernel 来源:http://songcy.net/向量与内积在一个 空间中,我们可以通过 个独立向量的线性组合来表示这个空间里的任意向量。这些独立的向量可以看作是空间里的一组基,基向量互相正交。比如 就是一组…

我的Java开发学习之旅------Base64的编码思想以及Java实现

Base64是一种用64个字符来表示任意二进制数据的方法。 用记事本打开exe、jpg、pdf这些文件时,我们都会看到一大堆乱码,因为二进制文件包含很多无法显示和打印的字符,所以,如果要让记事本这样的文本处理软件能处理二进制数据&#…

工业领域产品经理的尴尬处境

最近和一个1000人规模公司的智能制造部门进行交流,参会人员包括部门领导、技术人员、产品(经理)设计人员等,我介绍了工业信息建设相关理念、钢铁云及其他建设案例、iNeuOS工业互联网系统相关内容,交流期间他们领导说了…

【MyBatis-Plus】分页查询

为什么? 使用分页查询,可以将查询结果分割成多个部分,每次只查询部分数据,从而提高性能、减少内存消耗、提高用户体验和数据安全性。 封装分页查询数据类 分页查询的结果通常包含 4 个字段: page:当前页…

android tabhost黑色背景,android更改FragmentTabHost背景和文本颜色

您必须使用操作栏选项卡为每个选项卡获取不同的颜色。MainActivity.java:强>public class MainActivity extends FragmentActivity {static ViewPager Tab;TabsPagerAdapter TabAdapter;ActionBar actionBar;Overrideprotected void onCreate(Bundle savedInstan…

你永远不知道女生裙子下面藏着什么

1 心不是这样比的。。2 这翻墙技巧满分3 盖了我的章你就是我的人了!4 论道具组可以穷到什么地步5 你永远不知道女生裙子下面藏着什么6 理发店的赶紧来领你的名片,设计好了!7 20190523,就是这样一个本质神奇的日子!图自…