1.Tạo 1 project android với tên “GraphicsDrawPointSurfaceView”
2.
3.
4.
5.
6. Tạo 1 class mới tên PaintSurface src/in/wptrafficanalyzer/graphicsdrawpointsurfaceview/PaintSurface.java với nội dung như sau.
7. file res/layout/activity_main.xml
8. src/in/wptrafficanalyzer/graphicsdrawpointsurfaceview/MainActivity.java
9.Ảnh chụp Demo
2.
3.
4.
5.
6. Tạo 1 class mới tên PaintSurface src/in/wptrafficanalyzer/graphicsdrawpointsurfaceview/PaintSurface.java với nội dung như sau.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 | package in.wptrafficanalyzer.graphicsdrawpointsurfaceview; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.View; import android.view.View.OnTouchListener; public class PaintSurface extends SurfaceView implements Runnable, OnTouchListener{ // Surface holder allows to control and monitor the surface private SurfaceHolder mHolder; // A thread where the painting activities are taking place private Thread mThread; // A flag which controls the start and stop of the repainting of the SurfaceView private boolean mFlag = false ; // X coordinate of the touched position private float mX; // Y Coordinate of the touched position private float mY; // Paint private Paint mPaint; public PaintSurface(Context context, AttributeSet attrs) { super (context, attrs); // Getting the holder mHolder = getHolder(); // Initializing the X position mX = - 100 ; // Initializing the Y position mY = - 100 ; // Initializing the paint object mPaint mPaint = new Paint(); // Setting the color for the paint object mPaint.setColor(Color.BLUE); } public void resume(){ // Instantiating the thread mThread = new Thread( this ); // setting the mFlag to true for start repainting mFlag = true ; // Start repaint the SurfaceView mThread.start(); } public void pause(){ mFlag = false ; } @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()){ case MotionEvent.ACTION_DOWN: // Getting the X-Coordinate of the touched position mX = event.getX(); // Getting the Y-Coordinate of the touched position mY = event.getY(); break ; } return true ; } @Override public void run() { while (mFlag){ // Check whether the object holds a valid surface if (!mHolder.getSurface().isValid()) continue ; // Start editing the surface Canvas canvas = mHolder.lockCanvas(); // Draw a background color canvas.drawARGB( 255 , 255 , 255 , 255 ); // Draw a circle at (mX,mY) with radius 5 canvas.drawCircle(mX, mY, 5 , mPaint); // Finish editing the canvas and show to the user mHolder.unlockCanvasAndPost(canvas); } } } |
7. file res/layout/activity_main.xml
1 2 3 4 5 6 7 8 9 10 11 12 | android:layout_width = "match_parent" android:layout_height = "match_parent" tools:context = ".MainActivity" > < in.wptrafficanalyzer.graphicsdrawpointsurfaceview.PaintSurface android:id = "@+id/paint_surface" android:layout_width = "fill_parent" android:layout_height = "fill_parent" /> </ RelativeLayout > |
8. src/in/wptrafficanalyzer/graphicsdrawpointsurfaceview/MainActivity.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | package in.wptrafficanalyzer.graphicsdrawpointsurfaceview; import android.app.Activity; import android.os.Bundle; import android.view.Menu; public class MainActivity extends Activity { PaintSurface mPaintSurface; @Override protected void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.activity_main); // Getting reference to the PaintView mPaintSurface = (PaintSurface)findViewById(R.id.paint_surface); // Setting the touch listener mPaintSurface.setOnTouchListener(mPaintSurface); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true ; } @Override protected void onResume() { super .onResume(); mPaintSurface.resume(); } @Override protected void onPause() { super .onPause(); mPaintSurface.pause(); } } |
9.Ảnh chụp Demo
No comments:
Post a Comment