歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Android圖形與圖像處理-采用雙緩沖實現畫圖板

Android圖形與圖像處理-采用雙緩沖實現畫圖板

日期:2017/3/1 10:15:09   编辑:Linux編程

Android圖形與圖像處理-采用雙緩沖實現畫圖板

創建項目:HandDraw

運行項目效果:

DrawView.java

  1. package wwj.handdraw;
  2. import android.content.Context;
  3. import android.graphics.Bitmap;
  4. import android.graphics.Bitmap.Config;
  5. import android.graphics.Canvas;
  6. import android.graphics.Color;
  7. import android.graphics.Paint;
  8. import android.graphics.Path;
  9. import android.util.AttributeSet;
  10. import android.view.MotionEvent;
  11. import android.view.View;
  12. public class DrawView extends View{
  13. float preX;
  14. float preY;
  15. private Path path;
  16. public Paint paint = null;
  17. final int VIEW_WIDTH = 320;
  18. final int VIEW_HEIGHT = 480;
  19. //定義一個內存中的圖片,該圖片將作為緩沖區
  20. Bitmap cacheBitmap = null;
  21. //定義cacheBitmap上的Canvas對象
  22. Canvas cacheCanvas = null;
  23. public DrawView(Context context, AttributeSet attrs) {
  24. super(context, attrs);
  25. //創建一個與該View相同大小的緩沖區
  26. cacheBitmap = Bitmap.createBitmap(VIEW_WIDTH, VIEW_HEIGHT, Config.ARGB_8888);
  27. cacheCanvas = new Canvas();
  28. path = new Path();
  29. //設置cacheCanvas將會繪制到內存中cacheBitmap上
  30. cacheCanvas.setBitmap(cacheBitmap);
  31. //設置畫筆的顏色
  32. paint = new Paint(Paint.DITHER_FLAG);
  33. paint.setColor(Color.RED);
  34. //設置畫筆風格
  35. paint.setStyle(Paint.Style.STROKE);
  36. paint.setStrokeWidth(1);
  37. //反鋸齒
  38. paint.setAntiAlias(true);
  39. paint.setDither(true);
  40. }
  41. @Override
  42. public boolean onTouchEvent(MotionEvent event) {
  43. // TODO Auto-generated method stub
  44. //獲取拖動事件的發生位置
  45. float x = event.getX();
  46. float y = event.getY();
  47. switch(event.getAction()){
  48. case MotionEvent.ACTION_DOWN:
  49. path.moveTo(x, y);
  50. preX = x;
  51. preY = y;
  52. break;
  53. case MotionEvent.ACTION_MOVE:
  54. path.quadTo(preX, preY, x, y);
  55. preX = x;
  56. preY = y;
  57. break;
  58. case MotionEvent.ACTION_UP:
  59. cacheCanvas.drawPath(path, paint);
  60. path.reset();
  61. break;
  62. }
  63. invalidate();
  64. //返回true表明處理方法已經處理該事件
  65. return true;
  66. }
  67. @Override
  68. protected void onDraw(Canvas canvas) {
  69. // TODO Auto-generated method stub
  70. Paint bmpPaint = new Paint();
  71. //將cacheBitmap繪制到該View組件
  72. canvas.drawBitmap(cacheBitmap, 0, 0, bmpPaint);
  73. //沿著Path繪制
  74. canvas.drawPath(path, bmpPaint);
  75. }
  76. }

menu文件:my_menu.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <menu xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:title="@string/color">
  4. <menu>
  5. <!-- 定義一組單選菜單項 -->
  6. <group android:checkableBehavior="single">
  7. <!-- 定義多個菜單項 -->
  8. <item
  9. android:id="@+id/red" android:title="@string/color_red"/>
  10. <item
  11. android:id="@+id/green" android:title="@string/color_green"/>
  12. <item
  13. android:id="@+id/blue" android:title="@string/color_blue"/>
  14. </group>
  15. </menu>
  16. </item>
  17. <item android:title="@string/width">
  18. <menu>
  19. <!-- 定義一組菜單項 -->
  20. <group>
  21. <!-- 定義3個菜單項 -->
  22. <item
  23. android:id="@+id/width_1" android:title="@string/width_1"/>
  24. <item
  25. android:id="@+id/width_3" android:title="@string/width_3"/>
  26. <item
  27. android:id="@+id/width_5" android:title="@string/width_5"/>
  28. </group>
  29. </menu>
  30. </item>
  31. <item
  32. android:id="@+id/blur" android:title="@string/blur"/>
  33. <item
  34. android:id="@+id/emboss" android:title="@string/emboss"/>
  35. </menu>

HandDraw.java

  1. package wwj.handdraw;
  2. import android.os.Bundle;
  3. import android.app.Activity;
  4. import android.graphics.BlurMaskFilter;
  5. import android.graphics.Color;
  6. import android.graphics.BlurMaskFilter.Blur;
  7. import android.graphics.EmbossMaskFilter;
  8. import android.view.Menu;
  9. import android.view.MenuInflater;
  10. import android.view.MenuItem;
  11. import android.support.v4.app.NavUtils;
  12. public class HandDraw extends Activity {
  13. EmbossMaskFilter emboss;
  14. BlurMaskFilter blur;
  15. @Override
  16. public void onCreate(Bundle savedInstanceState) {
  17. super.onCreate(savedInstanceState);
  18. setContentView(R.layout.main);
  19. emboss = new EmbossMaskFilter(new float[]{1.5f, 1.5f, 1.5f}, 0.6f, 6, 4.2f);
  20. blur = new BlurMaskFilter(8, Blur.NORMAL);
  21. }
  22. @Override
  23. public boolean onCreateOptionsMenu(Menu menu) {
  24. MenuInflater inflator = new MenuInflater(this);
  25. //狀態R.menu.context對應的菜單,並添加到menu中
  26. inflator.inflate(R.menu.my_menu, menu);
  27. return super.onCreateOptionsMenu(menu);
  28. }
  29. @Override
  30. public boolean onOptionsItemSelected(MenuItem item) {
  31. // TODO Auto-generated method stub
  32. DrawView dv = (DrawView)findViewById(R.id.draw);
  33. //判斷單擊的是哪個菜單項,並有針對性地做出響應
  34. switch(item.getItemId()){
  35. case R.id.red:
  36. dv.paint.setColor(Color.RED);
  37. item.setChecked(true);
  38. break;
  39. case R.id.green:
  40. dv.paint.setColor(Color.GREEN);
  41. item.setChecked(true);
  42. break;
  43. case R.id.blue:
  44. dv.paint.setColor(Color.BLUE);
  45. item.setChecked(true);
  46. break;
  47. case R.id.width_1:
  48. dv.paint.setStrokeWidth(1);
  49. break;
  50. case R.id.width_3:
  51. dv.paint.setStrokeWidth(3);
  52. break;
  53. case R.id.width_5:
  54. dv.paint.setStrokeWidth(5);
  55. break;
  56. case R.id.blur:
  57. dv.paint.setMaskFilter(blur);
  58. break;
  59. case R.id.emboss:
  60. dv.paint.setMaskFilter(emboss);
  61. break;
  62. }
  63. return true;
  64. }
  65. }

布局文件:main.xml

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:id="@+id/LinearLayout1"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:orientation="vertical" >
  7. <wwj.handdraw.DrawView
  8. android:id="@+id/draw"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:width="320px"
  12. android:height="480px"
  13. />
  14. </LinearLayout>
字符串文件:string.xml
  1. <resources>
  2. <string name="app_name">手繪</string>
  3. <string name="hello_world">Hello world!</string>
  4. <string name="menu_settings">Settings</string>
  5. <string name="title_activity_hand_draw">HandDraw</string>
  6. <string name="width_1">1像素</string>
  7. <string name="width_3">3像素</string>
  8. <string name="width_5">5像素</string>
  9. <string name="color_red">紅色</string>
  10. <string name="color_green">綠色</string>
  11. <string name="color_blue">藍色</string>
  12. <string name="color">畫筆顏色</string>
  13. <string name="width">畫筆寬度</string>
  14. <string name="blur">模糊效果</string>
  15. <string name="emboss">浮雕效果</string>
  16. </resources>
Copyright © Linux教程網 All Rights Reserved