261 lines
7.2 KiB
JavaScript
261 lines
7.2 KiB
JavaScript
/**
|
||
* 以下方法出自 image-tools
|
||
* @see https://ext.dcloud.net.cn/plugin?id=123
|
||
*/
|
||
|
||
function getLocalFilePath(path) {
|
||
if (path.indexOf('_www') === 0 || path.indexOf('_doc') === 0 || path.indexOf('_documents') === 0 || path.indexOf(
|
||
'_downloads') === 0) {
|
||
return path
|
||
}
|
||
if (path.indexOf('file://') === 0) {
|
||
return path
|
||
}
|
||
if (path.indexOf('/storage/emulated/0/') === 0) {
|
||
return path
|
||
}
|
||
if (path.indexOf('/') === 0) {
|
||
let localFilePath = plus.io.convertAbsoluteFileSystem(path)
|
||
if (localFilePath !== path) {
|
||
return localFilePath
|
||
} else {
|
||
path = path.substr(1)
|
||
}
|
||
}
|
||
return '_www/' + path
|
||
}
|
||
|
||
function dataUrlToBase64(str) {
|
||
let array = str.split(',')
|
||
return array[array.length - 1]
|
||
}
|
||
|
||
let index = 0
|
||
|
||
function getNewFileId() {
|
||
return Date.now() + String(index++)
|
||
}
|
||
|
||
function biggerThan(v1, v2) {
|
||
let v1Array = v1.split('.')
|
||
let v2Array = v2.split('.')
|
||
let update = false
|
||
for (let index = 0; index < v2Array.length; index++) {
|
||
let diff = v1Array[index] - v2Array[index]
|
||
if (diff !== 0) {
|
||
update = diff > 0
|
||
break
|
||
}
|
||
}
|
||
return update
|
||
}
|
||
|
||
export function pathToBase64(path) {
|
||
return new Promise(function(resolve, reject) {
|
||
if (typeof window === 'object' && 'document' in window) {
|
||
if (typeof FileReader === 'function') {
|
||
let xhr = new XMLHttpRequest()
|
||
xhr.open('GET', path, true)
|
||
xhr.responseType = 'blob'
|
||
xhr.onload = function() {
|
||
if (this.status === 200) {
|
||
let fileReader = new FileReader()
|
||
fileReader.onload = function(e) {
|
||
resolve(e.target.result)
|
||
}
|
||
fileReader.onerror = reject
|
||
fileReader.readAsDataURL(this.response)
|
||
}
|
||
}
|
||
xhr.onerror = reject
|
||
xhr.send()
|
||
return
|
||
}
|
||
let canvas = document.createElement('canvas')
|
||
let c2x = canvas.getContext('2d')
|
||
let img = new Image
|
||
img.onload = function() {
|
||
canvas.width = img.width
|
||
canvas.height = img.height
|
||
c2x.drawImage(img, 0, 0)
|
||
resolve(canvas.toDataURL())
|
||
canvas.height = canvas.width = 0
|
||
}
|
||
img.onerror = reject
|
||
img.src = path
|
||
return
|
||
}
|
||
if (typeof plus === 'object') {
|
||
plus.io.resolveLocalFileSystemURL(getLocalFilePath(path), function(entry) {
|
||
entry.file(function(file) {
|
||
let fileReader = new plus.io.FileReader()
|
||
fileReader.onload = function(data) {
|
||
resolve(data.target.result)
|
||
}
|
||
fileReader.onerror = function(error) {
|
||
reject(error)
|
||
}
|
||
fileReader.readAsDataURL(file)
|
||
}, function(error) {
|
||
reject(error)
|
||
})
|
||
}, function(error) {
|
||
reject(error)
|
||
})
|
||
return
|
||
}
|
||
if (typeof wx === 'object' && wx.canIUse('getFileSystemManager')) {
|
||
wx.getFileSystemManager().readFile({
|
||
filePath: path,
|
||
encoding: 'base64',
|
||
success: function(res) {
|
||
resolve('data:image/png;base64,' + res.data)
|
||
},
|
||
fail: function(error) {
|
||
reject(error)
|
||
}
|
||
})
|
||
return
|
||
}
|
||
reject(new Error('not support'))
|
||
})
|
||
}
|
||
|
||
export function base64ToPath(base64) {
|
||
return new Promise(function(resolve, reject) {
|
||
if (typeof window === 'object' && 'document' in window) {
|
||
base64 = base64.split(',')
|
||
let type = base64[0].match(/:(.*?);/)[1]
|
||
let str = atob(base64[1])
|
||
let n = str.length
|
||
let array = new Uint8Array(n)
|
||
while (n--) {
|
||
array[n] = str.charCodeAt(n)
|
||
}
|
||
return resolve((window.URL || window.webkitURL).createObjectURL(new Blob([array], {
|
||
type: type
|
||
})))
|
||
}
|
||
let extName = base64.split(',')[0].match(/data\:\S+\/(\S+);/)
|
||
if (extName) {
|
||
extName = extName[1]
|
||
} else {
|
||
reject(new Error('base64 error'))
|
||
}
|
||
let fileName = getNewFileId() + '.' + extName
|
||
if (typeof plus === 'object') {
|
||
let basePath = '_doc'
|
||
let dirPath = 'uniapp_temp'
|
||
let filePath = basePath + '/' + dirPath + '/' + fileName
|
||
if (!biggerThan(plus.os.name === 'Android' ? '1.9.9.80627' : '1.9.9.80472', plus.runtime.innerVersion)) {
|
||
plus.io.resolveLocalFileSystemURL(basePath, function(entry) {
|
||
entry.getDirectory(dirPath, {
|
||
create: true,
|
||
exclusive: false,
|
||
}, function(entry) {
|
||
entry.getFile(fileName, {
|
||
create: true,
|
||
exclusive: false,
|
||
}, function(entry) {
|
||
entry.createWriter(function(writer) {
|
||
writer.onwrite = function() {
|
||
resolve(filePath)
|
||
}
|
||
writer.onerror = reject
|
||
writer.seek(0)
|
||
writer.writeAsBinary(dataUrlToBase64(base64))
|
||
}, reject)
|
||
}, reject)
|
||
}, reject)
|
||
}, reject)
|
||
return
|
||
}
|
||
let bitmap = new plus.nativeObj.Bitmap(fileName)
|
||
bitmap.loadBase64Data(base64, function() {
|
||
bitmap.save(filePath, {}, function() {
|
||
bitmap.clear()
|
||
resolve(filePath)
|
||
}, function(error) {
|
||
bitmap.clear()
|
||
reject(error)
|
||
})
|
||
}, function(error) {
|
||
bitmap.clear()
|
||
reject(error)
|
||
})
|
||
return
|
||
}
|
||
if (typeof wx === 'object' && wx.canIUse('getFileSystemManager')) {
|
||
let filePath = wx.env.USER_DATA_PATH + '/' + fileName
|
||
wx.getFileSystemManager().writeFile({
|
||
filePath: filePath,
|
||
data: dataUrlToBase64(base64),
|
||
encoding: 'base64',
|
||
success: function() {
|
||
resolve(filePath)
|
||
},
|
||
fail: function(error) {
|
||
reject(error)
|
||
}
|
||
})
|
||
return
|
||
}
|
||
reject(new Error('not support'))
|
||
})
|
||
}
|
||
|
||
/**
|
||
* 本方法为本人自己写的,建议还是使用上述的pathToBase64方法
|
||
* @description 图片地址转换为base64格式图片
|
||
* @param {string} url 图片地址 网络地址 本地相对路径
|
||
* @param {string} type base64图片类型 默认png
|
||
*/
|
||
export function urlToBase64(url, type = 'png') {
|
||
let promises
|
||
|
||
// 网络地址 或者h5端本地相对路径 可使用request方式
|
||
promises = new Promise((resolve, reject) => {
|
||
uni.request({
|
||
url: url,
|
||
method: 'GET',
|
||
responseType: 'arraybuffer',
|
||
success: (res) => {
|
||
const base64 = `data:image/${type};base64,${uni.arrayBufferToBase64(res.data)}`
|
||
resolve(base64);
|
||
},
|
||
fail: (err) => {
|
||
reject(err);
|
||
},
|
||
})
|
||
})
|
||
|
||
// #ifdef APP
|
||
if (!url.startsWith('http')) {
|
||
// app真机本地相对路径
|
||
promises = new Promise((resolve, reject) => {
|
||
// 使用compressImage获取到安卓本地路径file:///...
|
||
uni.compressImage({
|
||
src: url,
|
||
quality: 100,
|
||
success: (res) => {
|
||
const tempUrl = res.tempFilePath
|
||
plus.io.resolveLocalFileSystemURL(tempUrl, (entry) => {
|
||
entry.file((e) => {
|
||
let fileReader = new plus.io.FileReader();
|
||
fileReader.onload = (r) => {
|
||
resolve(r.target.result)
|
||
}
|
||
fileReader.readAsDataURL(e)
|
||
})
|
||
})
|
||
},
|
||
fail: (err) => {
|
||
reject(err);
|
||
},
|
||
})
|
||
})
|
||
}
|
||
// #endif
|
||
|
||
return promises
|
||
} |