


Tutorial zum Erstellen von Feuerwerkseffekten mit HTML5_html5-Tutorialkenntnissen
Es ist das chinesische Neujahr und alles, woran ich während des chinesischen Neujahrs denken kann, ist, ein Feuerwerk zu zünden. . . . Also habe ich Canvas verwendet, um einen Feuerwerkseffekt zu schreiben, der ebenfalls ein Feuerwerk erzeugt, aber nicht zu viele Feuerwerkskörper erzeugt. Die von einem Feuerwerk emittierten Partikel liegen zwischen 30 und 200. Wenn die Anzahl der Partikel auf der Seite einen bestimmten Wert erreicht Manchmal bleibt die Seite sehr hängen und ich habe Shenma nicht absichtlich optimiert. Lass uns später darüber reden, wenn wir Zeit haben.
Gehe direkt zur DEMO: Feuerwerk zünden
Das Prinzip ist ganz einfach. . . Schreiben Sie einfach eine Feuerwerksklasse und eine Trümmerklasse, instanziieren Sie sie und lassen Sie sie fliegen. Wenn Sie dann einen bestimmten Punkt erreichen, setzen Sie das Dead-Attribut des Feuerwerksobjekts auf true, instanziieren Sie dann eine bestimmte Anzahl von Trümmerobjekten und geben Sie „Einfach zufällig erstellen“ ein Legen Sie einen Zielpunkt fest, den die Trümmerobjekte erreichen sollen, und lassen Sie dann alle Trümmerobjekte dorthin fliegen.
【Feuerwerk】
- var Boom = function(x,r,c,boomArea,shape){ / /烟火对象
- this.booms = [];
- this.x = x;
- this.y = (canvas.height r);
- this.r = r;
- this.c = c;
- this.shape = Form || FALSCH;
- this.boomArea = boomArea;
- this.theta = 0;
- this.dead = false;
- this.ba = parseInt(getRandom(80 , 200));
- }
- Boom.prototype = {
- _paint:function(){
- ctx.save();
- ctx.beginPath();
- ctx.arc(this.x,this.y,this.r,0,2*Math.PI);
- ctx.fillStyle = this.c;
- ctx.fill();
- ctx.restore();
- },
- _move:function(){
- var dx = this.boomArea.x - this.x , dy = this.boomArea.y - this.y;
- thisthis.x = this.x dx*0.01;
- thisthis.y = this.y dy*0.01;
- if(Math.abs(dx)<=this.ba && Math.abs(dy)< =this.ba){
- if(this.shape){
- this._shapBoom();
- }
- else this._boom();
- } sonst {
- this._paint();
- }
- },
- _drawLight:function(){
- ctx.save();
- ctx.beginPath();
- ctx.arc(this.x , this.y , this.r 3*Math.random() 1 , 0 , 2*Math.PI); ctx.fill(); ctx.restore();
- },
- _boom:function(){ //普通爆炸
- var fragNum = getRandom(30 , 200);
- var style = getRandom(0,10)> =5? 1 : 2;
- var color;
- if(style===1){
- Farbe = {
- a:parseInt(getRandom(128,255)),
- b:parseInt(getRandom(128,255)),
- c:parseInt(getRandom(128,255))
- }
- }
- var fanwei = parseInt(getRandom(300, 400));
- for(var i=0;i<fragNum;i ){
- if(style===2){
- Farbe = {
- a:parseInt(getRandom(128,255)),
- b:parseInt(getRandom(128,255)),
- c:parseInt(getRandom(128,255))
- }
- }
- var a = getRandom(-Math.PI, Math.PI);
- var x = getRandom(0, fanwei) * Math.cos(a) this.x;
- var y = getRandom(0, fanwei) * Math.sin(a) this.y;
- var radius = getRandom(0 , 2)
- var frag = new Frag(this.x , this.y , radius , color , x , y );
- this.booms.push(frag);
- }
- },
- _shapBoom:function(){ //有形状的爆炸
- var das = dies;
- putValue(ocas , octx , this.shape , 5, function(dots){
- var dx = canvas.width/2-that.x;
- var dy = canvas.height/2-that.y;
- for(var i=0;i<dots.length;i ){
- var x = Punkte[i].x;
- var y = Punkte[i].y;
- var Radius = 1;
- var frag = new Frag(that.x , that.y , radius , color , x- dx , y-dy);
- that.booms.push(frag);
- }
- })
- }
- }
【碎屑】
- var Frag = Funktion(centerX , centerY , radius , color ,tx , ty) { //烟火碎屑对象
- this.tx = tx;
- this.ty = ty;
- this.x = centerX;
- this.y = centerY;
- this.dead = false;
- this.centerX = centerX;
- this.centerY = centerY;
- this.radius = radius;
- this.color = color;
- }
- Frag.prototype = {
- paint:function(){
- ctx.save();
- ctx.beginPath();
- ctx.arc(this.x , this.y , this.radius , 0 , 2*Math.PI);
- b "," this.color.c ",1)"; ctx.fill() ctx.restore();
- },
- moveTo:function(index){
- thisthis.ty = this.ty 0.3;
- var dx = this.tx - this.x , dy = this.ty - this.y;
- >0,1 ? this.tx : (this.x dx*0.1); >0,1 ? this.ty : (this.y dy*0.1); if( dx
- ===0 && Math.abs(dy)<=80){ } this.paint();
- } }
- 让碎屑产生虚影也很简单,就是每次刷新画布时,不是擦掉重绘,而是绘制透明度为0.1(如果想虚影更长,可以把这个值弄的更小)的背景颜色.然后虚影就可以做出来了.也就是: XML/HTML-Code复制内容到剪贴板
- ctx.save();
- ctx.fillStyle =
ctx.fillRect(0,0,canvas.width,canvas.height);
Lassen Sie das Feuerwerk die gewünschte Form annehmen, z. B. Schriftarten, Bilder usw. Dies ist auch sehr einfach über die Off-Screen-Leinwand und die getImageData-Methode der Leinwand möglich. Off-Screen-Canvas ist, wie der Name schon sagt, eine unsichtbare Leinwand. Sie können document.createElement("canvas") direkt in js verwenden, um ein Canvas-Dom-Objekt zu generieren Das Canvas-Objekt entspricht einem Off-Screen-Objekt. Wir können das Kontextobjekt dieser Off-Screen-Canvas abrufen und dann tun, was wir wollen, wo der Benutzer es nicht sehen kann.
Damit das Feuerwerk die gewünschte Form erhält, zeichnen Sie zunächst den Text oder das Bild auf der Leinwand außerhalb des Bildschirms, verwenden dann getImageData, um das Pixel-Array auf der Leinwand abzurufen, und durchlaufen dann das Array, um die farbigen Pixel zu erhalten. Das ist es, was wir wollen. Nachdem der Inhalt gespeichert wurde, wird er im Haupt-Canvas-Objekt angezeigt.
Ich habe in meinem vorherigen Blog über die Pixelverarbeitung von getImageData gesprochen. Wenn Sie nicht wissen, wie man sie verwendet, klicken Sie bitte hier: Lassen Sie uns über die Verwendung von Canvas sprechen, um eine Partikelisierung von Text und Bildern zu erreichen
Quellcode-Adresse: https://github.com/whxaxes/canvas-test/tree/gh-pages/src/Funny-demo/shotFire

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Dies ist eine Anleitung für verschachtelte Tabellen in HTML. Hier diskutieren wir anhand der entsprechenden Beispiele, wie man eine Tabelle innerhalb der Tabelle erstellt.

Anleitung zum Tabellenrahmen in HTML. Hier besprechen wir verschiedene Möglichkeiten zum Definieren von Tabellenrändern anhand von Beispielen für den Tabellenrand in HTML.

Anleitung zum HTML-Rand links. Hier besprechen wir einen kurzen Überblick über HTML margin-left und seine Beispiele sowie seine Code-Implementierung.

Leitfaden zum HTML-Tabellenlayout. Hier besprechen wir die Werte des HTML-Tabellenlayouts zusammen mit den Beispielen und Ausgaben im Detail.

Leitfaden zur HTML-geordneten Liste. Hier besprechen wir auch die Einführung von HTML-geordneten Listen und Typen sowie deren Beispiele

Anleitung zum Verschieben von Text in HTML. Hier besprechen wir eine Einführung, wie Marquee-Tags funktionieren, mit Syntax und Beispielen für die Implementierung.

Leitfaden für HTML-Eingabeplatzhalter. Hier besprechen wir die Beispiele für HTML-Eingabeplatzhalter zusammen mit den Codes und Ausgaben.

Anleitung zum HTML-OnClick-Button. Hier diskutieren wir deren Einführung, Funktionsweise, Beispiele und Onclick-Events in verschiedenen Veranstaltungen.
