Rumah > hujung hadapan web > tutorial js > Editor ringan JS ini boleh membantu anda memproses imej dengan cepat!

Editor ringan JS ini boleh membantu anda memproses imej dengan cepat!

藏色散人
Lepaskan: 2022-10-21 16:51:11
ke hadapan
2065 orang telah melayarinya

Artikel ini memperkenalkan anda kepada editor imej ringan yang dilaksanakan dalam JS tulen. Saya harap ia akan membantu rakan yang memerlukannya.

Editor ringan JS ini boleh membantu anda memproses imej dengan cepat!

Pengenalan

Disebabkan beberapa senario kerja yang unik, mereka yang menulis artikel perlu memproses beberapa gambar setiap kali, seperti yang ditunjukkan di atas Tambah teks penerangan, atau tambah beberapa grafik

Saya baru mula menggunakan PPT untuk memproses, menyalinnya satu demi satu, melakukan beberapa teduhan sempadan, menambah beberapa grafik, dan kemudian mengeksportnya, menyalinnya ke tempat yang diperlukan , dan eksportnya Gambar yang terhasil mungkin tidak digunakan lagi dan perlu dibersihkan

Semakin banyak gambar, semakin banyak langkah yang diperlukan, yang agak menyusahkan saya alat untuk menyelesaikan masalah ini, dan saya mencarinya sama ada perisian itu terlalu berat dan profesional, atau perisian yang tidak memenuhi keperluan kumpulan [Cadangan: Tutorial video JavaScript]

<.>Ringkasan ringkas senario saya ialah: Berikut adalah satu Timbunan gambar yang semuanya memerlukan "pemprosesan ringan", sesetengahnya perlu menambah teks atau menambah anak panah, dsb.

  • The kuncinya adalah "ringan", anda tidak perlu menunggu berpuluh-puluh saat untuk membukanya, lakukan pemprosesan yang membosankan

  • Anda boleh menggunakannya tanpa memuat turun, tutup sahaja apabila anda selesai dengannya

  • Mudah, mudah digunakan, visual, tidak perlu Beberapa operasi yang kompleks boleh diselesaikan dengan klik tetikus

A editor imej ringan dilaksanakan dalam JS tulen

Jika senario di atas ialah Apa yang anda temui, dan anda ingin memproses beberapa gambar dengan cepat dan mudah, projek ini disediakan untuk anda

GenOptimizer alamat demonstrasi dalam talian: https://genoptimizer.cn/

Editor ringan JS ini boleh membantu anda memproses imej dengan cepat!

  • Menyokong operasi berbilang imej

  • Menyokong seret dan lepas imej untuk ditambahkan

  • Menyokong semua atribut Konfigurasi dinamik

  • Menyokong penyalinan satu klik hasil yang diubah suai

  • Menyokong berus, teks, segi empat tepat, bulatan, anak panah, garisan, imej Ditambah

Projek ini tidak bergantung pada mana-mana rangka kerja pihak ketiga dan dilaksanakan dalam JS tulen

Akhirnya, rangka kerja (GenOptimizer) disarikan, dengan cara yang sangat mudah dan mudah digunakan Keseluruhan projek ditulis

Berikut ialah alamat git projek. Saya baru di bahagian hadapan, jadi sila beri saya nasihat

  • Alamat Github: https://github.com /hellojuantu/image_border_optimizer

  • Alamat Gitee: https://gitee.com/sanbuqu/image_border_optimizer

Berikut ialah beberapa ringkasan teknikal rangka kerja pengenalan , ringan khas, pelan pelaksanaan khusus akan didedahkan kemudian

Ciri rangka kerja Pengoptimum

Editor ringan JS ini boleh membantu anda memproses imej dengan cepat!

  • Pengurusan acara, lukisan dan interaksi global

  • Menyokong pendaftaran komponen tersuai, pengurusan konfigurasi boleh disesuaikan

  • Berdasarkan kod berorientasikan objek, sangat abstrak

  • adalah ringkas dan mudah untuk digunakan, dan boleh membangunkan pelbagai kesan dengan cepat

  • Gunakan rangka kerja Pengoptimum

Mula

Anda pertama kali memerlukan pengurus adegan untuk mewarisi Genscene Program Pengoptimum memulakan

class MainScene extends GenScene {
    constructor(optimizer) {
        super(optimizer)
    }
}
Salin selepas log masuk

Pengurus Pemandangan (Adegan)

GenOptimizer.instance(function(o){
    let scene = MainScene.new(o)
    o.runWithScene(scene)
})
Salin selepas log masuk

Acara )

Acara halaman

Acara tetikus

...
<div class=&#39;gen-auto-button-area&#39;>
    <button class=&#39;gen-auto-button&#39; data-value=&#39;config.arg1&#39;>text</button>
</div>
...
// 注册页面 class, 全局可用
this.registerPageClass({
    "buttonArea": &#39;gen-auto-button-area&#39;,
    ...
})
// 注册全局事件       
this.registerGlobalEvents([     
    {
        eventName: "click",
        // 事件绑定的元素区域
        className: sc.pageClass.buttonArea,
        // 在 所有 configToEvents 响应之 前 触发
        after: function(bindVar, target) {
            // bindVar: 绑定的变量
            // target: 事件触发的目标
        },        
        // 在 所有 configToEvents 响应之 后 触发
        before: function(bindVar, target) {
            // bindVar: 绑定的变量
            // target: 事件触发的目标
        },
        // 事件响应
        configToEvents: {
            // 自定义绑定的变量: 事件触发后的响应
            "config.arg1": function(target) {
                
            },
            "action.arg1": function(target) {
                
            },
            ...
        }
    },
    ...
])
Salin selepas log masuk
Acara papan kekunci

this.resgisterMouse(function(event, action) { 
    // event 是鼠标点击的事件
    // action 为鼠标点击的事件名称    
    if (action == &#39;mouseleave&#39;) {
        console.log(&#39;mouseleave canvas&#39;)
    } else if (action == &#39;up&#39;) {
        console.log(&#39;up canvas&#39;)
    } else if (action == &#39;down&#39;) {
        console.log(&#39;down canvas&#39;)
    } else if (action == &#39;move&#39;) {
        console.log(&#39;move canvas&#39;)
    }
})
Salin selepas log masuk
Komponen (Komponen)

Daftar komponen
this.registerAction("Backspace", status => {
    // status 为 &#39;down&#39; 时, 表示按下, 为 &#39;up&#39; 时, 表示松开
    console.log("Backspace", status)
})
this.registerAction("s", status => {
    // status 为 &#39;down&#39; 时, 表示按下, 为 &#39;up&#39; 时, 表示松开
    console.log("s", status)
})
Salin selepas log masuk

Gunakan komponen

class MyComponent extends GenComponent {
    constructor(control) {
        super(control.scene)
        this.control = control
    }
    ...
}
this.bindComponent(&#39;attribute&#39;, MyComponent.new(this))
Salin selepas log masuk

Ringkasan

// 全局可使用组件
let data = ...
this.getComponent(&#39;attribute&#39;).buildWith(data)
Salin selepas log masuk

Artikel ini memperkenalkan pelaksanaan pengarang Editor imej drag-and-drop, kod rendah, ringan yang menyelesaikan masalah pemprosesan imej yang membosankanKadang-kadang beberapa operasi kecil mungkin menyebabkan kita berfikir tentang bagaimana kita boleh menangani perkara ini dengan lebih mudah?

Contoh ini adalah pemikiran saya, saya harap boleh memberi anda sedikit inspirasi atau inspirasi.

Atas ialah kandungan terperinci Editor ringan JS ini boleh membantu anda memproses imej dengan cepat!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:segmentfault.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan