ホームページ >ウェブフロントエンド >jsチュートリアル >JS と Canves はクリックボタンの水の波紋効果を実現します

JS と Canves はクリックボタンの水の波紋効果を実現します

不言
不言オリジナル
2018-06-25 15:38:582680ブラウズ

この記事では、JS と Canvas に基づいたボタンをクリックしたときの波紋エフェクトを紹介します。このエフェクトに興味がある人はぜひご覧ください。クリックすると、水の波紋のエフェクトが生成されます。とても面白かったので、(下位バージョンのブラウザとの互換性の問題を考慮せずに) 簡単に実装しました

まず、以下に示すように、エフェクトを見てみましょう (gif 録画ソフトウェア)。は少し汚く、行き詰まっているように見えます...)

この効果は、要素内でキャンバスをネストするか、CSS3 によって実現できます。

Canves実装

インターネットからcanves実装のコードを拾い、繰り返し定義されたスタイルを少し削除し、jsコメントを付けました。コードは次のとおりです

htmlコード

<a class="btn color-1 material-design" data-color="#2f5398">Press me!</a>

cssコード

* {
box-sizing: border-box;
outline: none;
}
body {
font-family: &#39;Open Sans&#39;;
font-size: 100%;
font-weight: 300;
line-height: 1.5em;
text-align: center;
}
.btn {
border: none;
display: inline-block;
color: white;
overflow: hidden;
margin: 1rem;
padding: 0;
width: 150px;
height: 40px;
text-align: center;
line-height: 40px;
border-radius: 5px;
}
.btn.color-1 {
background-color: #426fc5;
}
.btn-border.color-1 {
background-color: transparent;
border: 2px solid #426fc5;
color: #426fc5;
}
.material-design {
position: relative;
}
.material-design canvas {
opacity: 0.25;
position: absolute;
top: 0;
left: 0;
}
.container {
align-content: center;
align-items: flex-start;
display: flex;
flex-direction: row;
flex-wrap: wrap;
justify-content: center;
margin: 0 auto;
max-width: 46rem;
}

jsコード

var canvas = {},
centerX = 0,
centerY = 0,
color = &#39;&#39;,
containers = document.getElementsByClassName(&#39;material-design&#39;)
context = {},
element = {},
radius = 0,
// 根据callback生成requestAnimationFrame动画
requestAnimFrame = function () {
return (
window.requestAnimationFrame || 
window.mozRequestAnimationFrame || 
window.oRequestAnimationFrame || 
window.msRequestAnimationFrame || 
function (callback) {
window.setTimeout(callback, 1000 / 60);
}
);
} (),
// 为每个指定元素生成canves
init = function () {
containers = Array.prototype.slice.call(containers);
for (var i = 0; i < containers.length; i += 1) {
canvas = document.createElement(&#39;canvas&#39;);
canvas.addEventListener(&#39;click&#39;, press, false);
containers[i].appendChild(canvas);
canvas.style.width =&#39;100%&#39;;
canvas.style.height=&#39;100%&#39;;
canvas.width = canvas.offsetWidth;
canvas.height = canvas.offsetHeight;
}
},
// 点击并且获取需要的数据,如点击坐标、元素大小、颜色
press = function (event) {
color = event.toElement.parentElement.dataset.color;
element = event.toElement;
context = element.getContext(&#39;2d&#39;);
radius = 0;
centerX = event.offsetX;
centerY = event.offsetY;
context.clearRect(0, 0, element.width, element.height);
draw();
},
// 绘制圆形,并且执行动画
draw = function () {
context.beginPath();
context.arc(centerX, centerY, radius, 0, 2 * Math.PI, false);
context.fillStyle = color;
context.fill();
radius += 2;
// 通过判断半径小于元素宽度,不断绘制 radius += 2 的圆形
if (radius < element.width) {
requestAnimFrame(draw);
}
};
init();

CSS3実装

次のステップはコードを手書きすることです...CSSを書くことに慣れているからかもしれませんが、CSS3実装の方が便利だと思います...

html code

<a class="waves ts-btn">Press me!</a>

css code

.waves{
position:relative;
cursor:pointer;
display:inline-block;
overflow:hidden;
text-align: center;
-webkit-tap-highlight-color:transparent;
z-index:1;
}
.waves .waves-animation{
position:absolute;
border-radius:50%;
width:25px;
height:25px;
opacity:0;
background:rgba(255,255,255,0.3);
transition:all 0.7s ease-out;
transition-property:transform, opacity, -webkit-transform;
-webkit-transform:scale(0);
transform:scale(0);
pointer-events:none
}
.ts-btn{
width: 200px;
height: 56px;
line-height: 56px;
background: #f57035;
color: #fff;
border-radius: 5px;
}

js code

document.addEventListener(&#39;DOMContentLoaded&#39;,function(){
var duration = 750;
// 样式string拼凑
var forStyle = function(position){
var cssStr = &#39;&#39;;
for( var key in position){
if(position.hasOwnProperty(key)) cssStr += key+&#39;:&#39;+position[key]+&#39;;&#39;;
};
return cssStr;
}
// 获取鼠标点击位置
var forRect = function(target){
var position = {
top:0,
left:0
}, ele = document.documentElement;
&#39;undefined&#39; != typeof target.getBoundingClientRect && (position = target.getBoundingClientRect());
return {
top: position.top + window.pageYOffset - ele.clientTop,
left: position.left + window.pageXOffset - ele.clientLeft
}
}
var show = function(event){
var pp = event.target,
cp = document.createElement(&#39;p&#39;);
pp.appendChild(cp);
var rectObj = forRect(pp),
_height = event.pageY - rectObj.top,
_left = event.pageX - rectObj.left,
_scale = &#39;scale(&#39; + pp.clientWidth / 100 * 10 + &#39;)&#39;;
var position = {
top: _height+&#39;px&#39;,
left: _left+&#39;px&#39;
};
cp.className = cp.className + " waves-animation",
cp.setAttribute("style", forStyle(position)),
position["-webkit-transform"] = _scale,
position["-moz-transform"] = _scale,
position["-ms-transform"] = _scale,
position["-o-transform"] = _scale,
position.transform = _scale,
position.opacity = "1",
position["-webkit-transition-duration"] = duration + "ms",
position["-moz-transition-duration"] = duration + "ms",
position["-o-transition-duration"] = duration + "ms",
position["transition-duration"] = duration + "ms",
position["-webkit-transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)",
position["-moz-transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)",
position["-o-transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)",
position["transition-timing-function"] = "cubic-bezier(0.250, 0.460, 0.450, 0.940)",
cp.setAttribute("style", forStyle(position));
var finishStyle = {
opacity: 0,
"-webkit-transition-duration": duration + "ms", // 过渡时间
"-moz-transition-duration": duration + "ms",
"-o-transition-duration": duration + "ms",
"transition-duration": duration + "ms",
"-webkit-transform" : _scale,
"-moz-transform" : _scale,
"-ms-transform" : _scale,
"-o-transform" : _scale,
top: _height + "px",
left: _left + "px",
};
setTimeout(function(){
cp.setAttribute("style", forStyle(finishStyle));
setTimeout(function(){
pp.removeChild(cp);
},duration);
},100)
}
document.querySelector(&#39;.waves&#39;).addEventListener(&#39;click&#39;,function(e){
show(e);
},!1);
},!1);
以上、中秋節おめでとうございます〜

以上がこの記事の内容になります。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。

関連する推奨事項:

効果を実現するための jQuery および CSS3 折りたたみカード ドロップダウン リスト ボックス


JS コンポーネントの使用方法についてブートストラップ ナビゲーション バー

以上がJS と Canves はクリックボタンの水の波紋効果を実現しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。