1. 程式人生 > >Android定製控制元件:帶圖示的TextView和可編輯文字框(附專案原始碼)

Android定製控制元件:帶圖示的TextView和可編輯文字框(附專案原始碼)

各位朋友,博主向大家問好啦!

初次見面,多多關照。

博主正在學習移動開發,今天老師教授的是定製控制元件:帶圖示的TextView,

然後課後依葫蘆畫瓢,博主定製了一個帶圖示的可編輯文字框,其實原理都一樣!

博主覺得該課題具有可鑑意義,特此分享給大家,幫助入門級開發人員,大蝦別見笑。

注意:以下專案在建立時沒有勾選activity,是一個空白專案

好啦,先來張效果圖演示吧:


專案結構圖:


一、在src目錄下建立一個類,用來編寫控制元件程式碼(博主的是IconTextView.java)

<span style="font-size:14px;color:#006600;">package com.demo.widgets;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.widget.TextView;


public class IconTextView extends TextView {
	//宣告名稱空間的值
	private final String namespace="http://widgets.demo.com";
	//儲存圖片資源ID的變數
	private int resourceId=0;
	//宣告圖片物件變數
	private Bitmap bitmap;
	//編寫控制構造方法
	public IconTextView(Context context,AttributeSet attrs){
		//由於該空間類是從TextView繼承,其構造過程應先構建父類,然後才是本身
		super(context,attrs);
		//使用AttributeResourceValue獲得佈局檔案中控制元件屬性的值
		//該方法有3個引數:
		//第一個引數表示名稱空間
		//第二個引數表示屬性名
		//第三個引數表示預設值,若在佈局檔案中不能得到該屬性的值則返回該值
		resourceId=attrs.getAttributeResourceValue(namespace, "iconSrc",0);
		if(resourceId>0){
			//若成功獲得影象資源ID則裝載影象並例項化Bitmap物件
			bitmap=BitmapFactory.decodeResource(getResources(), resourceId);			
		}
	}
	//過載onDraw方法
	@Override
	protected void onDraw(Canvas canvas) {
		// 保證要繪製的內容存在
		if(bitmap!=null){
			//從原圖擷取影象區域,本例使用的全圖
			Rect src=new Rect();//放寬區域
			//將影象區域複製到目標區域
			Rect target=new Rect();
			//定義從原圖中擷取的區域的邊界
			src.left=0;
			src.top=0;
			src.right=bitmap.getWidth();
			src.bottom=bitmap.getHeight();
			//獲取文字大小
			int textHeight=(int)getTextSize();
			//指定擷取的影象繪製到目標區域
			target.left=0;
			target.top=(getMeasuredHeight()-textHeight)/2;
			target.bottom=target.top+textHeight;
			//為了擷取的影象不變形,影象大小要重新計算
			target.right=(int)(textHeight*20/(float)20);
			//繪製截圖
			canvas.drawBitmap(bitmap,src,target,getPaint());
			//讓文字與截圖有點間距
			canvas.translate(target.right+2, 0);
		}
		super.onDraw(canvas);
	}
}</span>

二、在當前專案res/layout下新建一個線性佈局檢視(博主的是icontvxml.xml)

注意名稱空間的位置,需要新增一個自己的名稱空間,否則無法完成自定義控制元件

<span style="font-size:14px;color:#006600;"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:icoand="http://widgets.demo.com"
    android:background="@drawable/bg"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <com.demo.widgets.IconTextView 
        icoand:iconSrc="@drawable/ikivilife" 
        android:id="@+id/txt1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="輕微生活網"
        android:textSize="48sp"
        android:textColor="@color/aqua"
        />

        <com.demo.widgets.IconEditView 
        icoand:iconSrc="@drawable/etg" 
        android:id="@+id/etxt1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="請輸入文字..."
        android:textSize="25sp"
        android:textColor="@color/violet"
        />
    
        <com.demo.widgets.IconTextView 
        icoand:iconSrc="@drawable/eye" 
        android:id="@+id/txturl1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="humicai.cn"
        android:textSize="50sp"
        android:textColor="@color/purple"
        />
</LinearLayout></span>

三、建立一個activity,即建立一個類來繼承Activity,用來載入和顯示檢視效果(博主的是activityIconT)

注意:R類一定到匯入正確,必須是當前專案下的R類,否則無法完成自定義控制元件

<span style="font-size:14px;color:#006600;">package com.demo.widgets;

import com.demo.ch04_icontextview.R;

import android.app.Activity;
import android.os.Bundle;
import android.widget.LinearLayout;

public class activityIconT extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		//
		LinearLayout ilayout=(LinearLayout) getLayoutInflater().inflate(R.layout.icontvxml, null);
		setContentView(ilayout);
	}

	@Override
	protected void onDestroy() {
		// TODO Auto-generated method stub
		super.onDestroy();
	}

	@Override
	protected void onPause() {
		// TODO Auto-generated method stub
		super.onPause();
	}

	@Override
	protected void onRestart() {
		// TODO Auto-generated method stub
		super.onRestart();
	}

	@Override
	protected void onResume() {
		// TODO Auto-generated method stub
		super.onResume();
	}

	@Override
	protected void onStart() {
		// TODO Auto-generated method stub
		super.onStart();
	}

	@Override
	protected void onStop() {
		// TODO Auto-generated method stub
		super.onStop();
	}

}</span>
最後,在AndroidManifest.xml中,新增啟動程式碼
<span style="font-size:14px;color:#006600;"><?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.demo.ch04_icontextview"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="19" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity android:name="com.demo.widgets.activityIconT" 
            android:label="@string/app_name"
            android:theme="@style/AppTheme">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest></span>
這樣便完成了定製控制元件的專案需求了,另外如果需要設定顏色值得話,需要在res/values下建立一個color.xml用來儲存顏色值源以方便檢視呼叫,程式碼如下:
<span style="font-size:14px;color:#006600;"><?xml version="1.0" encoding="utf-8" ?> 
<resources> 
<color name="white">#FFFFFF</color><!--白色 --> 
<color name="ivory">#FFFFF0</color><!--象牙色 --> 
<color name="lightyellow">#FFFFE0</color><!--亮黃色 --> 
<color name="yellow">#FFFF00</color><!--黃色 --> 
<color name="snow">#FFFAFA</color><!--雪白色 --> 
<color name="floralwhite">#FFFAF0</color><!--花白色 --> 
<color name="lemonchiffon">#FFFACD</color><!--檸檬綢色 --> 
<color name="cornsilk">#FFF8DC</color><!--米綢色 --> 
<color name="seashell">#FFF5EE</color><!--海貝色 --> 
<color name="lavenderblush">#FFF0F5</color><!--淡紫紅 --> 
<color name="papayawhip">#FFEFD5</color><!--番木色 --> 
<color name="blanchedalmond">#FFEBCD</color><!--白杏色 --> 
<color name="mistyrose">#FFE4E1</color><!--淺玫瑰色 --> 
<color name="bisque">#FFE4C4</color><!--桔黃色 --> 
<color name="moccasin">#FFE4B5</color><!--鹿皮色 --> 
<color name="navajowhite">#FFDEAD</color><!--納瓦白 --> 
<color name="peachpuff">#FFDAB9</color><!--桃色 --> 
<color name="gold">#FFD700</color><!--金色 --> 
<color name="pink">#FFC0CB</color><!--粉紅色 --> 
<color name="lightpink">#FFB6C1</color><!--亮粉紅色 --> 
<color name="orange">#FFA500</color><!--橙色 --> 
<color name="lightsalmon">#FFA07A</color><!--亮肉色 --> 
<color name="darkorange">#FF8C00</color><!--暗桔黃色 --> 
<color name="coral">#FF7F50</color><!--珊瑚色 --> 
<color name="hotpink">#FF69B4</color><!--熱粉紅色 --> 
<color name="tomato">#FF6347</color><!--西紅柿色 --> 
<color name="orangered">#FF4500</color><!--紅橙色 --> 
<color name="deeppink">#FF1493</color><!--深粉紅色 --> 
<color name="fuchsia">#FF00FF</color><!--紫紅色 --> 
<color name="magenta">#FF00FF</color><!--紅紫色 --> 
<color name="red">#FF0000</color><!--紅色 --> 
<color name="oldlace">#FDF5E6</color><!--老花色 --> 
<color name="lightgoldenrodyellow">#FAFAD2</color><!--亮金黃色 --> 
<color name="linen">#FAF0E6</color><!--亞麻色 --> 
<color name="antiquewhite">#FAEBD7</color><!--古董白 --> 
<color name="salmon">#FA8072</color><!--鮮肉色 --> 
<color name="ghostwhite">#F8F8FF</color><!--幽靈白 --> 
<color name="mintcream">#F5FFFA</color><!--薄荷色 --> 
<color name="whitesmoke">#F5F5F5</color><!--煙白色 --> 
<color name="beige">#F5F5DC</color><!--米色 --> 
<color name="wheat">#F5DEB3</color><!--淺黃色 --> 
<color name="sandybrown">#F4A460</color><!--沙褐色 --> 
<color name="azure">#F0FFFF</color><!--天藍色 --> 
<color name="honeydew">#F0FFF0</color><!--蜜色 --> 
<color name="aliceblue">#F0F8FF</color><!--艾利斯蘭 --> 
<color name="khaki">#F0E68C</color><!--黃褐色 --> 
<color name="lightcoral">#F08080</color><!--亮珊瑚色 --> 
<color name="palegoldenrod">#EEE8AA</color><!--蒼麒麟色 --> 
<color name="violet">#EE82EE</color><!--紫羅蘭色 --> 
<color name="darksalmon">#E9967A</color><!--暗肉色 --> 
<color name="lavender">#E6E6FA</color><!--淡紫色 --> 
<color name="lightcyan">#E0FFFF</color><!--亮青色 --> 
<color name="burlywood">#DEB887</color><!--實木色 --> 
<color name="plum">#DDA0DD</color><!--洋李色 --> 
<color name="gainsboro">#DCDCDC</color><!--淡灰色 --> 
<color name="crimson">#DC143C</color><!--暗深紅色 --> 
<color name="palevioletred">#DB7093</color><!--蒼紫羅蘭色 --> 
<color name="goldenrod">#DAA520</color><!--金麒麟色 --> 
<color name="orchid">#DA70D6</color><!--淡紫色 --> 
<color name="thistle">#D8BFD8</color><!--薊色 --> 
<color name="lightgray">#D3D3D3</color><!--亮灰色 --> 
<color name="lightgrey">#D3D3D3</color><!--亮灰色 --> 
<color name="tan">#D2B48C</color><!--茶色 --> 
<color name="chocolate">#D2691E</color><!--巧可力色 --> 
<color name="peru">#CD853F</color><!--祕魯色 --> 
<color name="indianred">#CD5C5C</color><!--印第安紅 --> 
<color name="mediumvioletred">#C71585</color><!--中紫羅蘭色 --> 
<color name="silver">#C0C0C0</color><!--銀色 --> 
<color name="darkkhaki">#BDB76B</color><!--暗黃褐色 --> 
<color name="rosybrown">#BC8F8F</color><!--褐玫瑰紅 --> 
<color name="mediumorchid">#BA55D3</color><!--中粉紫色 --> 
<color name="darkgoldenrod">#B8860B</color><!--暗金黃色 --> 
<color name="firebrick">#B22222</color><!--火磚色 --> 
<color name="powderblue">#B0E0E6</color><!--粉藍色 --> 
<color name="lightsteelblue">#B0C4DE</color><!--亮鋼蘭色 --> 
<color name="paleturquoise">#AFEEEE</color><!--蒼寶石綠 --> 
<color name="greenyellow">#ADFF2F</color><!--黃綠色 --> 
<color name="lightblue">#ADD8E6</color><!--亮藍色 --> 
<color name="darkgray">#A9A9A9</color><!--暗灰色 --> 
<color name="darkgrey">#A9A9A9</color><!--暗灰色 --> 
<color name="brown">#A52A2A</color><!--褐色 --> 
<color name="sienna">#A0522D</color><!--赭色 --> 
<color name="darkorchid">#9932CC</color><!--暗紫色 --> 
<color name="palegreen">#98FB98</color><!--蒼綠色 --> 
<color name="darkviolet">#9400D3</color><!--暗紫羅蘭色 --> 
<color name="mediumpurple">#9370DB</color><!--中紫色 --> 
<color name="lightgreen">#90EE90</color><!--亮綠色 --> 
<color name="darkseagreen">#8FBC8F</color><!--暗海蘭色 --> 
<color name="saddlebrown">#8B4513</color><!--重褐色 --> 
<color name="darkmagenta">#8B008B</color><!--暗洋紅 --> 
<color name="darkred">#8B0000</color><!--暗紅色 --> 
<color name="blueviolet">#8A2BE2</color><!--紫羅蘭藍色 --> 
<color name="lightskyblue">#87CEFA</color><!--亮天藍色 --> 
<color name="skyblue">#87CEEB</color><!--天藍色 --> 
<color name="gray">#808080</color><!--灰色 --> 
<color name="grey">#808080</color><!--灰色 --> 
<color name="olive">#808000</color><!--橄欖色 --> 
<color name="purple">#800080</color><!--紫色 --> 
<color name="maroon">#800000</color><!--粟色 --> 
<color name="aquamarine">#7FFFD4</color><!--碧綠色 --> 
<color name="chartreuse">#7FFF00</color><!--黃綠色 --> 
<color name="lawngreen">#7CFC00</color><!--草綠色 --> 
<color name="mediumslateblue">#7B68EE</color><!--中暗藍色 --> 
<color name="lightslategray">#778899</color><!--亮藍灰 --> 
<color name="lightslategrey">#778899</color><!--亮藍灰 --> 
<color name="slategray">#708090</color><!--灰石色 --> 
<color name="slategrey">#708090</color><!--灰石色 --> 
<color name="olivedrab">#6B8E23</color><!--深綠褐色 --> 
<color name="slateblue">#6A5ACD</color><!--石藍色 --> 
<color name="dimgray">#696969</color><!--暗灰色 --> 
<color name="dimgrey">#696969</color><!--暗灰色 --> 
<color name="mediumaquamarine">#66CDAA</color><!--中綠色 --> 
<color name="cornflowerblue">#6495ED</color><!--菊蘭色 --> 
<color name="cadetblue">#5F9EA0</color><!--軍蘭色 --> 
<color name="darkolivegreen">#556B2F</color><!--暗橄欖綠 --> 
<color name="indigo">#4B0082</color><!--靛青色 --> 
<color name="mediumturquoise">#48D1CC</color><!--中綠寶石 --> 
<color name="darkslateblue">#483D8B</color><!--暗灰藍色 --> 
<color name="steelblue">#4682B4</color><!--鋼蘭色 --> 
<color name="royalblue">#4169E1</color><!--皇家藍 --> 
<color name="turquoise">#40E0D0</color><!--青綠色 --> 
<color name="mediumseagreen">#3CB371</color><!--中海藍 --> 
<color name="limegreen">#32CD32</color><!--橙綠色 --> 
<color name="darkslategray">#2F4F4F</color><!--暗瓦灰色 --> 
<color name="darkslategrey">#2F4F4F</color><!--暗瓦灰色 --> 
<color name="seagreen">#2E8B57</color><!--海綠色 --> 
<color name="forestgreen">#228B22</color><!--森林綠 --> 
<color name="lightseagreen">#20B2AA</color><!--亮海藍色 --> 
<color name="dodgerblue">#1E90FF</color><!--閃蘭色 --> 
<color name="midnightblue">#191970</color><!--中灰蘭色 --> 
<color name="aqua">#00FFFF</color><!--淺綠色 --> 
<color name="cyan">#00FFFF</color><!--青色 --> 
<color name="springgreen">#00FF7F</color><!--春綠色 --> 
<color name="lime">#00FF00</color><!--酸橙色 --> 
<color name="mediumspringgreen">#00FA9A</color><!--中春綠色 --> 
<color name="darkturquoise">#00CED1</color><!--暗寶石綠 --> 
<color name="deepskyblue">#00BFFF</color><!--深天藍色 --> 
<color name="darkcyan">#008B8B</color><!--暗青色 --> 
<color name="teal">#008080</color><!--水鴨色 --> 
<color name="green">#008000</color><!--綠色 --> 
<color name="darkgreen">#006400</color><!--暗綠色 --> 
<color name="blue">#0000FF</color><!--藍色 --> 
<color name="mediumblue">#0000CD</color><!--中蘭色 --> 
<color name="darkblue">#00008B</color><!--暗藍色 --> 
<color name="navy">#000080</color><!--海軍色 --> 
<color name="black">#000000</color><!--黑色 --> 
</resources></span>