Android自定義View實現(xiàn)簡單文字描邊功能
更新時間:2018年12月12日 16:25:22 作者:張雨明
這篇文章主要為大家詳細介紹了Android自定義View實現(xiàn)簡單文字描邊功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了Android實現(xiàn)簡單文字描邊功能的具體代碼,供大家參考,具體內容如下
效果圖:

實現(xiàn)代碼:
package com.example.zhangyu.myview.widget;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Picture;
import android.graphics.Rect;
import android.graphics.RectF;
import android.os.Build;
import android.support.annotation.Nullable;
import android.support.annotation.RequiresApi;
import android.util.AttributeSet;
import android.view.View;
import com.example.zhangyu.myview.R;
public class TouchPullView extends View {
//圓的半徑
private float mCircleRadius;
private Paint paint;
private Rect rect=new Rect();
private int count;
public TouchPullView(Context context) {
super(context);
init();
}
public TouchPullView(Context context, @Nullable AttributeSet attrs) {
super(context, attrs);
init();
}
public TouchPullView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init();
}
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
public TouchPullView(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
init();
}
/**
* 初始化
*/
private void init() {
paint = new Paint(Paint.ANTI_ALIAS_FLAG);
//設置抗鋸齒
paint.setAntiAlias(true);
//設置防抖動
paint.setDither(true);
//設置填充方式
paint.setStyle(Paint.Style.FILL_AND_STROKE);
//View的點擊事件
setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
count++;
invalidate();//重新繪制
}
});
}
@Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
//設置方形畫筆,背景。
paint.setColor(Color.YELLOW);
//先繪制底板
canvas.drawRect(0, 0, getWidth(), getHeight(), paint);
float x = getWidth() / 2;
float y = getHeight() / 2;
float offset = getWidth()/6;
//繪制圓形
paint.setColor(Color.GRAY);
mCircleRadius = offset*1.41f;
canvas.drawCircle(x, y, mCircleRadius, paint);
//繪制圖片
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.mipmap.pic1);
if (bitmap != null) {
canvas.drawBitmap(bitmap,null,new RectF(x-offset,y-offset,x+offset,y+offset),paint);
}
//繪制文字外層的文字,邊框
String s = String.valueOf(count);
paint.setStrokeWidth(10);
paint.setColor(Color.RED);
paint.setTextSize(100);
paint.getTextBounds(s,0,s.length(),rect);
float textWidth = rect.width();
float textHeight = rect.height();
x = getWidth()/2-textWidth/2;
y = getHeight() / 2+textHeight/2;
canvas.drawText(s, x, y, paint);
//繪制文字
paint.setColor(Color.BLUE);
paint.setStrokeWidth(0);
canvas.drawText(s, x, y, paint);
}
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
相關文章
Android中實現(xiàn)為TextView添加多個可點擊的文本
這篇文章主要介紹了Android中實現(xiàn)為TextView添加多個可點擊的文本,可實現(xiàn)類似Android社交軟件顯示點贊用戶并通過用戶名稱進入該用戶主頁的功能,是非常實用的技巧,需要的朋友可以參考下2014-09-09
Android控件之AnalogClock與DigitalClock用法實例分析
這篇文章主要介紹了Android控件之AnalogClock與DigitalClock用法,以實例形式分析了Android時鐘控件AnalogClock和DigitalClock用于顯示時間的具體使用技巧,需要的朋友可以參考下2015-09-09
Android中使用CircleImageView和Cardview制作圓形頭像的方法
這篇文章主要介紹了Android中使用CircleImageView和Cardview制作圓形頭像的方法,簡單介紹了CircleImageView和Cardview的使用,需要的朋友可以參考下2016-09-09
Android布局中gravity與layout_gravity屬性說明
這篇文章主要介紹了Android布局中gravity與layout_gravity屬性說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01
Android仿餓了么加入購物車旋轉控件自帶閃轉騰挪動畫的按鈕效果(實例詳解)
這篇文章主要介紹了Android仿餓了么加入購物車旋轉控件自帶閃轉騰挪動畫的按鈕效果(實例詳解)的相關資料,需要的朋友可以參考下2017-01-01
Android Studio中CodeStyle模板的配置方式
這篇文章主要介紹了Android Studio中CodeStyle模板的配置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03

