字体文件比较多,也比较大,有兴趣的私信笔者单发各位
自定义MarkTextDrawable:
package top.lc951.myandroid.views;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Typeface;
import android.graphics.drawable.BitmapDrawable;
import com.example.indicatorlib.utils.Utils;
import top.lc951.myandroid.utils.MeasureUtil;
/**
* @author lichong
* 2022年08月02日15:23:03
*/
public class MarkTextDrawable extends BitmapDrawable {
private Context mContext; // 声明一个上下文对象
private Paint mPaint = new Paint(); // 声明一个画笔对象
private String mText; // 水印文字
private int mTextSize = 40; // 文字大小
public MarkTextDrawable(Context ctx, Bitmap bitmap) {
super(ctx.getResources(), bitmap);
mContext = ctx;
}
// 设置水印文字及其字体
public void setMarkerText(String text, Typeface typeface) {
mText = text;
if (typeface != null) {
mPaint.setColor(0xff000000); // 设置画笔颜色
mPaint.setTextSize(Utils.dp2px(mContext, mTextSize)); // 设置文字大小
mPaint.setTypeface(typeface); // 设置文字字体
}
}
@Override
public void draw(Canvas canvas) {
super.draw(canvas);
if (mText == null) {
return;
}
int bitmapWidth = getBitmap().getWidth();
int bitmapHeight = getBitmap().getHeight();
// 获取指定文本的宽度(其实就是长度)
int textWidth = (int) MeasureUtil.measureTextWidth(mText, mTextSize);
// 获取指定文本的高度
int textHeight = (int) MeasureUtil.getTextHeight(mText, mTextSize);
// 在画布上绘制文本
canvas.drawText(mText, 0, 100, mPaint);
}
}
工具类MeasureUtil:
/**
* 测量文字的宽度
* */
public static float measureTextWidth(String txt,int size){
Paint paint=new Paint();
paint.setTextSize(size);
return paint.measureText(txt);
}
这个也是借用之前的activity BitmapAndDrawableFunActivity(改过名字的):
/**
*
* 图像色彩模式:黑白、模糊、老照片、胶卷等
* , "圆形剪裁", "椭圆剪裁", "圆角矩形剪裁"
*
* 字体:仿宋、楷体
*/
public class BitmapAndDrawableFunActivity extends AppCompatActivity {
private ImageView pictureIv;
private Bitmap mOriginBitmap;
public static void actionActivity(Context context) {
Intent intent = new Intent(context, BitmapAndDrawableFunActivity.class);
context.startActivity(intent);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_bitmap_color_mode);
pictureIv = findViewById(R.id.iv_origin);
loadTypeFace();
initSpinner();
}
private Typeface[] mTypeFaceArray; // 字体数组
private String[] fontFileArray = {"Regular", "FangSong", "KaiTi", "LiShu", "HeiTi", "YouYuan",
"HangKai", "XinWei", "CaiYun", "HuPo", "ShuTi", "YaoTi"};
// 加载字体文件
private void loadTypeFace() {
mTypeFaceArray = new Typeface[fontFileArray.length];
for (int i=0; i=8){
// 根据指定位图创建水印图形对象
MarkTextDrawable drawable = new MarkTextDrawable(BitmapAndDrawableFunActivity.this, mOriginBitmap);
drawable.setMarkerText("@lichong951", mTypeFaceArray[position-8]); // 设置水印文字及其字体
pictureIv.setImageDrawable(drawable); // 设置图像视图的图形对象
return;
}
}
@Override
public void onNothingSelected(AdapterView parent) {
}
});
}
}
布局什么的就显而易见哈!