これを自分で理解しました...説明されている動作は既知の問題のようです。これは、すべてのパスが、別のパスとマージできない個別の「輪郭」として内部的に認識されているためだと思います。
しかし、私は単純な「ハック」で目的の動作を得ることができました。ただし、これは回線ベースのパスでのみ機能します。誰かが興味を持っている場合に備えて、ここにコード(最小限の例)があります...
public class MyPath extends Path {
private ArrayList<Float> points = new ArrayList<Float>();
public void addPath(MyPath src) {
this.points.addAll(src.getPoints());
super.rewind();
super.moveTo(this.points.get(0), this.points.get(1));
for (int i = 2; i < this.points.size(); i += 2) {
super.lineTo(this.points.get(i), this.points.get(i+1));
}
}
@Override
public void moveTo(float x, float y) {
this.points.add(x);
this.points.add(y);
super.moveTo(x, y);
}
@Override
public void lineTo(float x, float y) {
this.points.add(x);
this.points.add(y);
super.lineTo(x, y);
}
public ArrayList<Float> getPoints() {
return this.points;
}
}
これの使用法は簡単です:
MyPath p1 = new MyPath();
MyPath p2 = new MyPath();
p1.moveTo(0,0); p1.lineTo(200,200);
p2.moveTo(200,200); p2.lineTo(400,0);
p1.addPath(p2); //merge
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
paint.setColor(Color.BLACK);
paint.setTextSize(40);
canvas.drawColor(Color.WHITE);
canvas.drawTextOnPath("Lorem ipsum dolor sit amet", p1, 0, 0, paint);