Canvas with React
What is Canvas ?
<canvas>
<canvas>
- HTML 元素
- IE9 以下不支援
- 繪製圖形
- 製作動畫
- 影像繪圖
- 合成、變形資源
data:image/s3,"s3://crabby-images/8d852/8d852f4a133650a8ee4a0bfe9b08664837e39651" alt=""
Canvas Example
- getContext
- get Render Context
- Static Size
data:image/s3,"s3://crabby-images/b0aa1/b0aa144c7d59724ee18cf7b1999d109f8b07ef17" alt=""
data:image/s3,"s3://crabby-images/8d852/8d852f4a133650a8ee4a0bfe9b08664837e39651" alt=""
Draw Graph
- Gird Concept
- Method
- 矩形
- fillRect
- strokeRect
- clearRect
- 路徑繪製
- beginPath
- closePath
- stroke
- fill
- moveTo
- lineTo
- Path2D objects
- 矩形
data:image/s3,"s3://crabby-images/62c29/62c299e8d6f1a0712e604ec4011bf10966b5e683" alt=""
矩形繪製
-
fillRect(x, y, width, height)
- 畫出一個填滿的矩形
-
strokeRect(x, y, width, height)
- 畫出一個矩形的邊框
-
clearRect(x, y, width, height
- 清除指定矩形區域內的內容,使其變為全透明。
data:image/s3,"s3://crabby-images/b0aa1/b0aa144c7d59724ee18cf7b1999d109f8b07ef17" alt=""
路徑繪製
- beginPath
- 產生一個新路徑,產生後再使用繪圖指令來設定路徑。
- closePath
- 閉合路徑好讓新的繪圖指令來設定路徑。
- stroke
- 畫出圖形的邊框。
- fill
- 填滿路徑內容區域來產生圖形。
- moveTo
- 移動畫筆到指定的(x, y)座標點
- lineTo
- 從目前繪圖點畫一條直線到指定的(x, y)座標點。
data:image/s3,"s3://crabby-images/393e5/393e521848ad66d13dd65ff1f43611a35622733a" alt=""
data:image/s3,"s3://crabby-images/404a6/404a6b229b9b017474293579cb5586c44d8baaf8" alt=""
What I Done
data:image/s3,"s3://crabby-images/92f3e/92f3eede9fb7381e1bfcfb7ae77437ac307a5f3e" alt=""
Canvas With React
And How to combine?
What we need to be done?
React Flow
React Flow
- Start to Draw
- Draw Layout
- Draw Board
- Draw Icon
- Draw Dots
- Draw Layout
- Refresh When Dot Move
- onDraw
- canvas method
- Dot Mouse method
- mouse down, mouse up, mouse move, mouse out
- onDraw
- Browser Size Change - window resize listener
Final Flow
data:image/s3,"s3://crabby-images/e0bf3/e0bf3195f9afc839ae013cb7e5720f37f74a7d8a" alt=""
To Be Continuted...
data:image/s3,"s3://crabby-images/f48e3/f48e3bd9a1cc1dc7d1007a10be8613803f8c0262" alt=""
data:image/s3,"s3://crabby-images/0e86a/0e86a303f9131bd539c4ee78eb62adc5ae6f5d1b" alt=""
三角函數登場
data:image/s3,"s3://crabby-images/8e056/8e0560ccecd5fcb5d344f3535e2e308f30c33375" alt=""
- (A ->) B -> C -> D
- 已知:O1, O2
- Canvas Function
- arc
- 已知兩點向量
- 求兩點間的圓弧角度
const startAngle = Math.atan2(prevCenter.y - center.y, prevCenter.x - center.x);
const endAngle = Math.atan2(dy, dx);
this.ctx.arc(center.x, center.y, RADIUS, startAngle, endAngle, false);
Title Text
Canvas with React
By Stanney Yen
Canvas with React
- 347