


Bagaimana untuk melaksanakan Kelas Perintah Kelas Komando di Konva.js untuk menyokong Undo dan Redo Functions?
Pelaksanaan fungsi redo undo berdasarkan mod arahan di konva.js
Artikel ini memperkenalkan cara menggunakan mod arahan untuk melaksanakan fungsi Undo (Ctrl Z) dan Redo (Ctrl Y) dalam aplikasi lukisan Konva.js. Kami merangkumi operasi grafik ke dalam objek arahan dan menguruskan operasi ini menggunakan timbunan arahan untuk mencapai kemunculan dan kemajuan dalam penyuntingan grafik.
Pertama, tentukan kelas Command
asas:
Perintah Kelas { pembina () { this.states = []; // Digunakan untuk menyimpan gambar negeri} laksanakan () { membuang ralat baru ('Kaedah melaksanakan mesti dilaksanakan'); } undo () { membuang kesilapan baru ('kaedah undo mesti dilaksanakan'); } SaveState (Negeri) { this.states.push (state); } restorestate () { kembali this.states.pop () || null; // kembali ke keadaan sebelumnya, atau batal } }
Seterusnya, buat kelas arahan tertentu, seperti arahan untuk melukis segi empat tepat:
Kelas DrawRectangLeCommand memanjangkan perintah { Pembina (peringkat, lapisan, rect) { super (); this.stage = stage; this.layer = lapisan; this.rect = rect; } laksanakan () { this.savestate (this.layer.tojson ()); // Simpan lapisan semasa keadaan this.layer.add (this.rect); this.layer.draw (); } undo () { this.rect.destroy (); const prevstate = this.restorestate (); jika (prevstate) { this.layer.destroychildren (); // Kosongkan lapisan this.layer = konva.node.create (prevstate, this.stage); // memulihkan keadaan sebelumnya ini.stage.add (this.layer); this.layer.draw (); } } }
Kemudian, laksanakan pengurus arahan:
CommandManager kelas { pembina () { this.undOstack = []; this.RedOstack = []; } executeCommand (perintah) { command.execute (); this.undOstack.push (command); this.RedOstack = []; // Setelah melaksanakan arahan baru, jelaskan timbunan semula} undo () { jika (this.undostack.length === 0) kembali; const command = this.undOstack.pop (); command.undo (); this.redOstack.push (command); } redo () { jika (this.redostack.length === 0) kembali; const command = this.redOstack.pop (); command.execute (); this.undOstack.push (command); } }
Akhirnya, gunakan dalam aplikasi Konva.js:
const stage = baru konva.stage ({ bekas: 'bekas', Lebar: Window.InnerWidth, Ketinggian: Window.InnerHeight }); const lapisan = baru konva.layer (); stage.add (lapisan); const commandManager = commandManager baru (); stage.on ('klik', (e) => { const rect = baru konva.rect ({ X: E.Evt.Layerx, y: e.evt.layery, Lebar: 50, Ketinggian: 50, Isi: 'merah', Draggable: Benar }); const command = new DrawRectangLeCommand (panggung, lapisan, rect); commandManager.ExecuteCommand (command); }); document.addeventListener ('keydown', (e) => { jika (e.ctrlkey && e.key === 'z') { commandManager.undo (); } else if (e.ctrlKey && e.key === 'y') { commandManager.redo (); } });
Kod ini melaksanakan lukisan segi empat tepat mudah dan membatalkan semula. Anda boleh melanjutkan kelas Command
untuk menyokong operasi grafik lain seperti pergerakan, skala, putaran, dan lain -lain. Ingatlah untuk menyelamatkan keadaan semasa dalam kaedah execute
setiap operasi dan memulihkan keadaan sebelumnya dalam kaedah undo
. Ini akan memastikan ciri Redo Undo anda berfungsi dengan betul.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan Kelas Perintah Kelas Komando di Konva.js untuk menyokong Undo dan Redo Functions?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Aplikasi Exchange OUYI menyokong memuat turun telefon bimbit Apple, lawati laman web rasmi, klik pilihan "Apple Mobile", dapatkan dan pasang di App Store, daftar atau log masuk untuk menjalankan perdagangan cryptocurrency.

Harga Bitcoin berkisar antara $ 20,000 hingga $ 30,000. 1. Harga Bitcoin telah berubah secara dramatik sejak tahun 2009, mencapai hampir $ 20,000 pada tahun 2017 dan hampir $ 60,000 pada tahun 2021. Harga dipengaruhi oleh faktor -faktor seperti permintaan pasaran, bekalan, dan persekitaran makroekonomi. 3. Dapatkan harga masa nyata melalui pertukaran, aplikasi mudah alih dan laman web. 4. Harga Bitcoin sangat tidak menentu, didorong oleh sentimen pasaran dan faktor luaran. 5. Ia mempunyai hubungan tertentu dengan pasaran kewangan tradisional dan dipengaruhi oleh pasaran saham global, kekuatan dolar AS, dan sebagainya. 6. Trend jangka panjang adalah yakin, tetapi risiko perlu dinilai dengan berhati-hati.

Sepuluh pertukaran cryptocurrency teratas di dunia pada tahun 2025 termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi, Bitfinex, Kucoin, Bittrex dan Poloniex, yang semuanya dikenali dengan jumlah dan keselamatan perdagangan mereka yang tinggi.

Sepuluh platform perdagangan cryptocurrency teratas di dunia termasuk Binance, OKX, Gate.io, Coinbase, Kraken, Huobi Global, Bitfinex, Bittrex, Kucoin dan Poloniex, yang semuanya menyediakan pelbagai kaedah perdagangan dan langkah -langkah keselamatan yang kuat.

Sepuluh pertukaran mata wang digital teratas seperti Binance, OKX, Gate.io telah meningkatkan sistem mereka, urus niaga yang pelbagai dan langkah -langkah keselamatan yang ketat.

Lawati laman web rasmi Binance dan semak logo HTTPS dan Green Lock untuk mengelakkan laman web phishing, dan aplikasi rasmi juga boleh diakses dengan selamat.

Memebox 2.0 mentakrifkan semula pengurusan aset crypto melalui seni bina yang inovatif dan kejayaan prestasi. 1) Ia menyelesaikan tiga titik kesakitan utama: silo aset, kerosakan pendapatan dan paradoks keselamatan dan kemudahan. 2) Melalui hab aset pintar, pengurusan risiko dinamik dan enjin peningkatan pulangan, kelajuan pemindahan rantaian, kadar hasil purata dan kelajuan tindak balas insiden keselamatan diperbaiki. 3) Menyediakan pengguna dengan visualisasi aset, automasi dasar dan integrasi tadbir urus, merealisasikan pembinaan semula nilai pengguna. 4) Melalui kerjasama ekologi dan inovasi pematuhan, keberkesanan keseluruhan platform telah dipertingkatkan. 5) Pada masa akan datang, kolam insurans kontrak pintar, ramalan integrasi pasaran dan peruntukan aset yang didorong AI akan dilancarkan untuk terus memimpin pembangunan industri.

Saat ini disenaraikan di antara sepuluh mata wang mata wang maya yang teratas: 1. Binance, 2 Okx, 3. Gate.io, 4. Perpustakaan duit syiling, 5. Siren, 6. Huobi Global Station, 7. Bybit, 8. Kucoin, 9.
