Android高手進階教程(三)之----Android 中自訂View的應用.

來源:互聯網
上載者:User

標籤:attr   enc   tst   final   rap   back   今天   .net   apk   

大家好我們今天的教程是在Android 教程中自訂View 的學習,對於初學著來說,他們習慣了Android 傳統的頁面配置方式,如下代碼:

<?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"      android:orientation="vertical"      android:layout_width="fill_parent"      android:layout_height="fill_parent"      >  <TextView        android:layout_width="fill_parent"       android:layout_height="wrap_content"       android:text="@string/hello"      />  </LinearLayout>

當然上面的布局方式可以協助我們完成簡單應用的開發了,但是如果你想寫一個複雜的應用,這樣就有點牽強了,大家不信可以下源碼都研究看看,高手寫的布局方式,如上面的布局高手通常是這樣寫的:

<?xml version="1.0" encoding="utf-8"?>  <A>      <B></B>  </A>
其中A extends LinerLayout, B extends TextView.

為了協助大家更容易理解,我寫了一個簡單的Demo ,具體步驟如下:

首先建立一個Android 工程 命名為ViewDemo .

然後自訂一個View 類,命名為MyView(extends View) .代碼如下:

package com.android.tutor;  import android.content.Context;  import android.graphics.Canvas;  import android.graphics.Color;  import android.graphics.Paint;  import android.graphics.Rect;  import android.graphics.Paint.Style;  import android.util.AttributeSet;  import android.view.View;  public class MyView extends View {      private Paint mPaint;      private Context mContext;      private static final String mString = "Welcome to Mr Wei‘s blog";            public MyView(Context context) {          super(context);            }      public MyView(Context context,AttributeSet attr)      {          super(context,attr);            }      @Override      protected void onDraw(Canvas canvas) {          // TODO Auto-generated method stub          super.onDraw(canvas);                    mPaint = new Paint();                    //設定畫筆顏色          mPaint.setColor(Color.RED);          //設定填充          mPaint.setStyle(Style.FILL);                    //畫一個矩形,前倆個是矩形左上方座標,後面倆個是右下角座標          canvas.drawRect(new Rect(10, 10, 100, 100), mPaint);                    mPaint.setColor(Color.BLUE);          //繪製文字          canvas.drawText(mString, 10, 110, mPaint);      }  }

然後將我們自訂的View 加入到main.xml 布局檔案中,代碼如下:

<?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"      android:orientation="vertical"      android:layout_width="fill_parent"      android:layout_height="fill_parent"      >  <TextView        android:layout_width="fill_parent"       android:layout_height="wrap_content"       android:text="@string/hello"      />  <com.android.tutor.MyView      android:layout_width="fill_parent"       android:layout_height="fill_parent"   />  </LinearLayout>

最後執行之,效果如:

Android高手進階教程(三)之----Android 中自訂View的應用.

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.