這篇文章主要介紹了在canvas上實現元素圖片鏡像翻轉動畫效果的方法的相關資料,內容挺不錯的,現在分享給大家,也給大家做個參考。
一、Canvas圖片水平鏡像翻轉效果預覽
#您可以狠狠的點擊這裡:canvas圖片水平鏡像翻轉動畫demo
demo頁面中點選圖片動畫效果可見。
二、Canvas上實現圖片鏡像翻轉的實作
#CSS中要想實現元素的翻轉效果,比較簡單,例如我們希望某一張圖片水平鏡像翻轉,只需要一行CSS就可以了:
img { transform: scaleX(-1); }
或:
img { transform: scale(-1, 1); }
但是在canvas中,則要麻煩一些,麻煩的並不是無法翻轉,而是座標系的定位。
在Canvas中,如下程式碼可以實現資源的水平鏡像翻轉(假設context 是Canvas的2d 上下文):
context.scale(-1, 1);
或使用setTransform API直接矩陣變換:
context.setTransform(-1, 0, 0, 1, 0, 0);
然而,翻轉雖然實現了,但是Canvas中元素定位就出了很大的問題。這是因為Canvas的座標變換系和CSS不一樣,因此,如果我們想實現居中翻轉效果,需要在翻轉之前將目標元素的中心點移動到變換軸上。
拿水平翻轉距離,在 scale 之前先 translate 位移變換後的水平偏移,然後就能看到一直居中翻轉的效果了。
語言蒼白,拿圖示意一下。
canvas預設的變化座標係是左上角。
因此,若水平scale 為1 , 0.5 , 0 , -0.5 , -1 時候的最終位置如下圖示意:
於是可以得到應當偏移的水平距離公式:
distance = (canvas.width – image.width * scale) / 2;
// 坐标参考调整 context.translate((canvas.width - image.width * scale) / 2, 0); context.scale(scale, 1); context.drawImage(image, 0, 0); // 坐标参考还原 context.setTransform(1, 0, 0, 1, 0, 0);如何增加動畫效果呢? 我們可以藉助Tween.js , https://github.com/zhangxinxu/tween裡面有各種緩動演算法,借助方便呼叫的Math.animation() 方法,就能輕鬆實現我們想要的效果啦!
Math.animation(form, to, duration, easing, callback);動畫JS如下:
var canvas = document.querySelector('canvas'); var context = canvas.getContext('2d'); // 动画进行 Math.animation(1, -1, 600, 'Quad.easeInOut', function (value, isEnding) { // 清除画布内容 context.clearRect(0, 0, canvas.width, canvas.height); // 调整坐标 context.translate((canvas.width - canvas.width * value) / 2, 0); // 调整缩放 context.scale(value, 1); // 绘制此时图片 context.drawImage(eleImg, 0, 0); // 坐标参考还原 context.setTransform(1, 0, 0, 1, 0, 0); });
三、結束語
又是一篇冷文,canvas這東西,玩的前端不多,受眾有限,不比流行技術。然,古語有云,不以善小而不為,希望以後有小夥伴搜尋到相關問題的時候可以提供幫助。 以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網! 相關推薦:##
以上是在canvas上實現元素圖片鏡像翻轉動畫效果的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

H5與HTML5指的是同一個東西,即HTML5。 HTML5是HTML的第五個版本,帶來了語義化標籤、多媒體支持、畫布與圖形、離線存儲與本地存儲等新功能,提升了網頁的表現力和交互性。

H5referstoHTML5,apivotaltechnologyinwebdevelopment.1)HTML5introducesnewelementsandAPIsforrich,dynamicwebapplications.2)Itsupportsmultimediawithoutplugins,enhancinguserexperienceacrossdevices.3)SemanticelementsimprovecontentstructureandSEO.4)H5'srespo

H5開發需要掌握的工具和框架包括Vue.js、React和Webpack。 1.Vue.js適用於構建用戶界面,支持組件化開發。 2.React通過虛擬DOM優化頁面渲染,適合複雜應用。 3.Webpack用於模塊打包,優化資源加載。

HTML5hassignificantlytransformedwebdevelopmentbyintroducingsemanticelements,enhancingmultimediasupport,andimprovingperformance.1)ItmadewebsitesmoreaccessibleandSEO-friendlywithsemanticelementslike,,and.2)HTML5introducednativeandtags,eliminatingthenee

H5通過語義化元素和ARIA屬性提升網頁的可訪問性和SEO效果。 1.使用、、等元素組織內容結構,提高SEO。 2.ARIA屬性如aria-label增強可訪問性,輔助技術用戶可順利使用網頁。

"h5"和"HTML5"在大多數情況下是相同的,但它們在某些特定場景下可能有不同的含義。 1."HTML5"是W3C定義的標準,包含新標籤和API。 2."h5"通常是HTML5的簡稱,但在移動開發中可能指基於HTML5的框架。理解這些區別有助於在項目中準確使用這些術語。

H5,即HTML5,是HTML的第五個版本,它為開發者提供了更強大的工具集,使得創建複雜的網頁應用變得更加簡單。 H5的核心功能包括:1)元素允許在網頁上繪製圖形和動畫;2)語義化標籤如、等,使網頁結構清晰,利於SEO優化;3)新API如GeolocationAPI,支持基於位置的服務;4)跨瀏覽器兼容性需要通過兼容性測試和Polyfill庫來確保。

如何創建 H5 鏈接?確定鏈接目標:獲取 H5 頁面或應用程序的 URL。創建 HTML 錨點:使用 <a> 標記創建錨點並指定鏈接目標URL。設置鏈接屬性(可選):根據需要設置 target、title 和 onclick 屬性。添加到網頁:將 HTML 錨點代碼添加到希望鏈接出現的網頁中。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

WebStorm Mac版
好用的JavaScript開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Linux新版
SublimeText3 Linux最新版

記事本++7.3.1
好用且免費的程式碼編輯器