本文實例講述了Android編程之SurfaceView用法。分享給大家供大家參考,具體如下:
關(guān)于surfaceView相關(guān)知識:
View和SurfaceView主要區(qū)別:
1. View只能在UI線程中刷新,而SurfaceView可以在子線程中刷新
2. SurfaceView可以控制刷新頻率
SurfaceView幾個重要的方法:
1. 繼承SurfaceView 后調(diào)用getHolder()方法可以獲取到mSurfaceHolder對象這個對于可以控制SurfaceView的繪制
2. 實現(xiàn)這個SurfaceHolder.Callback接口并且mSurfaceHolder.addCallback(this)添加回調(diào)可以感知到SurfaceView的生命周期
3. 繪制的時候mCanvas.drawColor(Color.BLACK);這個方法很重要,這個方法是清理上一次繪制的東西,這個方法一定要調(diào)用才能看到效果
實現(xiàn)效果 如下:

第一步:新建XRSurfaceView繼承SurfaceView
package com.rong.activity;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.util.AttributeSet;import android.view.SurfaceHolder;import android.view.SurfaceView;/** * 自定義SurfaceView * * @author 徐榮 * */public class XRSurfaceView extends SurfaceView implements SurfaceHolder.Callback, Runnable { // SurfaceView的寬 int surfaceWidth; // SurfaceView的高 int surfaceHeight; // SurfaceHolder對象 SurfaceHolder mSurfaceHolder; // 開關(guān)線程的標(biāo)志位 boolean isRunning = true; // 畫筆 Paint mPaint; // 圓的半徑 float radius = 0; // 圓是變大還是縮小的狀態(tài) boolean status = true; // 圓變化的速度 int mSpeed = 3; public XRSurfaceView(Context context, AttributeSet attrs) { super(context, attrs); initView(); } private void initView() { // 獲取mSurfaceHolder mSurfaceHolder = getHolder(); // 添加回調(diào) mSurfaceHolder.addCallback(this); } @Override public void surfaceCreated(SurfaceHolder holder) { isRunning = true; // 初始化畫筆 mPaint = new Paint(); mPaint.setAntiAlias(true); mPaint.setColor(Color.BLUE); // 開啟繪制線程 new Thread(this).start(); } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { // 獲取surface的寬 surfaceWidth = width; // 獲取surface的高 surfaceHeight = height; } @Override public void surfaceDestroyed(SurfaceHolder holder) { // 關(guān)閉繪制線程 isRunning = false; } @Override public void run() { Canvas mCanvas = null; while (isRunning) { try { // 鎖定canva進(jìn)行繪制 mCanvas = mSurfaceHolder.lockCanvas(null); // 這個方法很重要,相當(dāng)于重繪(一定要調(diào)用不然看不到效果) mCanvas.drawColor(Color.BLACK); // 畫圓 mCanvas.drawCircle((surfaceWidth / 2), (surfaceHeight / 2), radius, mPaint); // 更改半徑變量 if (status) { radius = radius + mSpeed; if (radius > 200) { status = false; } } else { radius = radius - mSpeed; if (radius < 0) { status = true; } } } catch (Exception e) { e.printStackTrace(); } finally { // 解除畫布鎖 mSurfaceHolder.unlockCanvasAndPost(mCanvas); } } }}第二步:新建布局文件activity_main.xml
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff" android:orientation="vertical" > <com.rong.activity.XRSurfaceView android:layout_width="match_parent" android:layout_height="match_parent" android:layout_centerInParent="true" android:orientation="vertical" /></RelativeLayout>
運(yùn)行!
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)入門與進(jìn)階教程》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計有所幫助。
新聞熱點
疑難解答
圖片精選