【canvas學習筆記一】基本認識

来源:http://www.cnblogs.com/-867259206/archive/2017/07/25/7235780.html
-Advertisement-
Play Games

<canvas>標簽定義了一塊畫布,畫布可以在網頁中繪製2D和3D圖象,現在先學習如何繪製2D圖象,繪製3D圖象屬於WebGL的內容(也就是網頁版的OpenGL,3D圖形介面)。 屬性 <canvas>只有width和height兩個屬性。如果沒有設置width和height屬性,canvas的預設 ...


<canvas>標簽定義了一塊畫布,畫布可以在網頁中繪製2D和3D圖象,現在先學習如何繪製2D圖象,繪製3D圖象屬於WebGL的內容(也就是網頁版的OpenGL,3D圖形介面)。

屬性

<canvas>只有width和height兩個屬性。如果沒有設置width和height屬性,canvas的預設初始大小是寬300px,高150px。如果通過CSS來設置canvas的寬高,而設置的寬高不是預設大小的比例,則canvas呈現的圖象會失真變形。所以,建議用JavaScript來設置canvas的寬高。
如果沒有給canvas設置樣式,那麼canvas將是一塊透明的矩形,除非在上面繪製圖形。

反饋信息

<canvas>標簽很容易定義反饋信息。如果瀏覽器不支持<canvas>標簽,則canvas不會出現,而包含在<canvas></canvas>標簽之間的內容則會顯現出來。比如:

<canvas>
  Your browser doesn't support!
</canvas>

如果瀏覽器不支持<canvas>標簽的話,則會顯示“Your browser doesn't support!”這條信息。 如果瀏覽器支持<canvas>標簽,則這些內容不會顯示。

繪圖上下文

要在canvas上繪圖,要獲取canvas的繪圖上下文,通過繪圖上下文在canvas上繪製圖形、圖象。 繪製2D圖形要獲取2D繪圖上下文,繪製3D圖形要獲取3D繪圖上下文,這就屬於WebGL的內容了。

<canvas id="canvas">
Your browser doesn't support!
</canvas>

省略完整代碼,下麵是JavaScript部分
var canvas = document.getElementById('canvas');
var ctx = canvas.getContext('2d');

用.getContext方法就可以獲得2D繪圖上下文。如何用ctx繪製圖形下一篇再說。

相容性檢測

之前說了<canvas>標簽內包含的反饋信息,現在說如何用JavaScript來檢測canvas的相容性。通過檢測.getContext方法是否存在來判斷。 代碼如下:

var canvas = document.getElementById('canvas');

if (canvas.getContext) {
  var ctx = canvas.getContext('2d');
  // drawing code here
} else {
  // canvas-unsupported code here
}

 

關於canvas的基礎認識就到這啦。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 相同點 兩者都用於在網頁載入完後執行相應代碼塊。 不同點 window.onload 在創建完 DOM 樹後,所有外部資源(圖片、Flash 動畫等)載入完成,且整個頁面在瀏覽器視窗中顯示完畢之後,才會執行。 $(document).ready 只需在 HTML 文檔解析為 DOM 樹後,就會執行。 ...
  • 用vue-cli生成項目時,如果選擇了單元測試,那麼會採用karma+mocha作為單元測試框架,預設使用的瀏覽器是PhantomJs。 Karma是一個基於Node.js的JavaScript測試執行過程管理工具(Test Runner)。可啟動所有主流Web瀏覽器作為測試容器,運行時會啟動一個w ...
  • 通過jQuery思維導圖,來進行計劃的溫習/掌握 jQuery技能。 通過思維導圖的思路學習,是很好的學習方法之一,思路清晰、跟上環節,易於貫通,重要的是少走彎路。 這裡一共有6張圖,第1張是大綱路線,順著路線可以掌握jQuery常用的操作,後面5張是關於jQuery相關Api及性能優化的細節。 結 ...
  • 一 HTML 是一種製作網站的標記語言 二、HTML基本語法 html標簽是html中的最基本單位 也是最重要的部分 通常使用尖角號 開始”<”和結束”>” 標簽分為兩種(成對出現 和不成 對出現) 雙標簽:(成對)<標簽名>內容</標簽名> 例如:<body></body><html></html ...
  • 冒泡排序<script type="text/javascript"> var arr = [3,7,6,2,1,5]; 定義一個交換使用的中間變數var temp = 0;for(i=0;i<arr.length;i++){ for(j=0;j<arr.length;j++){如果下一個元素小於當 ...
  • cookie、session cookie:在瀏覽器保存一些數據,每次請求都會帶過來 *不安全、有限(4K) session:保存數據,保存在服務端 *安全、無限 session:基於cookie實現的 *cookie中會有一個session的ID,伺服器利用sessionid找到session文件 ...
  • package com.log; import java.io.IOException; import java.net.URLEncoder; import java.util.ArrayList; import java.util.Enumeration; import java.util.Li... ...
  • 安裝 API 可以通過body-parser 對象創建中間件,當接收到客戶端請求時所有的中間件都會給req.body 添加屬性,請求體為空,則解析為空{} (或者出現錯誤)。 bodyParser.json(options) 中間件只會解析 json ,允許請求提任意Unicode編碼支持 gzip ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...