V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
x250881478
V2EX  ›  分享创造

Electron+vue3+element-plus 造个图片尺寸调整应用的轮子

  •  
  •   x250881478 ·
    xpf0000 · 2022-03-15 19:00:59 +08:00 · 2037 次点击
    这是一个创建于 984 天前的主题,其中的信息可能已经有所发展或是发生改变。

    工作中偶尔会遇到需要批量调整图片尺寸的需求, 一两张图片, 使用 PS 简单处理下即可, 或者也可以使用 PS 的批处理进行批量调整, 可是这样终究有点麻烦, 对于我们开发来说, 也可以选择使用各种编程语言, 写一个脚本, 直接执行就行, 可是这样还要手动输入各种参数, 输入文件 /文件夹, 输出文件 /文件夹, 调整后的宽高等参数, 那么我们何不直接一步到位, 做一个桌面应用, 点击选择文件 /文件夹, 输入框输入宽高, 点击按钮执行就行了

    本着没事造个轮子的精神, 笔者开发了这个图片尺寸调整应用, 应用界面如下:

    screen0.png

    screen1.png

    尽量做到简单直接, 拖拽或选择文件, 设定宽 /高, 输出文件夹, 使用多线程技术, 尽量做到极致的处理速度

    主要用到的技术栈:

    Electron

    可以使用 JS 编写桌面应用的框架, 本质上是封装了一个浏览器, 使用标准的前端技术栈进行页面的呈现, 然后通过内置的 IPC 通信模块, 进行后台进程和前台页面渲染进程的通信

    Electron 最大的优势在笔者看来就是使用 javascript 技术栈进行开发, 大大降低了整体的开发难度, 而且是跨平台的, 借助海量的 NPM 包和各种前端开发框架, 以及简单完善的 C/C++原生插件机制, Electron 几乎能做出任何需求的应用

    最大的缺点就是封装了一个完整的浏览器模块, 导致整体的包大小很大, 哪怕什么功能都没有的空应用, 生成的安装包大小也差不多 70M 左右了

    Vue3

    这个就不多说了, 目前前端几乎绕不开的开发框架, 拯救了多少 JQ 党, 也多少拯救了大家脆弱的头发

    element-plus

    配适 vue3 的前端组件库, 简单稳定好用, 开箱即用, 文档完善

    用的图片处理库是 sharp, 可以说是速度最快的 npm 图片处理库了, 全平台支持, 无需额外依赖

    使用也比较简单, 示例如下:

    const sharp = require('sharp');
    sharp(inputBuffer)
      .resize(320, 240)
      .toFile('output.webp', (err, info) => { ... });
    
    sharp('input.jpg')
      .rotate()
      .resize(200)
      .jpeg({ mozjpeg: true })
      .toBuffer()
      .then( data => { ... })
      .catch( err => { ... });
    

    应用已经开源到 github 和码云上, 有需要的可以自取, 有使用中的问题或者建议的, 可以加群联系笔者

    Github: https://github.com/xpf0000/ImageResize

    Gitee: https://gitee.com/X250881478/ImageResize

    7 条回复    2022-03-17 11:11:23 +08:00
    SpecterShell
        1
    SpecterShell  
       2022-03-15 22:04:13 +08:00
    Gitee 页面 403 ,GitHub 的 releases 文件名有问题。
    sigl0p
        2
    sigl0p  
       2022-03-16 08:47:09 +08:00
    ACDSEE (精简版 5Mb ) 全选,CTRL+R ,开始批量调整尺寸
    2345 看图王(去广告版,好像是 3Mb ),全选,批量处理,开始批量调整尺寸

    不能明白为什么我还需要一个差不多 100Mb 的只能用来改尺寸的轮子。
    freeup
        3
    freeup  
       2022-03-16 09:05:04 +08:00
    Windows 自带的画图也能调整很方便 支持百分比 和像素调整
    x250881478
        4
    x250881478  
    OP
       2022-03-16 11:49:51 +08:00
    有现成应用的话, 直接用就可以了, 这只是个人的一个轮子
    这个是全端的 windows mac linux 全都可以用, 最关键是这个是源码, 是提供给大家交流学习用的, 当然, 大佬可以无视了
    kunkunzhang
        5
    kunkunzhang  
       2022-03-16 16:29:51 +08:00
    有没有兴趣用 tauri 写一版。 哈哈哈
    7gugu
        6
    7gugu  
       2022-03-16 21:43:10 +08:00 via iPhone
    cooooool
    x250881478
        7
    x250881478  
    OP
       2022-03-17 11:11:23 +08:00
    @kunkunzhang 回头看下 如果能解决安装包大小的问题 整体开发难易度适中的话 可以考虑 后续应该会造很多轮子 这些确实都是问题
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2759 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 08:26 · PVG 16:26 · LAX 00:26 · JFK 03:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.