編輯:關於Android編程
本文實例講述了Android編程之SurfaceView用法。分享給大家供大家參考,具體如下:
關於surfaceView相關知識:
View和SurfaceView主要區別:
1. View只能在UI線程中刷新,而SurfaceView可以在子線程中刷新
2. SurfaceView可以控制刷新頻率
SurfaceView幾個重要的方法:
1. 繼承SurfaceView 後調用getHolder()方法可以獲取到mSurfaceHolder對象這個對於可以控制SurfaceView的繪制
2. 實現這個SurfaceHolder.Callback接口並且mSurfaceHolder.addCallback(this)添加回調可以感知到SurfaceView的生命周期
3. 繪制的時候mCanvas.drawColor(Color.BLACK);這個方法很重要,這個方法是清理上一次繪制的東西,這個方法一定要調用才能看到效果
實現效果 如下:
第一步:新建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; // 開關線程的標志位 boolean isRunning = true; // 畫筆 Paint mPaint; // 圓的半徑 float radius = 0; // 圓是變大還是縮小的狀態 boolean status = true; // 圓變化的速度 int mSpeed = 3; public XRSurfaceView(Context context, AttributeSet attrs) { super(context, attrs); initView(); } private void initView() { // 獲取mSurfaceHolder mSurfaceHolder = getHolder(); // 添加回調 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) { // 關閉繪制線程 isRunning = false; } @Override public void run() { Canvas mCanvas = null; while (isRunning) { try { // 鎖定canva進行繪制 mCanvas = mSurfaceHolder.lockCanvas(null); // 這個方法很重要,相當於重繪(一定要調用不然看不到效果) 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>
運行!
更多關於Android相關內容感興趣的讀者可查看本站專題:《Android開發入門與進階教程》、《Android基本組件用法總結》、《Android視圖View技巧總結》、《Android布局layout技巧總結》及《Android控件用法總結》
希望本文所述對大家Android程序設計有所幫助。
簡介通過android studio生成so庫的實踐。上一篇記錄的是通過eclipse生成so的方法eclipse生成so庫實踐,這裡記錄一下通過android stud
本節引言: 上一節,我們學習了Xfermode兩個已經過世(過時)的兒子:AvoidXfermode, PixelXorXfermode, 雖然說有點用,但是
1.生命周期場景演示 : 切換到該Fragment11-29 14:26:35.095: D/AppListFragment(7649): onAttach11-29 1
在項目中,我們常常需要實現界面滑動切換的效果。例如,微信界面的左右滑動切換效果。那這種效果是怎麼實現的?今天我就帶大家簡單了解ViewPager,並通過實例來實現該效果。