android 多个canvas,android – 在Canvas上绘制两个3D字符串?

我必须在canvas上绘制2个字符串.字符串必须使用相同的坐标绘制,第二个字符串必须是围绕轴Y旋转第一个字符串45度的结果.结果必须如下所示:

这是我的代码:

Matrix matrix = new Matrix();

matrix = canvas.getMatrix();

mCamera = new Camera();

canvas.drawText("In the name of God", 30, 100, redPaint);

mCamera.rotateY(45);

mCamera.getMatrix(matrix);

matrix.preTranslate(30, 100);

// matrix.postTranslate(-30, -100);

canvas.setMatrix(matrix);

canvas.drawText("In the name of God", 0, 0, greenPaint);

但上面代码的结果是:

你可以看到字符串的坐标是不同的.所以我做错了什么?我猜它是由matrix.preTranslate()的不正确参数引起的.

更新:

我更改了我的代码:

canvas.drawText("In the name of God", 30, 100, redPaint);

mCamera.rotateY(45);

mCamera.getMatrix(matrix);

matrix.preTranslate(-30, -100);

matrix.postTranslate(30, 100);

canvas.setMatrix(matrix);

canvas.drawText("In the name of God", 0, 0, greenPaint);

或者喜欢:

canvas.drawText("In the name of God", 30, 100, redPaint);

mCamera.rotateY(45);

mCamera.getMatrix(matrix);

matrix.preTranslate(-30, -100);

//matrix.postTranslate(30, 100);

canvas.setMatrix(matrix);

canvas.drawText("In the name of God", 0, 0, greenPaint);

或者喜欢:

canvas.drawText("In the name of God", 30, 100, redPaint);

mCamera.rotateY(45);

mCamera.getMatrix(matrix);

matrix.preTranslate(-30, -100);

// matrix.postTranslate(30, 100);

canvas.setMatrix(matrix);

canvas.drawText("In the name of God", 30, 100, greenPaint);

对于以上所有三个代码,结果如下所示:

我猜第二个文本是在范围之外或状态栏后面绘制的,因此它不可见.

然后将我的代码更改为:

mCamera.rotateY(45);

mCamera.getMatrix(matrix);

matrix.preTranslate(-30, -100);

matrix.postTranslate(30, 100);

canvas.setMatrix(matrix);

canvas.drawText("In the name of God", 30, 100, greenPaint);

结果:

解决方法:

试试这个:

Matrix matrix = new Matrix();

matrix = canvas.getMatrix();

mCamera = new Camera();

canvas.drawText("In the name of God", 30, 100, redPaint);

mCamera.translate(30, 100);

mCamera.rotateY(45);

mCamera.getMatrix(matrix);

canvas.setMatrix(matrix);

canvas.drawText("In the name of God", 0, 0, greenPaint);

我从不弄乱翻译前和翻译,但你可以调试它并尝试进行翻译而不是预翻译并提供(30,100)并查看是否有效.

标签:android,camera,matrix,android-canvas

来源: https://codeday.me/bug/20190620/1246869.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值