Heim Web-Frontend H5-Tutorial Techniken zur Leistungsverbesserung von HTML5 Canvas und Techniken zum Erfahrungsaustausch_html5-Tutorial

Techniken zur Leistungsverbesserung von HTML5 Canvas und Techniken zum Erfahrungsaustausch_html5-Tutorial

May 16, 2016 pm 03:49 PM
canvas html5

Verwenden Sie Caching-Technologie, um Vorzeichnungen zu implementieren, um das wiederholte Zeichnen von Canvs-Inhalten zu reduzieren.
Wenn wir auf Canvas zeichnen und aktualisieren, behalten wir oft immer einige unveränderte Inhalte bei, für die Inhalte
vorab erstellt werden sollten -gezeichnetes Caching statt jedes Mal aktualisieren.
Der Direktzeichnungscode lautet wie folgt:

Kopieren Sie den Code
Der Code lautet wie folgt:

context .font="24px Arial";
context.fillStyle="blue";
context.fillText("Bitte drücken Sie , um das Spiel zu verlassen",5,50);
requestAnimationFrame(render) ;

Cache-Pre-Drawing-Technologie verwenden:

Kopieren Sie den Code
Der Code lautet wie folgt:

function render(context) {
context.drawImage(mText_canvas, 0, 0);
requestAnimationFrame(render); }
function drawText(context) {
mText_canvas = document.createElement("canvas");
mText_canvas.height = 54;
var m_context = mText_canvas. getContext("2d");
m_context.font="24px Arial";
m_context.fillText("Bitte drücken Sie , um das Spiel zu verlassen",5 ,50);
}


Beachten Sie bei der Verwendung der Canvas-Cache-Zeichnungstechnologie unbedingt, dass die Größe des zwischengespeicherten Canvas-Objekts kleiner sein sollte als die tatsächliche Canvas-Größe. Versuchen Sie, die Vorgänge zum Zeichnen gerader Punkte zusammenzufassen und die Zeichnung auf einmal abzuschließen. Ein schlechter Code lautet wie folgt:



Code kopieren
Der Code lautet wie folgt:
für (var i = 0; i < Punkte.Länge - 1; i ) {
var p1 = Punkte[i ];
var p2 = points[i 1];
context.moveTo(p1.x, p1.y); p2.y);
context.Stroke();
}



Der geänderte Code mit höherer Leistung lautet wie folgt:



Code kopieren
Der Code lautet wie folgt: context.beginPath(); for (var i = 0; i < punkte.länge - 1 ; i ) {
var p1 = punkte[i]; .y);
context.lineTo( p2.x, p2.y);
context.Stroke();


Vermeiden Sie unnötiges häufiges Wechseln des Canvas-Zeichnungsstatus . Ein Beispiel für einen häufigen Wechsel des Zeichenstils ist wie folgt:





Code kopieren


Der Code lautet wie folgt:
var GAP = 10; for (var i=0; i<10; i ) { context.fillStyle = (i % 2 ? "blue" : "red"); context.fillRect(0, i * GAP, 400, GAP ; 🎜>
Der Code lautet wie folgt:

// even
context.fillStyle = "red";
for (var i = 0; i < 5; i ) {
context.fillRect(0, (i*2) * GAP, 400, GAP); >// odd
context.fillStyle = "blue";
for ( var i = 0; i < 5; i ) {
context.fillRect(0, (i*2 1) * GAP , 400, GAP);
}

zeichnen Beim Zeichnen wird nur der Bereich gezeichnet, der aktualisiert werden muss, und unnötiges wiederholtes Zeichnen und zusätzlicher Aufwand müssen jederzeit vermieden werden. Für das Rendern komplexer Szenen wird die Layer-Rendering-Technologie verwendet und Vordergrund und Hintergrund werden separat gezeichnet. Das
HTML, das die Canvas-Ebene definiert, lautet wie folgt:
Kopieren Sie den Code


Der Code lautet wie folgt:



">



Wenn es nicht notwendig ist, vermeiden Sie die Verwendung spezieller Zeichnungseffekte wie Schatten, Unschärfe usw.

Vermeiden Sie die Verwendung von Gleitkommakoordinaten
Beim Zeichnen von Grafiken sollten Länge und Koordinaten ganze Zahlen statt Gleitkommazahlen sein. Der Grund dafür ist, dass Canvas das Zeichnen mit halben Pixeln unterstützt und implementiert Der Interpolationsalgorithmus basiert auf Dezimalstellen. Um den Anti-Aliasing-Effekt gezeichneter Bilder zu erzielen, wählen Sie bitte keine Gleitkommawerte aus, es sei denn, dies ist erforderlich.

Zeichnungsinhalt auf Canvas löschen:
context.clearRect(0, 0, canvas.width,canvas.height)
Aber es gibt tatsächlich einen ähnlichen Hack in Canvas Die Löschmethode:
canvas.width = canvas.width;
kann auch den Effekt des Löschens des Inhalts auf der Leinwand erzielen, wird jedoch von einigen Browsern möglicherweise nicht unterstützt.
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Tabellenrahmen in HTML Tabellenrahmen in HTML Sep 04, 2024 pm 04:49 PM

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.

Verschachtelte Tabelle in HTML Verschachtelte Tabelle in HTML Sep 04, 2024 pm 04:49 PM

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.

HTML-Rand links HTML-Rand links Sep 04, 2024 pm 04:48 PM

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

HTML-Tabellenlayout HTML-Tabellenlayout Sep 04, 2024 pm 04:54 PM

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

HTML-Eingabeplatzhalter HTML-Eingabeplatzhalter Sep 04, 2024 pm 04:54 PM

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

Text in HTML verschieben Text in HTML verschieben Sep 04, 2024 pm 04:45 PM

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.

HTML-geordnete Liste HTML-geordnete Liste Sep 04, 2024 pm 04:43 PM

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

HTML-Onclick-Button HTML-Onclick-Button Sep 04, 2024 pm 04:49 PM

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

See all articles