返回顶部
首页 > 资讯 > 移动开发 >android自定义带箭头对话框
  • 702
分享到

android自定义带箭头对话框

2024-04-02 19:04:59 702人浏览 独家记忆
摘要

本文实例为大家分享了Android自定义带箭头对话框的具体代码,供大家参考,具体内容如下 import android.content.Context; import andr

本文实例为大家分享了Android自定义带箭头对话框的具体代码,供大家参考,具体内容如下


import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.canvas;
import android.graphics.Paint;
import android.graphics.Path;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.Gravity;
 
import com.sankuai.shanGou.stone.util.DensityUtil;
import com.sankuai.waimai.store.search.R;
 

public class BubbleArrowTextView extends android.support.v7.widget.AppCompatTextView {
 
 private final static int TRIANGLE_DIRECTION_TOP = 1;
 private final static int TRIANGLE_DIRECTION_BOTTOM = 2;
 private final static int TRIANGLE_DIRECTION_LEFT = 1;
 private final static int TRIANGLE_DIRECTION_RIGHT = 2;
 
 
 private Paint mPaint;
 private Paint mStrokePaint;
 
 private int mBGColor;
 private int mStrokeColor;
 private int mStrokeWidth;
 private int mTotalHeight;
 private int mTotalWidth;
 private int mLabelHeight;
 private int mTriangleHeight;
 private int mTriangleWidth;
 private int mRadius;
 private int triangleDirection;
 
 public BubbleArrowTextView(Context context) {
 this(context, null);
 }
 
 public BubbleArrowTextView(Context context,
  @Nullable AttributeSet attrs) {
 this(context, attrs, 0);
 }
 
 public BubbleArrowTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
 super(context, attrs, defStyleAttr);
 init(context, attrs, defStyleAttr);
 }
 
 public void init(Context context, AttributeSet attrs, int defStyleAttr) {
 if (attrs != null) {
  TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.BubbleArrowTextView);
  mBgColor = a.getColor(R.styleable.BubbleArrowTextView_bubbleColor, 0);
  mStrokeColor = a.getColor(R.styleable.BubbleArrowTextView_bubbleStrokeColor, 0);
  mRadius = a.getDimensionPixelOffset(R.styleable.BubbleArrowTextView_bubbleRadius, 0);
  mStrokeWidth = a.getDimensionPixelOffset(R.styleable.BubbleArrowTextView_bubbleStrokeWidth, 0);
  mTriangleHeight = a.getDimensionPixelOffset(R.styleable.BubbleArrowTextView_triangleHeight,
   DensityUtil.dip2px(context, 6));
  mTriangleWidth = a.getDimensionPixelOffset(R.styleable.BubbleArrowTextView_triangleWidth, DensityUtil.dip2px(context, 3.5f));
  triangleDirection = a.getInt(R.styleable.BubbleArrowTextView_triangleDirection, 0);
  a.recycle();
 }
 
 setGravity(Gravity.CENTER);
 initPaint();
 }
 
 //初始化画笔
 public void initPaint() {
 mPaint = new Paint();
 mPaint.setAntiAlias(true);
 mPaint.setStyle(Paint.Style.FILL);
 mPaint.setTextSize(getPaint().getTextSize());
 mPaint.setDither(true);
 }
 
 //初始化边框线画笔
 public void initStrokePaint() {
 mStrokePaint = new Paint();
 mStrokePaint.setAntiAlias(true);
 mStrokePaint.setStyle(Paint.Style.FILL);
 mStrokePaint.setDither(true);
 }
 
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
 super.onMeasure(widthMeasureSpec, heightMeasureSpec);
 mLabelHeight = getFontHeight() + getPaddingTop() + getPaddingBottom();
 mTotalHeight = mLabelHeight + mTriangleHeight * 2 + mStrokeWidth * 2;
 mTotalWidth = getPaddingLeft() + getFontWidth() + getPaddingRight() + mStrokeWidth * 2;
 setMeasuredDimension(mTotalWidth, mTotalHeight);
 }
 @Override
 protected void onDraw(Canvas canvas) {
 drawView(canvas);
 super.onDraw(canvas);
 }
 
 //绘制气泡
 private void drawView(Canvas canvas) {
 if (mStrokeColor != 0 && mStrokeWidth != 0) {
  initStrokePaint();
  mStrokePaint.setColor(mStrokeColor);
  drawRound(canvas, mStrokePaint, 0);
  drawTriangle(canvas, mStrokePaint, 0);
 }
 if (mBgColor != 0) {
  mPaint.setColor(mBgColor);
  drawRound(canvas, mPaint, mStrokeWidth);
  drawTriangle(canvas, mPaint, mStrokeWidth);
 }
 }
 
 //绘制矩形
 private void drawRound(Canvas canvas, Paint paint, int strokeWidth) {
 canvas.drawRoundRect(strokeWidth, mTriangleHeight + strokeWidth,
  mTotalWidth - strokeWidth, mTotalHeight - mTriangleHeight - strokeWidth,
  mRadius, mRadius, paint);
 }
 
 //绘制三角形
 private void drawTriangle(Canvas canvas, Paint paint, int strokeWidth) {
 Path path = new Path();
 switch (triangleDirection) {
  //上
  case TRIANGLE_DIRECTION_TOP:
  path.moveTo(mTotalWidth * 0.8f - mTriangleWidth / 2 + strokeWidth / 2, mTriangleHeight + strokeWidth);
  path.lineTo(mTotalWidth * 0.8f, strokeWidth + strokeWidth / 2);
  path.lineTo(mTotalWidth * 0.8f + mTriangleWidth / 2 - strokeWidth / 2, mTriangleHeight + strokeWidth);
  break;
  //下
  case TRIANGLE_DIRECTION_BOTTOM:
  path.moveTo(mTotalWidth * 0.8f - mTriangleWidth/2 + strokeWidth / 2, mTotalHeight - mTriangleHeight
   - strokeWidth);
  path.lineTo(mTotalWidth * 0.8f, mTotalHeight - strokeWidth - strokeWidth / 2);
  path.lineTo(mTotalWidth * 0.8f + mTriangleWidth/2 - strokeWidth / 2, mTotalHeight - mTriangleHeight
   - strokeWidth);
  break;
  default:
  return;
 }
 canvas.drawPath(path, paint);
 }
 
 //根据字号求字体高度
 private int getFontHeight() {
 Paint.FontMetrics fontMetrics = mPaint.getFontMetrics();
 return Math.round(fontMetrics.descent - fontMetrics.ascent);
 }
 
 //根据字号求字体宽度
 private int getFontWidth() {
 return (int) mPaint.measureText(getText().toString());
 }
} 

xml:


<declare-styleable name="BubbleArrowTextView">
  <attr name="bubbleColor" fORMat="reference|color" />
  <attr name="bubbleStrokeColor" format="reference|color" />
  <attr name="bubbleStrokeWidth" format="dimension" />
  <attr name="triangleHeight" format="dimension" />
  <attr name="triangleWidth" format="dimension" />
  <attr name="bubbleRadius" format="dimension" />
  <attr name="triangleDirection">
   <flag name="top" value="1" />
   <flag name="bottom" value="2" />
  </attr>
</declare-styleable>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: android自定义带箭头对话框

本文链接: https://lsjlt.com/news/121622.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作