国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

在Node.js中將SVG圖像轉(zhuǎn)換為PNG,JPEG,TIFF,WEBP和HEIF格式的方法

2019-11-19 10:59:52
字體:
供稿:網(wǎng)友

介紹

你需要將SVG文件轉(zhuǎn)換為PNG、JPEG、TIFF、WEBP 和 HEIF 格式嗎?本文將指導(dǎo)你如何轉(zhuǎn)換為所有這些類型的格式。

我們將使用 Node.js 和Sharp npm 包來完成大部分繁重的工作。

目錄

  1. 安裝 Sharp Npm 包
  2. SVG 轉(zhuǎn) PNG
  3. SVG 轉(zhuǎn) JPEG
  4. SVG 轉(zhuǎn) TIFF
  5. SVG 轉(zhuǎn) WEBP
  6. SVG 轉(zhuǎn) HEIF

安裝Sharp Npm Package

首先你需要安裝 npm 包。你可以使用下面的 npm 或 yarn 命令安裝:

Npm

$ npm install sharp --save

Yarn

$ yarn add sharp

現(xiàn)在我們已經(jīng)準(zhǔn)備好開始編寫一些代碼并轉(zhuǎn)換圖像了!

SVG 轉(zhuǎn) PNG

對于第一個(gè)例子,我們將 SVG文 件轉(zhuǎn)換為可移植網(wǎng)絡(luò)圖形(PNG)文件格式。確保你在項(xiàng)目目錄的根目錄中有一個(gè)可用的 SVG 文件。

這是完整的代碼:

// Node.jsconst sharp = require("sharp")sharp("file.svg")  .png()  .toFile("new-file.png")  .then(function(info) {    console.log(info)  })  .catch(function(err) {    console.log(err)      })

讓我們分解代碼的每個(gè)部分:

  1. 首先,導(dǎo)入 sharp 包并將其保存在 sharp 變量中。
  2. 然后,我們用 sharp 包來讀取我們的 file.svg 文件,將其轉(zhuǎn)換為 PNG 并使用 .toFile() 函數(shù)將新的 PNG文件寫入你的目錄。
  3. sharp 方法是一個(gè) promise,我們用它來獲取文件的 info。
  4. 最后,我們用 .catch() 方法來捕獲并 console.log() 所有錯(cuò)誤。

當(dāng)你運(yùn)行代碼時(shí),應(yīng)該得到類似的輸出:

{  format: 'png',  width: 2500,  height: 527,  channels: 4,  premultiplied: false,  size: 47194}

你應(yīng)該能夠在項(xiàng)目目錄中看到新的 PNG 文件。

還可以將其他選項(xiàng)傳遞給 .png() 方法來更改輸出圖像。這些包括壓縮級別、質(zhì)量、顏色等。你可以在文檔中查看它們。

SVG 轉(zhuǎn) JPEG

現(xiàn)在,讓我們將 SVG 文件轉(zhuǎn)換為 JPEG 格式。確保項(xiàng)目目錄的根目錄中有一個(gè) SVG 文件可供使用。

這是完整的代碼:

const sharp = require("sharp")sharp("file.svg")  .png()  .toFile("new-file.jpg")  .then(function(info) {    console.log(info)  })  .catch(function(err) {    console.log(err)  })

當(dāng)運(yùn)行代碼時(shí),你應(yīng)該得到類似的輸出:

{  format: 'jpg',  width: 2500,  height: 527,  channels: 4,  premultiplied: false,  size: 47194}

你應(yīng)該在項(xiàng)目目錄中看到新的JPEG文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#png

SVG 轉(zhuǎn) TIFF

接下來,讓我們將SVG文件轉(zhuǎn)換為標(biāo)記圖像文件格式(TIFF)文件。確保你在項(xiàng)目目錄的根目錄中有一個(gè)我們可以使用的SVG文件。

這是完整的代碼:

const sharp = require("sharp")sharp("file.svg") .tiff() .toFile("new-file.tiff") .then(function(info) {  console.log(info) }) .catch(function(err) {  console.log(err) })

當(dāng)你運(yùn)行代碼時(shí),應(yīng)該得到類似的輸出:

{  format: 'tiff',  width: 2500,  height: 527,  channels: 3,  premultiplied: false,  size: 65778}

你應(yīng)該在項(xiàng)目目錄中看到新的TIFF文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#tiff

SVG到WEBP

接下來,將 SVG 文件轉(zhuǎn)換為 WEBP 文件格式。確保你在項(xiàng)目目錄的根目錄中有一個(gè)我們可以使用的SVG文件。

這是完整的代碼:

const sharp = require("sharp")sharp("file.svg") .webp() .toFile("new-file.webp") .then(function(info) {  console.log(info) }) .catch(function(err) {  console.log(err) })

輸出:

{ format: 'webp', width: 2500, height: 527, channels: 4, premultiplied: false, size: 35600}

你應(yīng)該在項(xiàng)目目錄中看到新的WEBP文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#webp

SVG到HEIF

最后一個(gè)例子,讓我們將 SVG 文件轉(zhuǎn)換為高效圖像文件(HEIF)格式。確保你在項(xiàng)目目錄的根目錄中有一個(gè)可用的SVG文件。

這是完整的代碼:

const sharp = require("sharp")sharp("file.svg") .png() .toFile("new-file.heif") .then(function(info) {  console.log(info) }) .catch(function(err) {  console.log(err) })

你還應(yīng)該在項(xiàng)目目錄中看到新的HEIF文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#png

結(jié)論

希望本文能幫助你完成編碼工作!也希望大家多多支持武林網(wǎng)。

原文:https://coderrocketfuel.com/article/convert-a-svg-image-to-png-jpeg-tiff-webp-and-heif-formats-in-node-js

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 进贤县| 津市市| 兴城市| 石景山区| 岱山县| 清水河县| 沙河市| 招远市| 高雄县| 安福县| 大英县| 新和县| 青铜峡市| 时尚| 乌鲁木齐市| 东乌珠穆沁旗| 定南县| 澎湖县| 郸城县| 滨海县| 潞西市| 新化县| 武安市| 资源县| 兴海县| 大名县| 兴安盟| 鄂托克旗| 广丰县| 凤城市| 厦门市| 辽宁省| 隆德县| 广宁县| 中卫市| 滕州市| 黄大仙区| 湖南省| 名山县| 抚松县| 灌阳县|