Heim > Web-Frontend > js-Tutorial > Hauptteil

JS und Canves realisieren den Wasserwelleneffekt beim Klicken auf die Schaltfläche

不言
Freigeben: 2018-06-25 15:38:58
Original
2615 Leute haben es durchsucht

In diesem Artikel erfahren Sie, wie sich das Klicken auf eine Schaltfläche auf der Basis von js und Canvas auswirkt. Der Effekt ist sehr realistisch. Freunde, die sich dafür interessieren, sollten einen Blick darauf werfen.

Kürzlich habe ich etwas Gutes gesehen Klicken Sie auf den Button-Klick-Effekt. Es erzeugt jedes Mal einen Wasserwelleneffekt, der ziemlich viel Spaß macht, also habe ich ihn einfach implementiert (ohne die Kompatibilitätsprobleme mit Browsern niedrigerer Versionen zu berücksichtigen)

Schauen wir uns zuerst den Effekt an , wie unten gezeigt (die GIF-Aufzeichnungssoftware ist etwas schäbig, sie sieht aus wie Kaka ...)

Dieser Effekt kann durch Verschachteln von Leinwänden innerhalb des Elements oder durch css3.

Canves-Implementierung

Ich habe einen Code für die Canvas-Implementierung aus dem Internet geholt, einige wiederholt definierte Stile leicht entfernt und js-Kommentare hinzugefügt. Der Code lautet wie folgt

HTML-Code

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

CSS-Code

* {
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;
}
Nach dem Login kopieren

js-Code

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();
Nach dem Login kopieren

CSS3-Implementierung

Der nächste Schritt besteht darin, den Code von Hand einzugeben... Ich denke, die CSS3-Implementierung ist bequemer, vielleicht weil ich es gewohnt bin, CSS zu schreiben...

HTML-Code

<a class="waves ts-btn">Press me!</a>
Nach dem Login kopieren

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;
}
Nach dem Login kopieren

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);
Nach dem Login kopieren

Okay, das ist alles Übrigens: Frohes Mittherbstfest ~

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website !

Verwandte Empfehlungen:

JQuery- und CSS3-Klappkarten-Dropdown-Listenfeld, um den Effekt zu erzielen

Über JS Komponente Bootstrap-Navigationsleiste Verwendung von

Das obige ist der detaillierte Inhalt vonJS und Canves realisieren den Wasserwelleneffekt beim Klicken auf die Schaltfläche. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage