Android 中 drawTextOnPath 文字效果演示(中级)

原创作品,允许转载,转载时请务必以超链接形式标明文章  原始出处 、作者信息和本声明。否则将追究法律责任。 http://skyoceanone.blog.51cto.com/3483859/684685

Android 中 drawTextOnPath 文字效果演示(中级)

AndroidCanvas提供了一个drawTextOnPath (String text,Path ath,float hOffset,float vOffset,Pating paint)方法,该方法可以沿着Path绘制文本 其中hOffset参数指定水平偏移 vOffset参数指定垂直偏移 

上代码

private static class  mytext extends View{

private Paint paint;

private static final String SKY="skyoceanone";

private Path paths[]=new Path[3];

public mytext(Context context) {

super(context);

paint=new Paint();

paint.setColor(Color.RED);

paint.setAntiAlias(true);

paint.setTextAlign(Paint.Align.RIGHT);//设置从右变开始写字

paint.setTextSize(20);

paths[0]=new Path();

paths[0].moveTo(0,0);

for(int i=0;i<15;i++){//一条线的路径

paths[0].lineTo(i*30, (float)Math.random()*60);

}

paths[1]=new Path();

RectF oval=new RectF(0, 0, 300, 200);

paths[1].addOval(oval, Path.Direction.CCW);//一个椭圆的路径

paths[2]=new Path();

paths[2].addArc(oval, 60, 180);//一个弧线的路径

}

@Override

protected void onDraw(Canvas canvas) {

// TODO Auto-generated method stub

super.onDraw(canvas);

canvas.drawColor(Color.WHITE);

paint.setStyle(Paint.Style.STROKE);

paint.setStrokeWidth(1);

canvas.translate(0, 20);

//以线路径为列子 如果 hOffset vOffset两个参数 为0 效果如图一  会沿着线上走

// 参数为 0,20 则会向下20个像素点 如图二

canvas.drawPath(paths[0], paint);

canvas.drawTextOnPath(SKYpaths[0], 0, 20, paint);

canvas.translate(0, 120);

canvas.drawPath(paths[2], paint);

canvas.drawTextOnPath(SKYpaths[2], -30, 30, paint);

canvas.translate(0, 240);

paint.setStyle(Paint.Style.FILL);

canvas.drawPath(paths[1], paint);

canvas.drawTextOnPath(SKYpaths[1], -30, 30, paint);

}

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值