ホームページ >ウェブフロントエンド >jsチュートリアル >JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法

JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法

WBOY
WBOYオリジナル
2016-05-16 16:26:352536ブラウズ

冬が到来し、多くのブログ スペースに雪の結晶のエフェクトが追加されたので、そのエフェクトがどのように実装されているかを見に行きました。エフェクトコードがいくつかあるので、困っている友達に譲って試してもらいました。

雪の結晶の全体像:

JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法

エフェクトコード 1

<script type="text/javascript" language="javascript">
(function() {
function k(a, b, c) {
if (a.addEventListener) a.addEventListener(b, c, false);
else a.attachEvent && a.attachEvent("on" + b, c)
}
function g(a) {
if (typeof window.onload != "function") window.onload = a;
else {
var b = window.onload;
window.onload = function() {
b();
a()
}
}
}
function h() {
var a = {};
for (type in {
Top: "",
Left: ""
}) {
var b = type == "Top" &#63; "Y": "X";
if (typeof window["page" + b + "Offset"] != "undefined")
a[type.toLowerCase()] = window["page" + b + "Offset"];
else {
b = document.documentElement.clientHeight &#63; document.documentElement: document.body;
a[type.toLowerCase()] = b["scroll" + type]
}
}
return a
}
function l() {
var a = document.body,
b;
if (window.innerHeight) b = window.innerHeight;
else if (a.parentElement.clientHeight) b = a.parentElement.clientHeight;
else if (a && a.clientHeight) b = a.clientHeight;
return b
}
function i(a) {
this.parent = document.body;
this.createEl(this.parent, a);
this.size = Math.random() * 5 + 5;
this.el.style.width = Math.round(this.size) + "px";
this.el.style.height = Math.round(this.size) + "px";
this.maxLeft = document.body.offsetWidth - this.size;
this.maxTop = document.body.offsetHeight - this.size;
this.left = Math.random() * this.maxLeft;
this.top = h().top + 1;
this.angle = 1.4 + 0.2 * Math.random();
this.minAngle = 1.4;
this.maxAngle = 1.6;
this.angleDelta = 0.01 * Math.random();
this.speed = 2 + Math.random()
}
var j = false;
g(function() {
j = true
});
var f = true;
window.createSnow = function(a, b) {
if (j) {
var c = [],
m = setInterval(function() {
f && b > c.length && Math.random()
< b * 0.0025 && c.push(new i(a)); ! f && !c.length && clearInterval(m);
for (var e = h().top, n = l(), d = c.length - 1; d >= 0; d--)
if (c[d]) if (c[d].top < e || c[d].top + c[d].size + 1 > e + n) {
c[d].remove();
c[d] = null;
c.splice(d, 1)
} else {
c[d].move();
c[d].draw()
}
},
40);
k(window, "scroll",
function() {
for (var e = c.length - 1; e >= 0; e--) c[e].draw()
})
} else g(function() {
createSnow(a, b)
})
};
window.removeSnow = function() {
f = false
};
i.prototype = {
createEl: function(a, b) {
this.el = document.createElement("img");
this.el.setAttribute
("src", b + "雪花图片的绝对链接地址");
this.el.style.position = "absolute";
this.el.style.display = "block";
this.el.style.zIndex = "99999";
this.parent.appendChild(this.el)
},
move: function() {
if (this.angle < this.minAngle || this.angle > this.maxAngle)
this.angleDelta = -this.angleDelta;
this.angle += this.angleDelta;
this.left += this.speed * Math.cos(this.angle * Math.PI);
this.top -= this.speed * Math.sin(this.angle * Math.PI);
if (this.left < 0) this.left = this.maxLeft;
else if (this.left > this.maxLeft) this.left = 0
},
draw: function() {
this.el.style.top = Math.round(this.top) + "px";
this.el.style.left = Math.round(this.left) + "px"
},
remove: function() {
this.parent.removeChild(this.el);
this.parent = this.el = null
}
}
})();
createSnow("", 40);
</script>

記事ページのみを表示したい場合は、上記のコードをテーマのヘッダーまたはフッター ファイルに直接コピーして貼り付け、single に直接追加します。 以下に、雪の結晶の写真 (必要な素材) を皆さんに提供します。 JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法 小さな写真: ブログの現在のテーマにアップロードし、コード内のリンクを写真の場所に変更する必要があります。効果はこのページにある通りです

エフェクトコード 2:

 <html>
<head>
<script>
function start(){
var array=new Array();
var canvas=document.getElementById("mycanvas");
var context=canvas.getContext("2d");
for(var i=0;i<50;i++){
var ShowJS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法=new showJS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法();
array.push(ShowJS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法);
}
time=setInterval(function (){
context.clearRect(0,0,canvas.width,canvas.height);
for(var i=0;i<array.length;i++){
array[i].move();
array[i].draw(context);
}
},500);
}
function showJS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法(){
var y=parseInt(Math.random()*50)*10;
var x=parseInt(Math.random()*80)*10;
this.draw=function(context){
context.font="50px Calibri";
context.fillText("*",x,y);
}
this.move=function(){
y+=20;
if(y>600){
y=0;
}
}
}
</script>
</head>
<body>
<input type="button" value="start" onclick="start()" />
<br/>
<canvas id="mycanvas" height="600px" width="600px" style="border: 3px solid blue"></canvas>
</body>
</html>

この効果は次のように実証されます (見た目が悪いので推奨されません):

エフェクトコード 3

実際、Let it Snow プラグインを使用して、WordPress ブログに降る雪の結晶を実装することもできます。

let it Snow プラグインの使用方法については、ここでは詳しく説明しません。他のプラグインのインストールと何ら変わりはありません。let it Snow フォルダー内のファイルを直接ダウンロードしてアップロードすることができます。 /wp-content/plugins/ ディレクトリに移動し、このプラグインを有効にするには、WordPress 管理パネルのメニューでプラ​​グインを設定するだけです。または、バック プラグイン ライブラリを直接検索して見つけることもできます。

let it Snow 公式ウェブサイト: クリックしてアクセス

エフェクトコード 4

インターネット上で非常に強力な SnowStorm プラグインを見つけました。 Google で let it Snow と検索すると、雪と霜のエフェクトのコードが生成されるようです。子供靴が良いと思ったら、公式サイトにアクセスしてチェックしてみてください。

インターネット上で単純なランダムな雪の結晶が落ちるエフェクト コードを見つけましたので、共有します (このエフェクトは純粋なコードで書かれています。雪の結晶は * です):

内部の関数のいくつかを簡単に説明しましょう:

1. letItSnow()

雪が降っています(この文はまだ役に立ちません)。次に、createSnow を呼び出して雪の結晶を生成します。

2.createSnow()

雪の結晶を生成します。各雪の結晶は タグで、雪の結晶をシミュレートするには「*」を入力します (Google のコピーはダウンロードできません。実際にはスペースとして表示されます。とても驚きました)。 )、それを大きなコンテナに入れます。JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box と呼ばれるコンテナで、生成された個体は iArray にプッシュされて収集されます。スノーフレークは、JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box に基づいた絶対配置方法を使用し、上部は 0px、左側は Math.random()*window.screen.width を使用するため、スノーフレークは画面幅でランダムに生成されます。

色を使用して雪片の色の深さを制御し、0 ~ 200 の範囲で被写界深度を作成します
fontSize を使用して雪の結晶のサイズを 10 ピクセルから 15 ピクセルの範囲で制御します
Snowflake Falling の呼び出し間隔を時間を 40 ミリ秒から 50 ミリ秒の範囲で制御します
SnowInterval を使用して、雪の結晶の間隔を 500 ミリ秒から 1000 ミリ秒の範囲で制御します

その後、再帰的に自分自身を呼び出し、雪の結晶を継続的に生成します。

3.fallDown()

名前の通り、雪の結晶を降らせるものです。落下速度は2px、つまり垂直に2pxずつ落ちます。この時点でテストを実行し、スノーフレークが一定の高さ、つまり親コンテナーよりも高い位置まで下がった場合は、それを削除します。そうしないと、スノーフレークが多すぎるとブラウザーの動作が遅くなります。とにかく、overflow:hidden によって表示から削除されました。次に、垂直に降下しながら WindBlow 関数を呼び出して、雪の結晶をより芸術的に降らせます。

4.windBlow()

風が吹いているような名前ですが、実際は風が吹いているエフェクトであり(これはさらに無駄です。笑)、 Math.sin() を使用して空中に浮かぶ雪の結晶のエフェクトを生成し、雪の結晶が単調な直線にならずに、蛇行状に落ちるように、連続性が良くなり、より快適に見えるようにします。

function letItSnow(){
	var JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box=document.getElementById("JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box");
	var iArray=new Array();
	createSnow(JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box,iArray);

}
function fallDown(temObj,iArray){
	var speed=2;
	var top=parseInt(temObj.style.top);
	if(top>510){//当到超过高度时候就删了它,减轻浏览器压力
		for(var i=0;i<iArray.length;i++){
			if(temObj==iArray[i]){
				iArray.splice(i,1);
				var JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box=document.getElementById("JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box");
				JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box.removeChild(temObj);
				return false;
			}
		}
	}
	temObj.style.top=top+speed+"px";
	var wind=windBlow(temObj,top);
	temObj.style.left=parseInt(temObj.style.left)+wind*2+"px";
}
function windBlow(temObj,top){
	if(parseInt(Math.random())%2==1)
	return Math.sin(top/16);
	else return Math.cos(top/16);
}
function createSnow(JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box,iArray){
	var temObj=document.createElement("i");
	var temText=document.createTextNode("*");
	temObj.appendChild(temText);
	temObj.style.left=parseInt(Math.random()*window.screen.width)+"px";
	temObj.style.top="0px";
	var temNum=parseInt(Math.random()*200);
	temObj.style.color="#"+temNum.toString(16)+temNum.toString(16)+temNum.toString(16);
	iArray.push(temObj);
	JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box.appendChild(temObj);
	var temNum=0;
	while(temNum<10){
		temNum=parseInt(Math.random()*15);
	}
	temObj.style.fontSize=temNum+"px";

	var time=0;
	while(time<40){
		time=parseInt(Math.random()*50);
	}
	temObj.timer=setInterval(function(){
		fallDown(temObj,iArray);								
	},time);
	var JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Interval=0;
	while(JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Interval<500){
		JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Interval=parseInt(Math.random()*1000);
	}
	var createTimer=setTimeout(function(){
		createSnow(JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Box,iArray);	
		clearTimeout(createTimer);
	},JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法Interval);
}

デモのアドレス: http://demo.jb51.net/js/2014/JS コードとプラグインを使用して wordpress_javascript スキルで雪の結晶の降る効果を実現する 4 つの方法/

さて、これで 4 つのエフェクト コードは終わりです。困っている友達を助けることができれば幸いです。ご質問がございましたら、以下にメッセージを残してください。

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