mirror of
https://github.com/nolanlawson/blob-util.git
synced 2025-12-08 19:46:19 +00:00
more progress on ts docs
This commit is contained in:
parent
97494d3144
commit
244a5943fc
@ -115,6 +115,8 @@ So now we have two Kirbys - one with a normal URL, and the other with a blob URL
|
|||||||
API
|
API
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
<!-- begin insert API -->
|
||||||
|
|
||||||
### Overview
|
### Overview
|
||||||
|
|
||||||
* [createBlob(parts, options)](#createBlob)
|
* [createBlob(parts, options)](#createBlob)
|
||||||
@ -478,6 +480,8 @@ Convert a binary string to an <code>ArrayBuffer</code> to a binary string. Retur
|
|||||||
var myBuffer = blobUtil.binaryStringToArrayBuffer(binaryString)
|
var myBuffer = blobUtil.binaryStringToArrayBuffer(binaryString)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
<!-- end insert API -->
|
||||||
|
|
||||||
Credits
|
Credits
|
||||||
----
|
----
|
||||||
|
|
||||||
@ -501,3 +505,7 @@ Then to test in the browser using Saucelabs:
|
|||||||
Or to test locally in your browser of choice:
|
Or to test locally in your browser of choice:
|
||||||
|
|
||||||
npm run test-local
|
npm run test-local
|
||||||
|
|
||||||
|
To build the API docs and insert them in the README:
|
||||||
|
|
||||||
|
npm run doc
|
||||||
26
bin/write-docs-to-readme.js
Normal file
26
bin/write-docs-to-readme.js
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
const pify = require('pify')
|
||||||
|
const fs = require('fs')
|
||||||
|
const writeFile = pify(fs.writeFile.bind(fs))
|
||||||
|
const readFile = pify(fs.readFile.bind(fs))
|
||||||
|
const path = require('path')
|
||||||
|
|
||||||
|
async function main () {
|
||||||
|
let inputMd = await readFile(path.join(__dirname, '../docs-tmp/modules/_blob_util_.md'), 'utf8')
|
||||||
|
|
||||||
|
inputMd = inputMd.substring(inputMd.indexOf('## Index'))
|
||||||
|
inputMd = inputMd.replace(/_blob_util_\.md#/g, '#')
|
||||||
|
|
||||||
|
let outputMdFile = path.join(__dirname, '../README.md')
|
||||||
|
let outputMd = await readFile(outputMdFile, 'utf8')
|
||||||
|
|
||||||
|
outputMd = outputMd.replace(
|
||||||
|
/<!-- begin insert API -->[\s\S]+<!-- end insert API -->/,
|
||||||
|
`<!-- begin insert API -->\n\n${inputMd}\n\n<!-- end insert API -->`
|
||||||
|
)
|
||||||
|
await writeFile(outputMdFile, outputMd, 'utf8')
|
||||||
|
}
|
||||||
|
|
||||||
|
main().catch(e => {
|
||||||
|
console.error(e)
|
||||||
|
process.exit(1)
|
||||||
|
})
|
||||||
@ -22,7 +22,7 @@
|
|||||||
"url": "https://github.com/nolanlawson/blob-util/issues"
|
"url": "https://github.com/nolanlawson/blob-util/issues"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"lint": "standard test/*js && tslint src/*ts",
|
"lint": "standard test/*js bin/*js && tslint src/*ts",
|
||||||
"test": "npm run build && npm run lint && zuul --no-coverage ./test/test.js",
|
"test": "npm run build && npm run lint && zuul --no-coverage ./test/test.js",
|
||||||
"test-local": "npm run build && zuul ./test/test.js --local 9000 --no-coverage",
|
"test-local": "npm run build && zuul ./test/test.js --local 9000 --no-coverage",
|
||||||
"clean": "rimraf dist lib && mkdirp dist lib",
|
"clean": "rimraf dist lib && mkdirp dist lib",
|
||||||
@ -33,7 +33,10 @@
|
|||||||
"build-cjs": "rollup -i lib/blob-util.js -f cjs -o dist/blob-util.cjs.js",
|
"build-cjs": "rollup -i lib/blob-util.js -f cjs -o dist/blob-util.cjs.js",
|
||||||
"build-umd": "rollup -i lib/blob-util.js -f umd -n blobUtil -o dist/blob-util.js",
|
"build-umd": "rollup -i lib/blob-util.js -f umd -n blobUtil -o dist/blob-util.js",
|
||||||
"min": "uglifyjs dist/blob-util.js -mc > dist/blob-util.min.js",
|
"min": "uglifyjs dist/blob-util.js -mc > dist/blob-util.min.js",
|
||||||
"doc": "typedoc --out docs-tmp --target ES6 --theme markdown --mdHideSources src"
|
"doc": "run-s cleanup-doc gen-doc gen-readme cleanup-doc",
|
||||||
|
"gen-doc": "typedoc --out docs-tmp --target ES6 --theme markdown --mdHideSources --excludePrivate src",
|
||||||
|
"gen-readme": "node bin/write-docs-to-readme.js",
|
||||||
|
"cleanup-doc": "rimraf docs-tmp"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"bundle-collapser": "^1.1.4",
|
"bundle-collapser": "^1.1.4",
|
||||||
@ -45,6 +48,7 @@
|
|||||||
"mocha": "~1.18",
|
"mocha": "~1.18",
|
||||||
"native-or-lie": "1.0.2",
|
"native-or-lie": "1.0.2",
|
||||||
"npm-run-all": "^4.1.3",
|
"npm-run-all": "^4.1.3",
|
||||||
|
"pify": "^3.0.0",
|
||||||
"request": "^2.36.0",
|
"request": "^2.36.0",
|
||||||
"rimraf": "^2.6.2",
|
"rimraf": "^2.6.2",
|
||||||
"rollup": "^0.59.1",
|
"rollup": "^0.59.1",
|
||||||
|
|||||||
234
src/blob-util.ts
234
src/blob-util.ts
@ -3,12 +3,18 @@
|
|||||||
/* exported createObjectURL, revokeObjectURL, binaryStringToBlob, blobToDataURL,
|
/* exported createObjectURL, revokeObjectURL, binaryStringToBlob, blobToDataURL,
|
||||||
imgSrcToDataURL, imgSrcToBlob, arrayBufferToBlob, blobToArrayBuffer */
|
imgSrcToDataURL, imgSrcToBlob, arrayBufferToBlob, blobToArrayBuffer */
|
||||||
|
|
||||||
|
/** @private */
|
||||||
declare var BlobBuilder: any
|
declare var BlobBuilder: any
|
||||||
|
/** @private */
|
||||||
declare var MozBlobBuilder: any
|
declare var MozBlobBuilder: any
|
||||||
|
/** @private */
|
||||||
declare var MSBlobBuilder: any
|
declare var MSBlobBuilder: any
|
||||||
|
/** @private */
|
||||||
declare var WebKitBlobBuilder: any
|
declare var WebKitBlobBuilder: any
|
||||||
|
/** @private */
|
||||||
declare var webkitURL: any
|
declare var webkitURL: any
|
||||||
|
|
||||||
|
/** @private */
|
||||||
function loadImage (src, crossOrigin) {
|
function loadImage (src, crossOrigin) {
|
||||||
return new Promise(function (resolve, reject) {
|
return new Promise(function (resolve, reject) {
|
||||||
var img = new Image()
|
var img = new Image()
|
||||||
@ -23,6 +29,7 @@ function loadImage (src, crossOrigin) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** @private */
|
||||||
function imgToCanvas (img) {
|
function imgToCanvas (img) {
|
||||||
var canvas = document.createElement('canvas')
|
var canvas = document.createElement('canvas')
|
||||||
|
|
||||||
@ -41,44 +48,18 @@ function imgToCanvas (img) {
|
|||||||
return canvas
|
return canvas
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert a binary string to an <code>ArrayBuffer</code>.
|
|
||||||
* @param binary - binary string
|
|
||||||
* @returns array buffer
|
|
||||||
*/
|
|
||||||
export function binaryStringToArrayBuffer (binary: string): ArrayBuffer {
|
|
||||||
var length = binary.length
|
|
||||||
var buf = new ArrayBuffer(length)
|
|
||||||
var arr = new Uint8Array(buf)
|
|
||||||
var i = -1
|
|
||||||
while (++i < length) {
|
|
||||||
arr[i] = binary.charCodeAt(i)
|
|
||||||
}
|
|
||||||
return buf
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert an <code>ArrayBuffer</code> to a binary string.
|
|
||||||
* @param buffer - array buffer
|
|
||||||
* @returns binary string
|
|
||||||
*/
|
|
||||||
export function arrayBufferToBinaryString (buffer: ArrayBuffer): string {
|
|
||||||
var binary = ''
|
|
||||||
var bytes = new Uint8Array(buffer)
|
|
||||||
var length = bytes.byteLength
|
|
||||||
var i = -1
|
|
||||||
while (++i < length) {
|
|
||||||
binary += String.fromCharCode(bytes[i])
|
|
||||||
}
|
|
||||||
return binary
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shim for
|
* Shim for
|
||||||
* {@link https://developer.mozilla.org/en-US/docs/Web/API/Blob.Blob | <code>new Blob()</code>}
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/Blob.Blob | <code>new Blob()</code>}
|
||||||
* to support
|
* to support
|
||||||
* {@link http://caniuse.com/blob | older browsers that use the deprecated <code>BlobBuilder</code> API}.
|
* {@link http://caniuse.com/blob | older browsers that use the deprecated <code>BlobBuilder</code> API}.
|
||||||
*
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var myBlob = blobUtil.createBlob(['hello world'], {type: 'text/plain'});
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param parts - content of the <code>Blob</code>
|
* @param parts - content of the <code>Blob</code>
|
||||||
* @param properties - usually <code>{type: myContentType}</code>,
|
* @param properties - usually <code>{type: myContentType}</code>,
|
||||||
* you can also pass a string for the content type
|
* you can also pass a string for the content type
|
||||||
@ -113,6 +94,13 @@ export function createBlob (parts: Array<any>, properties?: BlobPropertyBag | st
|
|||||||
* {@link https://developer.mozilla.org/en-US/docs/Web/API/URL.createObjectURL | <code>URL.createObjectURL()</code>}
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/URL.createObjectURL | <code>URL.createObjectURL()</code>}
|
||||||
* to support browsers that only have the prefixed
|
* to support browsers that only have the prefixed
|
||||||
* <code>webkitURL</code> (e.g. Android <4.4).
|
* <code>webkitURL</code> (e.g. Android <4.4).
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var myUrl = blobUtil.createObjectURL(blob);
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param blob
|
* @param blob
|
||||||
* @returns url
|
* @returns url
|
||||||
*/
|
*/
|
||||||
@ -125,6 +113,13 @@ export function createObjectURL (blob: Blob): string {
|
|||||||
* {@link https://developer.mozilla.org/en-US/docs/Web/API/URL.revokeObjectURL | <code>URL.revokeObjectURL()</code>}
|
* {@link https://developer.mozilla.org/en-US/docs/Web/API/URL.revokeObjectURL | <code>URL.revokeObjectURL()</code>}
|
||||||
* to support browsers that only have the prefixed
|
* to support browsers that only have the prefixed
|
||||||
* <code>webkitURL</code> (e.g. Android <4.4).
|
* <code>webkitURL</code> (e.g. Android <4.4).
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.revokeObjectURL(myUrl);
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param url
|
* @param url
|
||||||
*/
|
*/
|
||||||
export function revokeObjectURL (url: string): void {
|
export function revokeObjectURL (url: string): void {
|
||||||
@ -134,6 +129,16 @@ export function revokeObjectURL (url: string): void {
|
|||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to a binary string.
|
* Convert a <code>Blob</code> to a binary string.
|
||||||
*
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.blobToBinaryString(blob).then(function (binaryString) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param blob
|
* @param blob
|
||||||
* @returns Promise that resolves with the binary string
|
* @returns Promise that resolves with the binary string
|
||||||
*/
|
*/
|
||||||
@ -159,6 +164,12 @@ export function blobToBinaryString (blob: Blob): Promise<string> {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a base64-encoded string to a <code>Blob</code>.
|
* Convert a base64-encoded string to a <code>Blob</code>.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var blob = blobUtil.base64StringToBlob(base64String);
|
||||||
|
* ```
|
||||||
* @param base64 - base64-encoded string
|
* @param base64 - base64-encoded string
|
||||||
* @param type - the content type (optional)
|
* @param type - the content type (optional)
|
||||||
* @returns Blob
|
* @returns Blob
|
||||||
@ -170,6 +181,13 @@ export function base64StringToBlob (base64: string, type?: string): Blob {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a binary string to a <code>Blob</code>.
|
* Convert a binary string to a <code>Blob</code>.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var blob = blobUtil.binaryStringToBlob(binaryString);
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param binary - binary string
|
* @param binary - binary string
|
||||||
* @param type - the content type (optional)
|
* @param type - the content type (optional)
|
||||||
* @returns Blob
|
* @returns Blob
|
||||||
@ -180,6 +198,17 @@ export function binaryStringToBlob (binary: string, type?: string): Blob {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to a binary string.
|
* Convert a <code>Blob</code> to a binary string.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.blobToBase64String(blob).then(function (base64String) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param blob
|
* @param blob
|
||||||
* @returns Promise that resolves with the binary string
|
* @returns Promise that resolves with the binary string
|
||||||
*/
|
*/
|
||||||
@ -191,6 +220,13 @@ export function blobToBase64String (blob: Blob): Promise<string> {
|
|||||||
* Convert a data URL string
|
* Convert a data URL string
|
||||||
* (e.g. <code>'...'</code>)
|
* (e.g. <code>'...'</code>)
|
||||||
* to a <code>Blob</code>.
|
* to a <code>Blob</code>.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var blob = blobUtil.dataURLToBlob(dataURL);
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param dataURL - dataURL-encoded string
|
* @param dataURL - dataURL-encoded string
|
||||||
* @returns Blob
|
* @returns Blob
|
||||||
*/
|
*/
|
||||||
@ -205,6 +241,13 @@ export function dataURLToBlob (dataURL: string): Blob {
|
|||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to a data URL string
|
* Convert a <code>Blob</code> to a data URL string
|
||||||
* (e.g. <code>'...'</code>).
|
* (e.g. <code>'...'</code>).
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var dataURL = blobUtil.blobToDataURL(blob);
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param blob
|
* @param blob
|
||||||
* @returns Promise that resolves with the data URL string
|
* @returns Promise that resolves with the data URL string
|
||||||
*/
|
*/
|
||||||
@ -218,9 +261,28 @@ export function blobToDataURL (blob: Blob): Promise<string> {
|
|||||||
* Convert an image's <code>src</code> URL to a data URL by loading the image and painting
|
* Convert an image's <code>src</code> URL to a data URL by loading the image and painting
|
||||||
* it to a <code>canvas</code>.
|
* it to a <code>canvas</code>.
|
||||||
*
|
*
|
||||||
* <p/>Note: this will coerce the image to the desired content type, and it
|
* Note: this will coerce the image to the desired content type, and it
|
||||||
* will only paint the first frame of an animated GIF.
|
* will only paint the first frame of an animated GIF.
|
||||||
*
|
*
|
||||||
|
* Examples:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.imgSrcToDataURL('http://mysite.com/img.png').then(function (dataURL) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.imgSrcToDataURL('http://some-other-site.com/img.jpg', 'image/jpeg',
|
||||||
|
* 'Anonymous', 1.0).then(function (dataURL) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param src - image src
|
* @param src - image src
|
||||||
* @param type - the content type (optional, defaults to 'image/png')
|
* @param type - the content type (optional, defaults to 'image/png')
|
||||||
* @param crossOrigin - for CORS-enabled images, set this to
|
* @param crossOrigin - for CORS-enabled images, set this to
|
||||||
@ -239,7 +301,29 @@ export function imgSrcToDataURL (src: string, type?: string, crossOrigin?: strin
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>canvas</code> to a <code>Blob</code>.
|
* Convert a <code>canvas</code> to a <code>Blob</code>.
|
||||||
* @param canvas
|
*
|
||||||
|
* Examples:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.canvasToBlob(canvas).then(function (blob) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Most browsers support converting a canvas to both `'image/png'` and `'image/jpeg'`. You may
|
||||||
|
* also want to try `'image/webp'`, which will work in some browsers like Chrome (and in other browsers, will just fall back to `'image/png'`):
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.canvasToBlob(canvas, 'image/webp').then(function (blob) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* @param canvas - HTMLCanvasElement
|
||||||
* @param type - the content type (optional, defaults to 'image/png')
|
* @param type - the content type (optional, defaults to 'image/png')
|
||||||
* @param quality - a number between 0 and 1 indicating image quality
|
* @param quality - a number between 0 and 1 indicating image quality
|
||||||
* if the requested type is 'image/jpeg' or 'image/webp'
|
* if the requested type is 'image/jpeg' or 'image/webp'
|
||||||
@ -258,9 +342,28 @@ export function canvasToBlob (canvas: HTMLCanvasElement, type?: string, quality?
|
|||||||
* Convert an image's <code>src</code> URL to a <code>Blob</code> by loading the image and painting
|
* Convert an image's <code>src</code> URL to a <code>Blob</code> by loading the image and painting
|
||||||
* it to a <code>canvas</code>.
|
* it to a <code>canvas</code>.
|
||||||
*
|
*
|
||||||
* <p/>Note: this will coerce the image to the desired content type, and it
|
* Note: this will coerce the image to the desired content type, and it
|
||||||
* will only paint the first frame of an animated GIF.
|
* will only paint the first frame of an animated GIF.
|
||||||
*
|
*
|
||||||
|
* Examples:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.imgSrcToBlob('http://mysite.com/img.png').then(function (blob) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.imgSrcToBlob('http://some-other-site.com/img.jpg', 'image/jpeg',
|
||||||
|
* 'Anonymous', 1.0).then(function (blob) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param src - image src
|
* @param src - image src
|
||||||
* @param type - the content type (optional, defaults to 'image/png')
|
* @param type - the content type (optional, defaults to 'image/png')
|
||||||
* @param crossOrigin - for CORS-enabled images, set this to
|
* @param crossOrigin - for CORS-enabled images, set this to
|
||||||
@ -280,6 +383,12 @@ export function imgSrcToBlob (src: string, type?: string, crossOrigin?: string,
|
|||||||
/**
|
/**
|
||||||
* Convert an <code>ArrayBuffer</code> to a <code>Blob</code>.
|
* Convert an <code>ArrayBuffer</code> to a <code>Blob</code>.
|
||||||
*
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var blob = blobUtil.arrayBufferToBlob(arrayBuff, 'audio/mpeg');
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param buffer
|
* @param buffer
|
||||||
* @param type - the content type (optional)
|
* @param type - the content type (optional)
|
||||||
* @returns Blob
|
* @returns Blob
|
||||||
@ -290,6 +399,17 @@ export function arrayBufferToBlob (buffer: ArrayBuffer, type?: string): Blob {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Convert a <code>Blob</code> to an <code>ArrayBuffer</code>.
|
* Convert a <code>Blob</code> to an <code>ArrayBuffer</code>.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* blobUtil.blobToArrayBuffer(blob).then(function (arrayBuff) {
|
||||||
|
* // success
|
||||||
|
* }).catch(function (err) {
|
||||||
|
* // error
|
||||||
|
* });
|
||||||
|
* ```
|
||||||
|
*
|
||||||
* @param blob
|
* @param blob
|
||||||
* @returns Promise that resolves with the <code>ArrayBuffer</code>
|
* @returns Promise that resolves with the <code>ArrayBuffer</code>
|
||||||
*/
|
*/
|
||||||
@ -304,3 +424,47 @@ export function blobToArrayBuffer (blob: Blob): Promise<ArrayBuffer> {
|
|||||||
reader.readAsArrayBuffer(blob)
|
reader.readAsArrayBuffer(blob)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert an <code>ArrayBuffer</code> to a binary string.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var myString = blobUtil.arrayBufferToBinaryString(arrayBuff)
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* @param buffer - array buffer
|
||||||
|
* @returns binary string
|
||||||
|
*/
|
||||||
|
export function arrayBufferToBinaryString (buffer: ArrayBuffer): string {
|
||||||
|
var binary = ''
|
||||||
|
var bytes = new Uint8Array(buffer)
|
||||||
|
var length = bytes.byteLength
|
||||||
|
var i = -1
|
||||||
|
while (++i < length) {
|
||||||
|
binary += String.fromCharCode(bytes[i])
|
||||||
|
}
|
||||||
|
return binary
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert a binary string to an <code>ArrayBuffer</code>.
|
||||||
|
*
|
||||||
|
* ```js
|
||||||
|
* var myBuffer = blobUtil.binaryStringToArrayBuffer(binaryString)
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* @param binary - binary string
|
||||||
|
* @returns array buffer
|
||||||
|
*/
|
||||||
|
export function binaryStringToArrayBuffer (binary: string): ArrayBuffer {
|
||||||
|
var length = binary.length
|
||||||
|
var buf = new ArrayBuffer(length)
|
||||||
|
var arr = new Uint8Array(buf)
|
||||||
|
var i = -1
|
||||||
|
while (++i < length) {
|
||||||
|
arr[i] = binary.charCodeAt(i)
|
||||||
|
}
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user