ご覧頂き ありがとうございます。
現在タップをした座標に円形を描画するアプリケーションを制作しています。
そこでつまづいてしまっている部分が、今回ご教示いただきたい内容になります。
以下に示しますプログラムを「複数の図形の描画に対応させたい」のです。
説明が下手で申し訳ありません。
以下の参考URLの方のソースを図形に置き換えたい。と言うことです。
参考URL
MainAvtivity
Java
1public class MainActivity extends AppCompatActivity { 2 3 @Override 4 protected void onCreate(Bundle savedInstanceState) { 5 super.onCreate(savedInstanceState); 6 TouchView touchView = new TouchView(this); 7 setContentView(touchView); 8 } 9}
View
java
1public class CircleView extends View implements AnimatorUpdateListener, AnimatorListener{ 2 ValueAnimator anim = null; 3 private float axisX = 0; 4 private float axisY = 0; 5 boolean animationEnd = false; 6 7 public CircleView(Context context) { 8 super(context); 9 anim = ValueAnimator.ofFloat(0.f, 300.f); 10 anim.setDuration(500l); 11 anim.setInterpolator(new AccelerateDecelerateInterpolator()); 12 anim.addUpdateListener(this); 13 //anim.start(); 14 15 } 16 17 @Override 18 public void onAnimationUpdate(ValueAnimator animation) { 19 invalidate(); 20 } 21 22 @Override 23 public void onAnimationStart(Animator animation) { 24 25 } 26 27 @Override 28 public void onAnimationEnd(Animator animation) { 29 animationEnd = true; 30 } 31 32 @Override 33 public void onAnimationCancel(Animator animation) { 34 35 } 36 37 @Override 38 public void onAnimationRepeat(Animator animation) { 39 40 } 41 42 @Override 43 public boolean onTouchEvent(MotionEvent event) { 44 45 Log.d("TouchEvent", "X:" + axisX + ",Y:" + axisY); 46 47 switch (event.getAction()) { 48 case MotionEvent.ACTION_DOWN: 49 Log.d("TouchEvent", "getAction()" + "ACTION_DOWN"); 50 axisX = event.getX(); 51 axisY = event.getY(); 52 53 Canvas canvas = new Canvas(); 54 draw(canvas); 55 this.anim.start();//thisをつけることが重要 56 this.invalidate(); 57 break; 58 case MotionEvent.ACTION_UP: 59 Log.d("TouchEvent", "getAction()" + "ACTION_UP"); 60 break; 61 case MotionEvent.ACTION_MOVE: 62 Log.d("TouchEvent", "getAction()" + "ACTION_MOVE"); 63 break; 64 case MotionEvent.ACTION_CANCEL: 65 Log.d("TouchEvent", "getAction()" + "ACTION_CANCEL"); 66 break; 67 } 68 return true; 69 } 70 71 @Override 72 public void onDraw(Canvas canvas) { 73 Paint mPaint = new Paint(); 74 75 int color = Color.parseColor("#5589c3eb");//A(lpha)RGB 76 mPaint.setColor(color); 77 mPaint.setStrokeWidth(10); 78 mPaint.setAntiAlias(true); 79 mPaint.setStyle(Paint.Style.STROKE); 80 81 canvas.drawCircle(axisX, axisY, (Float)anim.getAnimatedValue(), mPaint); 82 83 //Log.i("i : ",String.valueOf(axisX)); 84 } 85} 86
以上になります。
参考URLをもとに自分で書いてみたりもしたのですが、上手くいっていない状態です。
ご助力の程、よろしくお願いいたします。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/08/18 05:50
2016/08/22 13:32