界面加一串文字android,Android界面布局文字水印

刚创建的React Native 微信公众号,

欢迎微信扫描关注订阅号,

每天定期会分享react native 技术文章,

移动技术干货,精彩文章技术推送

。同时可以扫描我的微信加入react-native技术交流微信群。欢迎各位大牛,React Native技术爱好者加入交流!

一、需求分析

某友说要解决一个需求,在每个布局中加上水印效果,如下图:

5648f1cac9484626b84b34f9c21a3d24.png

从图中,我们看到在内容布局中很明显有文字水印效果,如何实现这种效果呢:

(1)水印文字有旋转

(2)水印效果处于内容布局之下

(3)水印文字位置不固定

分析以上三步,想必大家都想到了,利用Android自定义View的方式来实现。

二 、功能实现

1、自定义水印文字

从需求图中可以看到,水印文字有旋转角度,颜色,字体大小等等属性。颜色,字体的属性系统TextView已经帮我们实现,所以我们可以继承TextView。旋转的角度使用自定义属性即可。

package watermark;

import android.content.Context;

import android.content.res.TypedArray;

import android.graphics.Canvas;

import android.util.AttributeSet;

import android.view.Gravity;

import android.widget.TextView;

import com.song.androidwatermark.R;

/**

* 水印文字

* Created by Song on 2017/6/29.

*/

public class WaterMarkText extends TextView {

private int mDegree; // 旋转角度

public WaterMarkText(Context context) {

this(context, null);

}

public WaterMarkText(Context context, AttributeSet attrs) {

this(context, attrs, 0);

}

public WaterMarkText(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

this.setGravity(Gravity.CENTER);

// 获取自定义属性

TypedArray ta = context.obtainStyledAttributes(attrs, R.styleable.WaterMarkText,defStyleAttr,0);

for (int i = 0; i < ta.getIndexCount(); i++) {

int index = ta.getIndex(i);

switch (index) {

case R.styleable.WaterMarkText_degree:

mDegree = ta.getInt(index,0);

break;

}

}

ta.recycle();

}

@Override

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

super.onMeasure(widthMeasureSpec, heightMeasureSpec);

setMeasuredDimension(getMeasuredWidth(), getMeasuredHeight()+80);

}

@Override

protected void onDraw(Canvas canvas) {

canvas.save();

// 位移,保持文字居中

canvas.translate(getCompoundPaddingLeft(), getExtendedPaddingTop());

// 以文字中心轴旋转

canvas.rotate(mDegree, this.getWidth() / 2f, this.getHeight() / 2f);

super.onDraw(canvas);

canvas.restore();

}

/**

* 设置旋转角度

* @param degree

*/

public void setDegree(int degree) {

this.mDegree = degree;

}

}

2、自定义水印布局

水印布局中,水印文字随机展示在某个位置,我们可以获取【x,y】的坐标范围,然后在范围中产生随机数,展示水印文字即可。此处为了方便,我直接定义位置

3、添加水印到当前布局

如何将水印布局添加到内容布局之下,我们可以利用DecoerView来实现。在onCreate中设置了根布局后,会生成DecoerView,那么我们可以通过addView的方式,将水印布局添加,通过第二个参数来控制布局层次即可。

package com.song.androidwatermark;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

}

@Override

protected void onStart() {

addWaterMarkView();

super.onStart();

}

/**

* 添加水印

*/

private void addWaterMarkView() {

View waterMarkView = LayoutInflater.from(this)

.inflate(R.layout.layout_watermark,null);

getRootView().addView(waterMarkView,0);

}

/**

* 获取根布局DecorView

* @return

*/

private ViewGroup getRootView() {

ViewGroup rootView = (ViewGroup)findViewById(android.R.id.content);

return rootView;

}

}通过以上几个步骤就可以轻松实现水印文字效果啦~

三、效果图

109316a026f1247e2e07d21ac222b511.png

源码下载

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值