老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

Android實現掃一掃功能之繪制指定區域透明區域

一、概述

創新互聯公司是一家專業提供都安企業網站建設,專注與做網站、成都網站設計H5技術、小程序制作等業務。10年已為都安眾多企業、政府機構等服務。創新互聯專業網站設計公司優惠進行中。

在實現掃一掃的功能的時候,我們需要繪制一個中間為透明的掃碼框,其余部分為半透明。通常情況下,例如微信或者支付寶的掃碼框都是矩形的,如果中間的掃碼框是一個矩形,那么布局是很簡單的,可是如果掃碼框是一個圓角矩形,或者圓形等情況怎么辦呢?這篇文章主要是記錄繪制一個中間透明帶圓角的矩形。

按照慣例,我們先來看看效果圖 :

Android實現掃一掃功能之繪制指定區域透明區域

二、按照流程我們就開始來看看代碼啦

1、CustomDrawable,支持中間出現透明區域的drawable

package per.juan.scandome;

import android.graphics.Canvas;
import android.graphics.ColorFilter;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.drawable.Drawable;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;

/**
 * 支持中間出現透明區域的drawable
 * 通過{@link #setSrcPath(Path)}設定透明區域的形狀
 * Created by juan on 2018/07/20.
 */
public class CustomDrawable extends Drawable {
 private Paint srcPaint;
 private Path srcPath = new Path();

 private Drawable innerDrawable;


 public CustomDrawable(Drawable innerDrawable) {
  this.innerDrawable = innerDrawable;
  srcPath.addRect(100, 100, 200, 200, Path.Direction.CW);
  srcPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
  srcPaint.setColor(0xffffffff);
 }

 /**
  * 設置內部透明的部分
  *
  * @param srcPath
  */
 public void setSrcPath(Path srcPath) {
  this.srcPath = srcPath;
 }

 @Override
 public void draw(@NonNull Canvas canvas) {
  innerDrawable.setBounds(getBounds());
  if (srcPath == null || srcPath.isEmpty()) {
   innerDrawable.draw(canvas);
  } else {
   //將繪制操作保存到新的圖層,因為圖像合成是很昂貴的操作,將用到硬件加速,這里將圖像合成的處理放到離屏緩存中進行
   int saveCount = canvas.saveLayer(0, 0, canvas.getWidth(), canvas.getHeight(), srcPaint, Canvas.ALL_SAVE_FLAG);

   //dst 繪制目標圖
   innerDrawable.draw(canvas);

   //設置混合模式
   srcPaint.setXfermode(new PorterDuffXfermode(PorterDuff.Mode.CLEAR));
   //src 繪制源圖
   canvas.drawPath(srcPath, srcPaint);
   //清除混合模式
   srcPaint.setXfermode(null);
   //還原畫布
   canvas.restoreToCount(saveCount);
  }
 }

 @Override
 public void setAlpha(int alpha) {
  innerDrawable.setAlpha(alpha);
 }

 @Override
 public void setColorFilter(@Nullable ColorFilter colorFilter) {
  innerDrawable.setColorFilter(colorFilter);
 }

 @Override
 public int getOpacity() {
  return innerDrawable.getOpacity();
 }
}

(1)主要用到的技術是PorterDuffXfermode的PorterDuff.Mode.XOR模式

(2)核心思想是先正常繪制出整個drawable,然后將指定的區域混合成透明色

2、CustomLayout

package per.juan.scandome;

import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Path;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.view.View;
import android.widget.FrameLayout;

/**
 * 根據layout中子View的位置,確定局部透明區域
 * Created by juan on 2018/07/20.
 */
public class CustomLayout extends FrameLayout {

 private Context mContext;
 private CustomDrawable background;

 public CustomLayout(@NonNull Context context) {
  super(context);
  initView(context, null, 0);
 }

 public CustomLayout(@NonNull Context context, @Nullable AttributeSet attrs) {
  super(context, attrs);
  this.mContext=context;
  initView(context, attrs, 0);
 }

 public CustomLayout(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
  super(context, attrs, defStyleAttr);
  initView(context, attrs, defStyleAttr);
 }

 @SuppressLint("NewApi")
 private void initView(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
  background = new CustomDrawable(getBackground());
  setBackground(background);
 }

 @Override
 protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
  super.onLayout(changed, left, top, right, bottom);
  resetBackgroundHoleArea();
 }

 @SuppressLint("NewApi")
 private void resetBackgroundHoleArea() {
  Path path = null;
  // 以子View為范圍構造需要透明顯示的區域
  View view = findViewById(R.id.iv_scan);
  if (view != null) {
   path = new Path();
   // 矩形透明區域
   path.addRoundRect(view.getLeft(), view.getTop(), view.getRight(), view.getBottom(), dp2Px(mContext,10), dp2Px(mContext,10),Path.Direction.CW);
  }
  if (path != null) {
   background.setSrcPath(path);
  }
 }

 public int dp2Px(Context context, float dp) {
  final float scale = context.getResources().getDisplayMetrics().density;
  return (int) (dp * scale + 0.5f);
 }
}

3、然后在XML布局中聲明我們的自定義View

<?xml version="1.0" encoding="utf-8"?>


 

 

  
  

 

好了,本篇文章就這樣了,存在不足的地方還望指導,感謝^_^

附錄:

自定義Drawable之:在Drawable中部指定透明區域

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對創新互聯的支持。


名稱欄目:Android實現掃一掃功能之繪制指定區域透明區域
分享網址:http://www.xueling.net.cn/article/jeieih.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 午夜成熟看A级毛片 | 精产国品一二三区 | 偷拍25位美女撒尿bbb片户外 | 挺进陈书婷雪白大腿呻吟 | 天天干天天操天天拍 | 亚洲精品午夜一区人人爽 | 伊人久久一区二区 | 爽到憋不住潮喷大喷水视频 | 国产91视频在线 | 国产一区高清在线 | 国产亚洲美女视频 | 久久免费国产 | A级无遮挡超级高清-在线观看 | 亚洲乱码日产精品bd | 国产在线观看成人 | 老熟妇真实网站 | 成人看片| 亚洲欧洲美洲综合色网 | 日本精品一区在线 | 51cao在线观看| 龙珠z中文版普通话 | 两性故事吃奶添下面 | 美女高潮在线观看 | 精品无码三级在线观看视频 | 日夜操天天干 | 国产精品午夜福利在线观看地址 | 久久久爽爽爽美女图片 | 国产黄色一级片 | 精品国产免费一区二区三区香蕉 | 天堂中文最新版在线官网在线 | 国产精品美女久久久网站 | 久草在线视频免费资源观看 | 国产精品多P对白交换绿帽 久久久老司机 | 国产我和子的与子乱视频 | 日韩综合网站 | 一区二区三区在线观看欧美 | 亚洲精品无码久久久久Y | 69堂视频| 91在线日本| 新包青天1995国语版 | 亚洲香蕉伊综合在人在线观看 |