私はテキスト測定とスケーリングされたキャンバスに苦労しました。スケーリングされたキャンバスでテキストを測定する
キャンバスがスケーリングされていない場合、getTextBoundsとmeasureTextは正確な結果を返します。しかし、キャンバスが拡大縮小されている場合、両方のメソッドは印刷されたテキストの実際のサイズに一致する結果を出力しません。
私はonDraw、以下の方法でビューのサブクラスを作成したテストでは:スケーリング= 0.51以下の結果を
:私は次の出力を得る= 0.5をスケーリングするための
final float scaling = 0.51f;
final int fontSize = 50;
canvas.scale(scaling, scaling);
font = Typeface.create("Arial", Typeface.NORMAL);
Paint paint = new Paint();
paint.setColor(0xff4444ff);
paint.setTypeface(font);
paint.setTextSize(fontSize);
paint.setAntiAlias(true);
int x = 10;
int y = 100;
final String text = "Lorem ipsum dolor sit amet, consectetur adipisici elit...";
canvas.drawText(text, x, y, paint);
// draw border using getTextBounds
paint.setColor(0xffff0000);
paint.setStyle(Paint.Style.STROKE);
paint.setTypeface(font);
paint.setTextSize(fontSize);
Rect bounds = new Rect();
paint.getTextBounds(text, 0, text.length(), bounds);
bounds.offset(x, y);
paint.setColor(0x80ffff00);
canvas.drawRect(bounds, paint);
// draw border using measureText
float w = paint.measureText(text);
bounds.left = x;
bounds.right = (int) Math.ceil(bounds.left + w);
bounds.top -= 10;
bounds.bottom += 10;
paint.setColor(0x8000ffff);
paint.setPathEffect(new DashPathEffect(new float[] { 10, 10 }, 0));
canvas.drawRect(bounds, paint);
黄色の実線の境界線はgetTextBoundsから渡された矩形をマークし、破線のシアンの矩形はfrの幅を使用してレンダリングされますom measureText。
ご覧のとおり、スケーリング= 0.5のテキストは測定されたサイズよりも小さく、スケーリング= 0.51では描画されたテキストが測定されたサイズよりかなり大きくなります。
ご協力いただきましてありがとうございます。私はここに示すように、表示メトリックを使用していたMono for Androidを使用し
あなたはありません、常に補正適用されているとキャンバスでのスケーリング値を補償しませんか?私は実際に境界矩形の計算が間違っているとは思っていませんが、フォントレンダリングコードはキャンバススケーリングに応じて適切なフォントサイズを選択しません。 –
はい、スケーリングせずにテキストサイズが必要であると計算されますキャンバス。 –
忘れてしまったのは、キャンバス内のテキストの配置に使用され、正確な寸法と位置が必要であることがわかっています。 –