首頁 > web前端 > H5教程 > HTML5高階程式設計之圖形扭曲及其應用二(運用篇)

HTML5高階程式設計之圖形扭曲及其應用二(運用篇)

黄舟
發布: 2017-03-02 13:31:51
原創
2979 人瀏覽過

上次介紹了在html5中實現圖片扭曲效果的原理,並擴展成了drawtriangles函數,

下面來詳細講解一下drawtriangles函數的使用方法。 並且使用drawtriangles函數實作下面這種處理效果


因為這個方法是從AS3移植而來,所以它的使用方法和AS3基本上一致,這裡是AS3的drawtriangles函數API,大家可以參考一下

http://help.adobe.com/zh_CN/FlashPlatform/reference/ actionscript/3/flash/display/Graphics.html#drawTriangles()

#上次也說明過,移植後的drawtriangles函數,第4個之後的參數的意義不同,在這裡它第4個參數表示分割線的線粗,第5個參數則表示分割線的顏色,如果不設定,則不顯示分割線

drawTriangles函數的定義

drawTriangles(vertices, indices, uvtData,thickness,color)
vertices:由数字构成的矢量,其中的每一对数字将被视为一个坐标位置(一个 x, y 对)。vertices 参数是必需的。
indices:一个由整数或索引构成的矢量,其中每三个索引定义一个三角形。
如果 indexes 参数为 null,则每三个顶点(vertices 矢量中的 6 对 x,y)定义一个三角形。否则,每个索引将引用一个顶点,即 vertices 矢量中的一对数字。
例如,indexes[1] 引用 (vertices[2], vertices[3])。
uvtData:由用于应用纹理映射的标准坐标构成的矢量。
每个坐标引用用于填充的位图上的一个点。每个顶点必须具有一个 UV 或一个 UVT 坐标。对于 UV 坐标,(0,0) 是位图的左上角,(1,1) 是位图的右下角。
thickness:分割三角形的边框的线粗
color:分割三角形的边框的颜色
登入後複製

直接看上面的文字,恐怕不太容易理解,下面來舉幾個例子,最後兩個參數比較簡單,先來說說這兩個參數,下面是最後兩個參數線寬設定為2,顏色為白色的效果



可以看到,上圖顯示了三角形的邊框。

好了,接下來說說其他三個參數的用法,

#1,第一個參數vertices,其實就是定義每個頂點的座標,這幾個頂點的順序依次為下圖


vertices參數儲存的就是上面的9個頂點的座標,程式碼如下

vertices = new Array();
vertices.push(0, 0);
vertices.push(0, 120);
vertices.push(0, 240);
vertices.push(120, 0);
vertices.push(120, 120);
vertices.push(120, 240);
vertices.push(240, 0);
vertices.push(240, 120);
vertices.push(240, 240);
登入後複製

2,第二個參數indices是定義三角形,陣列vertices中每三個頂點可以組成一個三角形,indices就是來定義這些三角形,這些三角形的頂點順序是有規定的,其實從前面的圖中可以看到,每兩個三角形是一個矩形,定義這些三角形的時候,要以這些矩形的四個頂點為基準,三角形的頂點順序分別是(左上,右上,左下)和(右上,左下,右下),如下圖所示



對應圖中的三角形,程式碼如下

indices = new Array();
indices.push(0, 3, 1);
indices.push(3, 1, 4);
indices.push(1, 4, 2);
indices.push(4, 2, 5);
indices.push(3, 6, 4);
indices.push(6, 4, 7);
indices.push(4, 7, 5);
indices.push(7, 5, 8);
登入後複製


2,第三個參數uvtData是定義上面的每個頂點相對於整張圖片的比例,例如上面的圖中的9個頂點的座標,他們相對於原圖片中的位置分別為下圖所示


換算成程式碼如下

uvtData = new Array();
uvtData.push(0, 0);
uvtData.push(0, 0.5);
uvtData.push(0, 1);
uvtData.push(0.5, 0);
uvtData.push(0.5, 0.5);
uvtData.push(0.5, 1);
uvtData.push(1, 0);
uvtData.push(1, 0.5);
uvtData.push(1, 1);
登入後複製

有了上面這些參數的定義,然後透過LSprite物件的graphics屬性的beginBitmapFill和drawTriangles兩個函數,就可以繪製多樣化的圖形了

beginBitmapFill是用點陣圖影像填滿繪圖區,參數是LBitmapData物件

如果,在vertices參數中定義的座標位置就是原始圖片中對應的位置,那麼圖片就是沒有什麼變化的,但是,如果改變這些座標的位置,例如下面的程式碼

vertices = new Array();
vertices.push(0, 0);
vertices.push(0-50, 120);//这里将原坐标的x坐标左移50
vertices.push(0, 240);
vertices.push(120, 0);
vertices.push(120, 120);
vertices.push(120, 240);
vertices.push(240, 0);
vertices.push(240+50, 120);//这里将原坐标的x坐标右移50
vertices.push(240, 240);

indices = new Array();
indices.push(0, 3, 1);
indices.push(3, 1, 4);
indices.push(1, 4, 2);
indices.push(4, 2, 5);
indices.push(3, 6, 4);
indices.push(6, 4, 7);
indices.push(4, 7, 5);
indices.push(7, 5, 8);

uvtData = new Array();
uvtData.push(0, 0);
uvtData.push(0, 0.5);
uvtData.push(0, 1);
uvtData.push(0.5, 0);
uvtData.push(0.5, 0.5);
uvtData.push(0.5, 1);
uvtData.push(1, 0);
uvtData.push(1, 0.5);
uvtData.push(1, 1);
backLayer.graphics.beginBitmapFill(bitmapData);
backLayer.graphics.drawTriangles(vertices, indices, uvtData);
登入後複製

效果如圖


上面的變形是將圖片分割成了8個三角形,要實現更多種變形,那隻需要將圖片分割成更多的小三角形就可以了

比如我利用這個函數,製作了一個簡陋的圖片修飾工具,效果如下



#大家可以點選下面的連接,來測試它的效果

http://lufylegend.com/html5/lufylegend/ps.html

 轉載請註明:轉自lufy_legend的部落格


#備註:

使用drawtriangles函數,你需要下載HTML5開源引擎lufylegend的1.5版或以上版本,lufylegend1.5版發佈位址如下

http://blog.csdn.net/lufy_legend/article/details/8054658

##以上就是HTML5高階程式設計圖形扭曲及其應用二(運用篇)的內容,更多相關內容請關注PHP中文網(www.php.cn)!


來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板