Android可配置透明度的水印
今天對Android端水印進行了一個簡單的優(yōu)化,優(yōu)化方式是對水印生成方式的修改。如圖1修改為如圖2。
我們先簡單了解一下圖一水印是如生成得。
//創(chuàng)建水印類構造方法 public MarkDrawable(String mMarkStr,int textColor,int textSize,int backgroundColor) { ? ? this.mMarkStr = mMarkStr; ? ? this.mTextColor=textColor; ? ? this.mTextSize=textSize; ? ? this.mBackgroundColor=backgroundColor; }
//創(chuàng)建paint實例繪制文字 mPaint=new TextPaint(); mPaint.setTextSize(mTextSize); mPaint.setAntiAlias(true); mPaint.setColor(mTextColor); final float width=mPaint.measureText(mMarkStr,0,mMarkStr.length())*2;
這里我們創(chuàng)建了文字繪制工具進行繪制文字
//繪制矩形 Rect rect=new Rect(); mPaint.getTextBounds(mMarkStr,0,mMarkStr.length(),rect); mBoundRect=new RectF(); //設置矩形得寬高 mBoundRect.set(0,0,(float) (width*Math.cos(Math.toRadians(mDegree) ))+inset,(float)(width*Math.sin(Math.toRadians(mDegree)))+inset); //在這里我們進行繪制矩形,為了設置單個水印的寬高
接著我們開始在畫布上進行繪制
public void draw(Canvas canvas) { ? ? canvas.save(); ? ? canvas.drawColor(mBackgroundColor); ? ? canvas.translate(mBoundRect.width()/2,mBoundRect.height()/2); ? ? canvas.rotate(-mDegree); ? ? canvas.drawText(mMarkStr,inset/2-mBoundRect.width()/2,0,mPaint); ? ? canvas.restore(); }
繪制出一個帶偏移角得文字
到這里我們前期工作完成繪制出了一個水印出來,現(xiàn)在我們需要將所有的水印鋪滿整個屏幕
//我們調(diào)用水印繪制得類 public WaterMarkDrawable(String markStr,int textColor,int textSize,int backgroundColor) { ? ? //在這里我們獲取到單個水印得實體類 ? ? this.mMarkDrawable = new MarkDrawable(markStr,textColor,textSize,backgroundColor); ? ? //設置水印矩形 ? ? mBoundRect = new RectF(); ? ? //水印寬高 ? ? final int width=mMarkDrawable.getIntrinsicWidth(); ? ? final ?int height=mMarkDrawable.getIntrinsicHeight(); ? ? //將水印轉(zhuǎn)成bitmap ? ? Bitmap bmp = Bitmap.createBitmap(width,height, Bitmap.Config.ARGB_8888); ? ? //將水印繪制到畫布上 ? ? Canvas canvas = new Canvas(bmp); ? ? mMarkDrawable.setBounds(0,0,width,height);//用來確定繪制大小和位置 ? ? mMarkDrawable.draw(canvas); ? ? //利用bitmapshader類進行重復xy軸平鋪 ? ? mShader = new BitmapShader(bmp, Shader.TileMode.REPEAT, Shader.TileMode.REPEAT);//基于繪制的第一個完成的bitmap,X軸Y軸方向重復的繪制bitmap ? ? mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);//使位圖抗鋸齒的標志 ? ? mPaint.setStyle(Paint.Style.FILL);//填充 ? ? //設置paint得shader ? ? mPaint.setShader(mShader); }
在這里我們先將畫出來的水印轉(zhuǎn)成bitmaph后再將其繪制到畫布上,最后利用BitmapShader進行xy軸進行重復平鋪從而做到布滿xy軸得需要,但到這里雖然平鋪了,但是是整齊得平鋪效果上并沒有達到理想的效果如圖所示:
我們主要談談第二種方式:
第二種方式,不用轉(zhuǎn)成bitmap也沒有用到BitmapShader重復平鋪,而是利用暴力枚舉進行對每一個x,y軸進行遍歷對不同坐標上進行畫水印。
public void draw(@NonNull Canvas canvas) { ? ? ? ? //獲取屏幕寬度 ? ? ? ? int width = getBounds().right; ? ? ? ? //獲取屏幕高度 ? ? ? ? int height = getBounds().bottom; ? ? ? ? //獲取屏幕對角線 ? ? ? ? int diagonal = (int) Math.sqrt(width * width + height * height); // 對角線的長度 ? ? ? ? int Yspacing = 50; ? ? ? ? int XSpacing = 100; ? ? ? ? float textWidth; ? ? ? ? canvas.drawColor(0x00000000); ? ? ? ? canvas.rotate(mAngle); ? ? ? ? //文本寬度默認第一個文本 ? ? ? ? if (!ListUtils.isEmpty(mContent)){ ? ? ? ? ? ? if (StringUtils.isEmpty(mContent.get(0))){ ? ? ? ? ? ? ? ? return; ? ? ? ? ? ? } ? ? ? ? //設置文本的寬度從而做到文本寬度得不固定 ? ? ? ? ? ? textWidth = mPaint.measureText(mContent.get(0)); ? ? ? ? ? ? mes = mContent.get(0); ? ? ? ? }else{ ? ? ? ? ? ? if (StringUtils.isEmpty(mMessage)){ ? ? ? ? ? ? ? ? return; ? ? ? ? ? ? } ? ? ? //設置文本的寬度從而做到文本寬度得不固定 ? ? ? ? ? ? textWidth = mPaint.measureText(mMessage); ? ? ? ? ? ? mes = mMessage; ? ? ? ? } ? ? ? ? //為了統(tǒng)計當前在第幾行從而實現(xiàn)錯開顯示 ? ? ? ? int index = 0; ? ? ? ? //記錄當前的x軸坐標 ? ? ? ? float fromX; ? ? ? ? ? ? ? ? for (int positionY = diagonal / 10; positionY <= diagonal; positionY += (diagonal / 10+Yspacing)) { ? ? ? ? ? ? fromX = -width * 3 / 2 + (index++ % 2) * textWidth; // 上下兩行的X軸起始點不一樣,錯開顯示 ? ? ? ? ? ? int spacing ?= 0;//間距 ? ? ? ? ? ? for (float positionX = fromX; positionX < width; positionX += (textWidth * 2+XSpacing)) { ? ? ? ? ? ? ? ? ? ? canvas.drawText(mes, positionX, positionY , mPaint); ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? canvas.save(); ? ? ? ? canvas.restore(); ? ? }
這種方式主要利用暴力枚舉,y軸上在對角線比例高度得位置+間隔距離開始Y軸遍歷;x軸上在初始位置,每次兩倍字符串寬度+間隔得距離進行x軸開始遍歷。最后鋪滿整個屏幕得到的效果為:
這樣做到了上下兩行得X軸起始點不一樣,錯開顯示,實現(xiàn)界面美觀。
在最后我們直接調(diào)用:(因為我們透明度調(diào)用了接口所以大家知道就好傳入的參數(shù)為int型數(shù)據(jù))
var alpha: Int = WaterMarkUtils.getChildrenBean(WaterMarkUtils.SCENE_SHOP)?.whiteTransparency!! * 255 / 100 binding.tvWaterMark.background = ( ? ? WaterMarkBg( ? ? ? ? this, ? ? ? ? WaterMarkUtils.getMarkName( ? ? ? ? ? ? WaterMarkUtils.getChildrenBean(WaterMarkUtils.SCENE_SHOP) ? ? ? ? ), ? ? ? ? -15, ? ? ? ? 14, ? ? ? ? Color.argb(alpha, 0, 0, 0), ? ? ? ? Typeface.DEFAULT_BOLD ? ? ) )
最終實現(xiàn)透明度配置。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
OpenGL ES 矩陣變換及其數(shù)學原理詳解(五)
這篇文章主要為大家詳細介紹了OpenGL ES 矩陣變換及其數(shù)學原理的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05Android自定義密碼樣式 黑點轉(zhuǎn)換成特殊字符
這篇文章主要為大家詳細介紹了Android自定義密碼樣式的制作方法,黑點換成¥、%等特殊字符,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07Android開發(fā)仿IOS滑動開關實現(xiàn)代碼
這篇文章主要介紹了 android開發(fā)仿IOS滑動開關實現(xiàn)代碼的相關資料,需要的朋友可以參考下2017-05-05Android scheme 跳轉(zhuǎn)的設計與實現(xiàn)詳解
這篇文章主要介紹了Android scheme 跳轉(zhuǎn)的設計與實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06Android TextView字體顏色設置方法小結(jié)
這篇文章主要介紹了Android TextView字體顏色設置方法,結(jié)合實例形式總結(jié)分析了Android開發(fā)中TextView設置字體顏色的常用技巧,需要的朋友可以參考下2016-02-02