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

來源:互聯網
上載者:User

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

view plaincopy to clipboardprint?
<?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> 

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

view plaincopy to clipboardprint?
<?xml version="1.0" encoding="utf-8"?> 
<A> 
    <B></B> 
</A> 

view plaincopy to clipboardprint?
其中A extends LinerLayout, B extends TextView. 

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

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

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

view plaincopy to clipboardprint?
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 Weis 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 布局檔案中,代碼如下:

view plaincopy to clipboardprint?
<?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> 

最後執行之,效果如:

 

OK,大功告成,今天就寫到這裡,開始做飯了,老婆孩子等我做飯了,lol~

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.