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!

藏色散人
藏色散人ke hadapan
2022-10-21 16:50:102063semak imbas

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)
    }
}

Pengurus Pemandangan (Adegan)

GenOptimizer.instance(function(o){
    let scene = MainScene.new(o)
    o.runWithScene(scene)
})

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) {
                
            },
            ...
        }
    },
    ...
])
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;)
    }
})
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)
})

Gunakan komponen

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

Ringkasan

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

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!

Kenyataan:
Artikel ini dikembalikan pada:segmentfault.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam