歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Android開發之自定義View(視圖)

Android開發之自定義View(視圖)

日期:2017/3/1 10:26:24   编辑:Linux編程

View類是Android的一個超類,這個類幾乎包含了所有的屏幕類型。每一個View都有一個用於繪圖的畫布,這個畫布可以進行任意擴展。在游戲開發中往往需要自定義視圖(View),這個畫布的功能更能滿足我們在游戲開發中的需要。在Android中,任何一個View類都只需重寫onDraw 方法來實現界面顯示,自定義的視圖可以是復雜的3D實現,也可以是非常簡單的文本形式等。

為了實現自定義View,需要創建一個新的類,然後重寫onDraw方法,在此需要注意,新創建的類MyView要繼承View基類,同時還要加入有參數的兩個構造方法MyView(Context context)和MyView(Contextcontext,AttributeSet attr),否則編譯運行無法通過。

更多Android相關信息見Android 專題頁面 http://www.linuxidc.com/topicnews.aspx?tid=11

在onDraw方法中,初始化了一個畫筆對象myPaint,設置畫筆顏色,還有文字大小,填充等屬性。再利用本方法傳入的參數canvas畫布完成一幅條形統計圖的繪制。具體代碼如下:

  1. package com.viewTest;
  2. import android.content.Context;
  3. import android.graphics.Canvas;
  4. import android.graphics.Color;
  5. import android.graphics.Paint;
  6. import android.graphics.Rect;
  7. import android.graphics.Paint.Style;
  8. import android.util.AttributeSet;
  9. import android.view.View;
  10. public class MyView extends View {
  11. public MyView(Context context) {
  12. super(context);
  13. // TODO Auto-generated constructor stub
  14. }
  15. public MyView(Context context,AttributeSet attr) {
  16. super(context,attr);
  17. }
  18. private Paint myPaint;
  19. private static final String myString1 = "2006-2011上半年中國移動互聯網行業各年度投資情況";
  20. private static final String myString2 = "來源:清科研究中心 2011.08";
  21. @Override
  22. protected void onDraw(Canvas canvas) {
  23. // TODO Auto-generated method stub
  24. super.onDraw(canvas);
  25. myPaint = new Paint();
  26. //繪制標題
  27. myPaint.setColor(Color.BLACK); //設置畫筆顏色
  28. myPaint.setTextSize(18);//設置文字大小
  29. canvas.drawText(myString1, 20, 20, myPaint);
  30. //繪制坐標軸
  31. canvas.drawLine(50, 100, 50, 500, myPaint);//縱坐標軸
  32. canvas.drawLine(50, 500, 400, 500, myPaint);//橫坐標軸
  33. int[] array1 = new int[]{0, 50, 100, 150, 200, 250, 300, 350};
  34. //繪制縱坐標刻度
  35. myPaint.setTextSize(10);//設置文字大小
  36. canvas.drawText("單位:百萬美元", 20, 90, myPaint);
  37. for (int i = 0; i < array1.length; i++) {
  38. canvas.drawLine(50, 500 - array1[i], 54, 500 - array1[i], myPaint);
  39. canvas.drawText(array1[i] + "", 20, 500 - array1[i], myPaint);
  40. }
  41. //繪制橫坐標文字
  42. String[] array2 = new String[]{"2008年", "2009年", "2010年", "2011上半年"};
  43. for (int i = 0; i < array2.length; i++) {
  44. canvas.drawText(array2[i], array1[i] + 80, 520, myPaint);
  45. }
  46. //繪制條形圖
  47. myPaint.setColor(Color.BLUE); //設置畫筆顏色
  48. myPaint.setStyle(Style.FILL); //設置填充
  49. canvas.drawRect(new Rect(90, 500 - 56, 110, 500), myPaint);//畫一個矩形,前兩個參數是矩形左上角坐標,後兩個參數是右下角坐標
  50. canvas.drawRect(new Rect(140, 500 - 98, 160, 500), myPaint);//第二個矩形
  51. canvas.drawRect(new Rect(190, 500 - 207, 210, 500), myPaint);//第三個矩形
  52. canvas.drawRect(new Rect(240, 500 - 318, 260, 500), myPaint);//第四個矩形
  53. myPaint.setColor(Color.BLACK); //設置畫筆顏色
  54. canvas.drawText("56.32", 88, 500 - 58, myPaint);//第一個矩形的數字說明
  55. canvas.drawText("98.00", 138, 500 - 100, myPaint);
  56. canvas.drawText("207.65", 188, 500 - 209, myPaint);
  57. canvas.drawText("318.30", 238, 500 - 320, myPaint);
  58. //繪制出處
  59. myPaint.setColor(Color.BLACK); //設置畫筆顏色
  60. myPaint.setTextSize(16);//設置文字大小
  61. canvas.drawText(myString2, 20, 560, myPaint);
  62. }
  63. }
Copyright © Linux教程網 All Rights Reserved