整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          這是一份你值得保存學習的HTML5技術干貨整理分享

          記得在過去的Web前端開發中,如果你需要繪圖或者生成相關圖形的話,使用Flash可能是你唯一或者說最強大的實現方式,而在近些年的技術熱點HTML5標準中,HTML Canvas(畫布)能夠更加方便的幫助你實現2D繪制圖形圖像及其各種動畫效果功能。

          首先我們先來了解一下什么是HTML Canvas?

          我們可以在HTML中使用屬性width和height來定義Canvas。但是實現Canvas的相關功能主要還依賴于Javascript實現,即HTML5 Canvas API。我們使用javascript來訪問和控制Canvas相關的區域,比如調用相關繪圖的方法,用來動態的生成需要的動畫或者圖形。

          接下來我們來看看canvas的特性:

          互動性:Canvas支持互動,可以很好的響應用戶的操作,我們可以通過Javascript來監鍵盤,鼠標,及其觸摸設備相關事件。

          動 畫:任何被canvas繪制的圖形都可以添加動畫,簡單的彈跳球或者復雜的HTML5游戲都可以實現

          靈活性:開發人員可以使用Canvas來繪制任何的內容,比如,直線,圖形,文字,圖片等,可以包含動畫或者不包含。同時你可以添加音頻或者視頻瀏覽器支持:幾乎所有的現代瀏覽器都支持,并且被廣泛的各種設備支持,例如,桌面,平板,智能手機等等。

          流行度:canvas目前很流行,很多的開發人員都使用它來開發類似游戲或者繪圖類應用

          web標準:只需要有瀏覽器就可以運行,而非flash或者silverlight,需要安裝相關的插件

          開發一次,任何瀏覽器都可以運行(當然,不包括老式瀏覽器)

          可以使用免費擁有大量的開發工具及其類庫。

          使用HTML5 Canvas我們能開發那些相關產品或者應用呢?

          1 可視化數據: 各類統計圖表,比如:百度的echart

          2 場景秀:用Canvas實現動態的廣告效果能夠非常融洽的跨平臺運行。如:手機中微產品.在移動端兼容性很好。

          3 游戲:canvas在基于Web的圖像顯示方面比Flash更加立體、更加精巧,canvas成為HTML5小游戲開發首選。現階段h5做游戲,營業方式不是很明確. 25 超棒的 HTML5 Canvas 游戲。

          4 其他可嵌入網站的內容 (多用于活動頁面、特效):類似圖表、音頻、視頻,還有許多元素能夠更好地與Web融合,并且不需要任何插件。

          5 趨勢=> 模擬器: 無論從視覺效果還是核心功能方面來說,模擬器產品可以完全由JavaScript來實現。模擬真實硬件環境,如移動端各種類型手機.

          6 趨勢=> 遠程計算機控制: Canvas可以讓開發者更好地實現基于Web的數據傳輸,構建一個完美的可視化控制界面。

          7 趨勢=> 圖形編輯器: Photoshop圖形編輯器將能夠100%基于Web實現。

          如何使用HTML5 Canvas?

          使用HTML5 canvas其實非常簡單, 每一個canvas都擁有一個上下文(context)。使用它你可以來調用相關的畫布方法。

          <canvas id="mycanvas" width="500" height ="400">

          <p>您的瀏覽器不支持HTML5 Canvas</p>

          </canvas>

          以上代碼我們在HTML中添加了一個canvas標簽,如果瀏覽器不支持canvas,會顯示<p>標簽的內容,當然,如果你需要支持老式瀏覽器你也可以使用flash或者其它方法來做一個替代的解決方案。

          var canvas = document.getElementById('mycanvas'),

          context = canvas.getContext(‘2d’);

          以上代碼我們通過canvas取到2D的context。

          在HTML5 Canvas的2D結構中,坐標(0,0)在左上方,這和傳統的坐標不太一樣。大家需要注意一下,如下圖所示:

          下面來說一下canvas的API:

          canvas的主要屬性和方法:

          save():保存當前環境的狀態

          restore():返回之前保存過的路徑狀態和屬性

          createEvent()

          getContext():返回一個對象,指出訪問繪圖功能必要的API

          toDateURL():返回canvas圖像的URL

          顏色、樣式和陰影屬性和方法:

          fillStyle:設置或返回用于填充繪畫的顏色、漸變或模式

          strokeStyle:設置或返回用于筆觸的顏色、漸變或模式

          shadowColor:設置或返回用于陰影的顏色

          shadowBlur:設置或返回用于陰影的模糊級別

          shadowOffsetX:設置或返回陰影距形狀的水平距離

          shadowOffsetY:設置或返回陰影距形狀的垂直距離

          createLinearGradient():創建線性漸變(用在畫布內容上)

          createPattern():在指定的方向上重復指定的元素

          createRadialGradient():創建放射狀/環形的漸變(用在畫布內容上)

          addColorStop():規定漸變對象中的顏色和停止位置

          線條樣式屬性和方法

          lineCap:設置或返回線條的結束端點樣式

          lineJoin:設置或返回兩條線相交時,所創建的拐角類型

          lineWidth:設置或返回當前的線段寬度

          miterLimit:設置或返回最大斜接長度

          Canvas的API-路徑方法

          fill():填充當前繪圖(路徑)

          stroke():繪制已定義的路徑

          beginPath():起始一條路徑,或重置當前路徑

          moveTo():把路徑移動到畫布中的指定點,不創建線條

          closePath():創建從當前點回到起始點的路徑

          lineTo():添加一個新點,創建從該點到最后指定點的線條

          clip():從原始畫布剪切任意形狀和尺寸的區域

          quadraticCurveTo():創建二次貝塞爾曲線

          bezierCurveTo():創建三次貝塞爾曲線

          arc():創建弧/曲線(用于創建圓形或部分圓)

          arcTo():創建兩切線之間的弧/曲線

          isPointInPath():如果指定的點位于當前路徑中,返回布爾值

          Canvas的API-轉換方法

          scale():縮放當前繪圖至更大或更小

          rotate():旋轉當前繪圖

          translate():重新映射畫布上的(0,0)位置

          transform():替換繪圖的當前轉換矩陣

          setTransform():將當前轉換重置為單位矩陣,然后運行transform()

          Canvas的API-文本屬性和方法

          font:設置或返回文本內容的當前字體屬性

          textAlign:設置或返回文本內容的當前對齊方式

          textBaseline:設置或返回在繪制文本時使用的的當前文本基線

          fillText():在畫布上繪制“被填充的”文本

          strokeText():在畫布上繪制文本(無填充)

          measureText():返回包含指定文本寬度的對象

          Canvas的API-圖像繪制方法

          drawImage():向畫布上繪制圖像、畫布或視頻

          Canvas的API-像素操作方法和屬性

          width:返回ImageData對象的寬度

          height:返回ImageData對象的高度

          data:返回一個對象,其包含指定的ImageData對象的圖像數據

          createImageData():創建新的、空白的I馬哥Data對象

          getImageData():返回ImageData對象,該對象為畫布上指定的矩形復制像素數據

          putImageData():把圖像數據(從指定的ImageData對象)放回畫布上

          Canvas的API-圖像合成屬性

          globalAlpha:設置或返回繪圖的當前alpha或透明值

          globalCompositeOperation:設置或返回新圖像如何繪制到已有的圖像上

          快速高效的創建HTML5畫布圖形?

          直接使用Canvas來繪制圖形相對來說比較乏味并且麻煩,所以在現代的HTML5 Canvas中我們使用一些現成的第三方類庫幫助我們多快好省的實現圖形繪制的功能:

          KineticJS

          Paper.js

          EaselJS

          Fabric.js

          oCanvas

          Echart.js

          多特效代碼請添加HTML5前端交流群581549454

          廢話不多說,上代碼!

          源代碼:

          <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.aaa-cg.com.cn?lcc">

          <html xmlns="http://www.aaa-cg.com.cn?lcc">

          <head>

          <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

          <title>非常酷的3D立體圖片相冊展示代碼</title>

          <meta name="Author" content="Gerard Ferrandez at http://www.dhteumeuleu.com">

          <link href="css/lanrenzhijia.css" type="text/css" rel="stylesheet" />

          <script type="text/javascript" src="js/lanrenzhijia.js"></script>

          </head>

          <body>

          <div id="screen" style="zoom:1">

          <span><img src="images/pr04.jpg" title="One morning" alt="-2,-1,-.8,1.5,2"></span>

          <span><img src="images/pr03.jpg" title="hailing the Sun" alt="-1,-.8,0,1.2,1.6"></span>

          <a target="_blank" ><img src="images/3D-eyes-big.jpg" title="befriending death" alt="-1.5,-.9,.8,3,1.8"></a>

          <span><img src="images/pr01.jpg" title="world at myfingertips" alt="1,-.6,.2,1,.75"></span>

          <span><img src="images/pr02.jpg" title="gathering strength" alt="-1.7,0,.4,1.4,1"></span>

          <span><img src="images/pr07.jpg" title="I said, all right." alt=".5,-1,-.4,1.5,2"></span>

          </div>

          </body>

          </html>

          代碼很簡單,但是能實現的效果很強大

          需要文檔版本源碼,可以加我的HTML5前端交流群581549454

          一、項目背景】

          隨著HTML5 CSS3的出現和發展,使得我們的網頁可以實現更加復雜的效果,也使得我們的瀏覽體驗更加豐富,所以今天我們將制作一個正方體的3D效果。


          【二、項目分析】

          想要利用CSS3實現3D立方體,就要清楚立方體是由六個面組成,分上下左右和前后,考慮這些可以幫助我們更好的融入CSS3的代碼。

          因此我設置了6個div,作為立方體的6個面。因為定位的原因,一開始所有的盒子都是面對著屏幕這面的,因此要賦予每個面不一樣的值,即不一樣的位置它才能展現出來。


          【三、需要的工具】

          Adobe Dreamweaver


          【四、項目目標】

          實現3的l立方體旋轉,鼠標移上去實現縮放效果。


          【五、項目實現】

          1、打開Adobe Dreamweaver,新建html文檔。把標題改為“3d立方體”。


          2、在body標簽,創建一個div盒子 ,給它class屬性,在外層div里面在創建6個div表示立方體的六個面,同樣給它們 class屬性。

          <body>
              <div class="box">
                <div class="box2">
                  <div class="box-2">top</div>
                  <div class="box-2">btm</div>
                  <div class="box-2">left</div>
                  <div class="box-2">right</div>
                  <div class="box-2">face</div>
                  <div class="box-2">back</div>
                </div>
              </div>
          </body>

          3、創建CSS樣式

          <style type="text/css">
          .box {
            width: 200px;
            height: 200px;
            position: absolute;
            top: 0;
            left: 0;
            bottom: 0;
            right: 0;
            margin: auto;
            transition: all 2s;
            transform-style: preserve-3d;
            transform: rotateX(15deg) rotateY(-15deg);
          }
          .box:hover {
            transform: rotateX(300deg) rotateZ(300deg) rotateY(-300deg) scale(0.5);
          }
          .box .box-2 {
            width: 100px;
            height: 100px;
            text-align: center;
            line-height: 100px;
            font-size: 1.2em;
            position: absolute;
            top: 0;
            left: 0;
          }
          .box .box-2:nth-child(1) {
            /*小立方體第一面*/
            background: rgba(225,0,0,0.5);
            transform: rotateX(90deg) translateZ(50px); #角度 偏移量
          }
          .box .box-2:nth-child(2) {
              /*小立方體第二面*/
            background: rgba(255,255,0,0.5);
            transform: rotateX(-90deg) translateZ(50px);
          }
          .box .box-2:nth-child(3) {
              /*小立方體第三面*/
            background: rgba(225,0,255,0.5);
            transform: rotateY(-90deg) translateZ(50px);
          }
          .box .box-2:nth-child(4) {
               /*小立方體第四面*/
            background: rgba(0,255,0,0.5);
            transform: rotateY(90deg) translateZ(50px);
          }
          .box .box-2:nth-child(5) {
               /*小立方體第五面*/
            background: rgba(225,0,0,0.5);
            transform: translateZ(50px);
          }
          .box .box-2:nth-child(6) {
              /*小立方體第六面*/
            background: rgba(0,0,255,0.5);
            transform: rotateY(180deg) translateZ(50px);
          }
          </style>
            </head>
            <body>
              <div class="box">
                <div class="box2">
                  <div class="box-2">top</div>
                  <div class="box-2">btm</div>
                  <div class="box-2">left</div>
                  <div class="box-2">right</div>
                  <div class="box-2">face</div>
                  <div class="box-2">back</div>
                </div>
              </div>
          </body>
          </html>

          方法說明:

          rotateX() 方法

          通過 rotateX() 方法,元素圍繞其 X 軸以給定的度數進行旋轉。

          rotateY() 旋轉

          通過 rotateY() 方法,元素圍繞其 Y 軸以給定的度數進行旋轉。

          rotateZ() 旋轉

          通過 rotateZ() 方法,元素圍繞其 Z 軸以給定的度數進行旋轉。

          下表是部分屬性所代表的含義:



          4、運行一下看下效果;點擊F12運行。


          5、呈現的效果如下圖所示。

          可以看到效果基本上可以 ,可是鼠標移上去沒有效果。

          6、添加鼠標移上去縮放的效果

          .box:hover{
              transform: rotateX(300deg) rotateZ(300deg) rotateY(-300deg) scale(0.5);
          
            } # scale是縮放倍數


          7、外層再添加一個3d立方體形成疊加效果

          body代碼:

          <div class="box">
          <div class="box-1">top</div>
          <div class="box-1">btm</div>
          <div class="box-1">left</div>
          <div class="box-1">right</div>
          <div class="box-1">face</div>
          <div class="box-1">back</div>
          </div>


          CSS樣式代碼

          <style type="text/css">
          .box .box-1{
              width: 200px;
              height: 200px;
              text-align: center;
              line-height: 200px;
              font-size: 2em;
              position: absolute;
              top: 0;
              left: 0;
            }
            .box .box-1:nth-child(1){
              /*大立方體第一面*/
              background: rgba(225,0,0,0.5);
              transform:rotateX(90deg) translateZ(100px);
          
            }.box .box-1:nth-child(2){
                   /*大立方體第二面*/
              background: rgba(255,255,0,0.5);
              transform:rotateX(-90deg) translateZ(100px);
          
            }.box .box-1:nth-child(3){
                  /*大立方體第三面*/
              background: rgba(225,0,255,0.5);
              transform:rotateY(-90deg) translateZ(100px);
            }.box .box-1:nth-child(4){
                   /*大立方體第四面*/
              background: rgba(0,255,0,0.5);
              transform:rotateY(90deg) translateZ(100px);
          
            }.box .box-1:nth-child(5){
                  /*大立方體第五面*/
              background: rgba(225,0,0,0.5);
                transform:translateZ(100px);
            }.box .box-1:nth-child(6){
                  /*大立方體第六面*/
              background: rgba(0,0,255,0.5);
              transform:rotateY(180deg) translateZ(100px);
            }
          </style>


          【六、效果展示】

          1、點擊運行,效果如下圖所示。

          2、鼠標移到立方體上,縮放效果展示,如下圖所示。


          【七、總結】

          1、整個效果寫出來,還是比較簡單的,只要明白各個命令的意思,剩下的就是組織一下邏輯而已。

          2、歡迎大家積極嘗試,有時候看到別人實現起來很簡單,但是到自己動手實現的時候,總會有各種各樣的問題,切勿眼高手低,勤動手,才可以理解的更加深刻。

          3、CSS樣式的效果不止這些,還有更加炫酷的效果,值得大家去學習。

          4、實現的方法3d立方體的方法有很多,但這是最簡單的一種。

          5、如果需要本文源碼,請在公眾號后臺回復“立方體”四個字獲取。


          看完本文有收獲?請轉發分享給更多的人

          IT共享之家

          入群請在微信后臺回復【入群】

          想學習更多Python網絡爬蟲與數據挖掘知識,可前往專業網站:http://pdcfighting.com/


          主站蜘蛛池模板: 99久久精品国产高清一区二区| 天堂va视频一区二区| 一级毛片完整版免费播放一区 | 一区二区3区免费视频| 秋霞日韩一区二区三区在线观看| 无码国产精品久久一区免费| 国产一区中文字幕在线观看 | 99精品久久精品一区二区| 不卡一区二区在线| 国产丝袜视频一区二区三区| 中文字幕一区二区三区免费视频| 在线观看免费视频一区| 国产一区二区三区在线2021| 久久国产精品最新一区| 精品福利视频一区二区三区| 糖心vlog精品一区二区三区| 在线观看国产一区亚洲bd| 在线视频一区二区三区三区不卡| 精品国产不卡一区二区三区| 精品一区二区三区波多野结衣| 色窝窝免费一区二区三区| 精品无码成人片一区二区| 中文字幕一区二区人妻| 97久久精品无码一区二区天美| 加勒比精品久久一区二区三区 | 色视频综合无码一区二区三区| 亚洲AV无码一区二三区| 中文字幕一区二区三区5566| 无码av免费一区二区三区试看| 亚洲AV无码一区二区乱子仑| 国产精品一区二区三区99| 国产精品久久一区二区三区| 精品乱码一区二区三区在线| 91亚洲一区二区在线观看不卡| 国产aⅴ一区二区| 精品福利一区二区三区免费视频| 精品人妻少妇一区二区| 欧美人妻一区黄a片| 久久久久人妻一区二区三区 | 免费观看日本污污ww网站一区| 精品一区二区三区中文字幕|