2020年3月24日 星期二

[ Android Studio ]表面視圖 SurfaceView 與畫布 Canvas 結合的用法


一、介紹:
1. SurfaceView 功能:

setZOrderOnTop():Z軸,控制項在容器之圖層順序上面,true為開啟。
setBackgroundColor():背景。Color.RED為紅色

2. SurfaceHolder 功能:



setFormat():設置格式。PixelFormat.TRANSLUCENT為像素格式.半透明。
lockCanvas():鎖定畫布。
unlockCanvasAndPost():解鎖畫布並發布。

3. Paint功能:

setColor():繪制顏色。Color.BLUE 為藍色。

4. Canvas 功能:

drawCircle():圓形。drawCircle(x位置,y位置,半經,繪制畫筆)
drawArc():扇形。
drawOval():橢圓。
drawPoint():點。
drawRect():矩形。
drawRoundRect():圓角矩形。
drawLine():線。
drawPath():路徑。

二、 語法如下:
package com.example.canvas_0;
import androidx.appcompat.app.AppCompatActivity;
import androidx.constraintlayout.widget.ConstraintLayout;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.PixelFormat;
import android.os.Bundle;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

SurfaceView view2=(SurfaceView)findViewById(R.id.surfaceView);
view2.setZOrderOnTop(true);
view2.setBackgroundColor(Color.RED);
SurfaceHolder holder = view2.getHolder();
holder.setFormat(PixelFormat.TRANSLUCENT);//PixelFormat.TRANSLUCENT為像素格式.半透明

holder.addCallback(new SurfaceHolder.Callback() {
@Override
public void surfaceCreated(SurfaceHolder holder) {
Canvas canvas= holder.lockCanvas();
Paint p = new Paint();
p.setColor(Color.BLUE);
canvas.drawCircle(200,200,100,p);
holder.unlockCanvasAndPost(canvas);
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
}
});


}
}
x

沒有留言:

張貼留言

影片的問題請留在影片的留言區裡。
部落格不會另外通知給我,所以很難發現你有留言。