自定義View在開發(fā)中是經(jīng)常遇到的,例如一個×××燈的效果、或者自定義一個轉(zhuǎn)盤來顯示下載進度的百分百比。今天把實現(xiàn)方式寫下來,下面是源碼部分:
為淮安等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及淮安網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站制作、做網(wǎng)站、淮安網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
MainActivity:沒變動
import android.app.Activity; import android.os.Bundle; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } }
主布局:只增加了一個自定義View
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <com.example.myview.MineView android:layout_width="wrap_content" android:layout_height="wrap_content" > </com.example.myview.MineView> </RelativeLayout>
自定義View:
import java.util.Random; import android.content.Context; import android.graphics.Canvas; import android.graphics.Paint; import android.graphics.RectF; import android.os.SystemClock; import android.util.AttributeSet; import android.view.View; public class MineView extends View { /** * 字體移動的X坐標 */ private int rx = 0; /** * 畫筆工具 */ private Paint paint; /** * 創(chuàng)建線程對象,用于循環(huán)延遲執(zhí)行命令 */ private MyThread t; /** * 0表示圓的left,60表示圓的top,100表示圓的right,160表示圓的bottom */ private RectF rectF = new RectF(0, 60, 100, 160); /** * 表示區(qū)間角度 */ private float sweepAngle; /** * 創(chuàng)建隨機數(shù)對象 */ private Random random; /** * isdestroy表示該Activity是否已經(jīng)結(jié)束 */ private boolean isdestroy = false; public MineView(Context context, AttributeSet attrs) { super(context, attrs); System.out.println("構(gòu)造器"); paint = new Paint(); random = new Random(); //抗鋸齒,否則圖像會很難看 paint.setAntiAlias(true); if (t == null) { t = new MyThread(); t.start(); } } public MineView(Context context) { super(context); System.out.println("構(gòu)造器"); paint = new Paint(); paint.setAntiAlias(true); if (t == null) { t = new MyThread(); t.start(); } } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); paint.setTextSize(30); // rx表示移動字體的x坐標 canvas.drawText("移動字體", rx, 30, paint); // rectF表示圓的對象,0表示起始角度,sweepAngle表示區(qū)間角度,true和false表示繪制過程的方式,paint表示畫筆對象 canvas.drawArc(rectF, 0, sweepAngle, true, paint); } class MyThread extends Thread { @Override public void run() { super.run(); while (true) { rx += 5; // 如果字體移動出屏幕以外,就讓字體從頭開始 if (rx > getWidth()) { rx = (int) (0 - paint.measureText("移動字體")); } sweepAngle += 5; // 如果角度大于360就讓圓從0度開始重新繪制 if (sweepAngle > 360) { sweepAngle = 0; } // 讓顏色從0-255隨機選擇 int r = random.nextInt(256); int g = random.nextInt(256); int b = random.nextInt(256); // 分別表示:透明度(0~255)、紅、綠、藍 paint.setARGB(255, r, g, b); /** * 判斷Activity是否已經(jīng)退出,如果退出則isdestroy為true,那么立刻讓線程對象與畫筆對象為空,并且break, * 否則會造成內(nèi)存溢出,此辦法必須在此處使用,否則會造成空指針的BUG。 */ if (isdestroy) { if (t != null) { t = null; } if (paint != null) { paint = null; } break; } // 睡眠 SystemClock.sleep(50); // 可以讓ondraw方法重新執(zhí)行 postInvalidate(); // invalidate();分線程無效,要在主線程使用 } } } /** * 當窗口銷毀的時候會調(diào)用此方法,用于關(guān)閉資源 */ @Override protected void onDetachedFromWindow() { super.onDetachedFromWindow(); isdestroy = true; System.out.println("onDetachedFromWindow"); } }
運行效果:運行起來是動態(tài)的,我不會上傳動態(tài)效果,想看效果的自己跑起來就可以了。
注意:這里的×××燈效果只是一種非常笨的方式,有更簡單的辦法,我以后會介紹!
網(wǎng)頁題目:自定義View繪制圖像與移動字體
瀏覽地址:http://bm7419.com/article42/goiohc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、域名注冊、關(guān)鍵詞優(yōu)化、外貿(mào)建站、服務(wù)器托管、虛擬主機
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)