work更改为yaskpool
This commit is contained in:
parent
a486b36cee
commit
c11d61a577
|
@ -115,18 +115,18 @@ struct PngjTestCasePage {
|
||||||
if (!this.pngdecodeRun2) {
|
if (!this.pngdecodeRun2) {
|
||||||
this.pngdecodeRun2 = true;
|
this.pngdecodeRun2 = true;
|
||||||
let pngj = new Pngj();
|
let pngj = new Pngj();
|
||||||
let png_worker = new worker.ThreadWorker('entry/ets/workers/upngWorkerTestCase.ets', {
|
// let png_worker = new worker.ThreadWorker('entry/ets/workers/upngWorkerTestCase.ets', )
|
||||||
type: 'classic',
|
let obj ={
|
||||||
name: 'readPngImageAsync'
|
type: 'classic',
|
||||||
})
|
name: 'readPngImageAsync'
|
||||||
pngj.readPngImageAsync(png_worker, this.pngSource2!, {pngCallback: (sender:ArrayBuffer, value:Record<string,Object>) => {
|
}
|
||||||
|
pngj.readPngImageAsync(obj, this.pngSource2!, {pngCallback: (sender:ArrayBuffer, value:Record<string,Object>) => {
|
||||||
this.pngSource2 = sender
|
this.pngSource2 = sender
|
||||||
this.hint8 = '重新获取buffer才能测试'
|
this.hint8 = '重新获取buffer才能测试'
|
||||||
this.hint2 = 'img with=' + value.width + ' img height=' + value.height
|
this.hint2 = 'img with=' + value.width + ' img height=' + value.height
|
||||||
+ ' img depth=' + value.depth + ' img ctype=' + value.ctype
|
+ ' img depth=' + value.depth + ' img ctype=' + value.ctype
|
||||||
this.pngdecodeRun2 = false;
|
this.pngdecodeRun2 = false;
|
||||||
}})
|
}})
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
this.hint8 = '已经在执行了,请稍等'
|
this.hint8 = '已经在执行了,请稍等'
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,200 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2021 Huawei Device Co., Ltd.
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
import {UPNG} from '../../3rd_party/upng/UPNG';
|
||||||
|
import {PngCallback} from './PngCallback';
|
||||||
|
import image from '@ohos.multimedia.image';
|
||||||
|
import resourceManager from '@ohos.resourceManager';
|
||||||
|
import ArkWorker from '@ohos.worker'
|
||||||
|
import { BusinessError } from '@ohos.base'
|
||||||
|
export class Pngj {
|
||||||
|
readPngImageInfo(arraybuffer: ArrayBuffer, callback:PngCallback<ArrayBuffer, image.ImageInfo>) {
|
||||||
|
let imageSource:image.ImageSource = image.createImageSource(arraybuffer);
|
||||||
|
if (imageSource != undefined){
|
||||||
|
imageSource.getImageInfo((err:BusinessError, value:image.ImageInfo) => {
|
||||||
|
if (err) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
callback.pngCallback(arraybuffer, value);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
readPngImage(pngBuffer: ArrayBuffer, callback:PngCallback<ArrayBuffer, any>) {
|
||||||
|
var png = UPNG.decode(pngBuffer);
|
||||||
|
callback.pngCallback(pngBuffer, png)
|
||||||
|
}
|
||||||
|
|
||||||
|
writePngWithString(addInfo:string, pngBuffer: ArrayBuffer,callback:PngCallback<ArrayBuffer, any>) {
|
||||||
|
var pngDecode = UPNG.decode(pngBuffer);
|
||||||
|
var newPng = UPNG.encodeWithString(addInfo, UPNG.toRGBA8(pngDecode), pngDecode.width, pngDecode.height, 0)
|
||||||
|
callback.pngCallback(pngBuffer, newPng);
|
||||||
|
}
|
||||||
|
|
||||||
|
writePng(pngBuffer: ArrayBuffer,callback:PngCallback<ArrayBuffer, any>) {
|
||||||
|
var pngDecode = UPNG.decode(pngBuffer);
|
||||||
|
var newPng = UPNG.encode(UPNG.toRGBA8(pngDecode), pngDecode.width, pngDecode.height, 0)
|
||||||
|
callback.pngCallback(pngBuffer, newPng);
|
||||||
|
}
|
||||||
|
|
||||||
|
readPngImageAsync(type: any, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
||||||
|
// worker.onerror = function (data) {
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// worker.onmessageerror = function (e) {
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// worker.onexit = function () {
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// worker.onmessage = function(e) {
|
||||||
|
// var data = e.data;
|
||||||
|
// switch (data.type) {
|
||||||
|
// case 'readPngImageAsync':
|
||||||
|
// callback.pngCallback(data.receiver, data.data)
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break
|
||||||
|
// }
|
||||||
|
// worker.terminate();
|
||||||
|
// }
|
||||||
|
// var obj = { type: 'readPngImageAsync', data: pngBuffer }
|
||||||
|
// worker.postMessage(obj, [pngBuffer])
|
||||||
|
let task = new taskpool.Task(taskParseImage,type, arrayBuffer, callback)
|
||||||
|
// task.setTransferList([])
|
||||||
|
taskpool.execute(task).then((pixelmap: Object) => {
|
||||||
|
LogUtil.log('ceshi321 : Succeeded in creating pixelmap Ui .' + (pixelmap as image.PixelMap).getPixelBytesNumber())
|
||||||
|
onCompleteFunction(pixelmap as image.PixelMap);
|
||||||
|
}).catch((err: string) => {
|
||||||
|
LogUtil.log("ceshi321 : test occur error: " + err)
|
||||||
|
onErrorFunction(err);
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
// taskPoolExecutePixelMap(arrayBuffer: ArrayBuffer, onCompleteFunction: (value: PixelMap) => void | PromiseLike<PixelMap>, onErrorFunction: (reason?: BusinessError | string) => void) {
|
||||||
|
// let task = new taskpool.Task(taskParseImage, arrayBuffer, scale)
|
||||||
|
// task.setTransferList([])
|
||||||
|
// taskpool.execute(task).then((pixelmap: Object) => {
|
||||||
|
//
|
||||||
|
// }).catch((err: string) => {
|
||||||
|
// LogUtil.log("ceshi321 : " + err)
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
writePngWithStringAsync(worker: any, addInfo: string, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
||||||
|
worker.onerror = function (data) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.onmessageerror = function (e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.onexit = function () {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.onmessage = function(e) {
|
||||||
|
var data = e.data;
|
||||||
|
switch (data.type) {
|
||||||
|
case 'writePngWithStringAsync':
|
||||||
|
callback.pngCallback(data.receiver, data.data)
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
worker.terminate();
|
||||||
|
}
|
||||||
|
|
||||||
|
var obj = { type: 'writePngWithStringAsync', data:pngBuffer, info: addInfo}
|
||||||
|
worker.postMessage(obj, [pngBuffer])
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
writePngAsync(worker: any, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
||||||
|
worker.onerror = function (data) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.onmessageerror = function (e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.onexit = function () {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
worker.onmessage = function(e) {
|
||||||
|
var data = e.data;
|
||||||
|
switch (data.type) {
|
||||||
|
case 'writePngAsync':
|
||||||
|
callback.pngCallback(data.receiver, data.data)
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
worker.terminate();
|
||||||
|
}
|
||||||
|
|
||||||
|
var obj = { type: 'writePngAsync', data:pngBuffer}
|
||||||
|
worker.postMessage(obj, [pngBuffer])
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
@Concurrent
|
||||||
|
async function taskParseImage(type, arrayBuffer, callback): Promise<PixelMap> {
|
||||||
|
|
||||||
|
switch (type.type) {
|
||||||
|
case 'readPngImageAsync':
|
||||||
|
callback(data.receiver, data.data)
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
let obj = { type: 'readPngImageAsync', data: arrayBuffer }
|
||||||
|
|
||||||
|
return (obj,[arrayBuffer])
|
||||||
|
}
|
||||||
|
|
||||||
|
// function taskPoolExecutePixelMap(arrayBuffer: ArrayBuffer, scale: number, onCompleteFunction: (value: PixelMap) => void | PromiseLike<PixelMap>, onErrorFunction: (reason?: BusinessError | string) => void) {
|
||||||
|
// LogUtil.log("ceshi321 : arrayBuffer长度" + arrayBuffer.byteLength)
|
||||||
|
// let task = new taskpool.Task(taskParseImage, arrayBuffer, scale)
|
||||||
|
// task.setTransferList([])
|
||||||
|
// taskpool.execute(task).then((pixelmap: Object) => {
|
||||||
|
// LogUtil.log('ceshi321 : Succeeded in creating pixelmap Ui .' + (pixelmap as image.PixelMap).getPixelBytesNumber())
|
||||||
|
// onCompleteFunction(pixelmap as image.PixelMap);
|
||||||
|
// }).catch((err: string) => {
|
||||||
|
// LogUtil.log("ceshi321 : test occur error: " + err)
|
||||||
|
// onErrorFunction(err);
|
||||||
|
// });
|
||||||
|
// }
|
|
@ -63,33 +63,58 @@ export class Pngj {
|
||||||
}
|
}
|
||||||
|
|
||||||
readPngImageAsync(worker: any, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
readPngImageAsync(worker: any, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
||||||
worker.onerror = function (data) {
|
// worker.onerror = function (data) {
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// worker.onmessageerror = function (e) {
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// worker.onexit = function () {
|
||||||
|
//
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// worker.onmessage = function(e) {
|
||||||
|
// var data = e.data;
|
||||||
|
// switch (data.type) {
|
||||||
|
// case 'readPngImageAsync':
|
||||||
|
// callback.pngCallback(data.receiver, data.data)
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break
|
||||||
|
// }
|
||||||
|
// worker.terminate();
|
||||||
|
// }
|
||||||
|
// var obj = { type: 'readPngImageAsync', data: pngBuffer }
|
||||||
|
// worker.postMessage(obj, [pngBuffer])
|
||||||
|
let task = new taskpool.Task(taskParseImage, arrayBuffer, scale)
|
||||||
|
task.setTransferList([])
|
||||||
|
taskpool.execute(task).then((pixelmap: Object) => {
|
||||||
|
LogUtil.log('ceshi321 : Succeeded in creating pixelmap Ui .' + (pixelmap as image.PixelMap).getPixelBytesNumber())
|
||||||
|
onCompleteFunction(pixelmap as image.PixelMap);
|
||||||
|
}).catch((err: string) => {
|
||||||
|
LogUtil.log("ceshi321 : test occur error: " + err)
|
||||||
|
onErrorFunction(err);
|
||||||
|
});
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
worker.onmessageerror = function (e) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
worker.onexit = function () {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
worker.onmessage = function(e) {
|
|
||||||
var data = e.data;
|
|
||||||
switch (data.type) {
|
|
||||||
case 'readPngImageAsync':
|
|
||||||
callback.pngCallback(data.receiver, data.data)
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break
|
|
||||||
}
|
|
||||||
worker.terminate();
|
|
||||||
}
|
|
||||||
var obj = { type: 'readPngImageAsync', data: pngBuffer }
|
|
||||||
worker.postMessage(obj, [pngBuffer])
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
writePngWithStringAsync(worker: any, addInfo: string, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
writePngWithStringAsync(worker: any, addInfo: string, pngBuffer: ArrayBuffer, callback: PngCallback<ArrayBuffer, any>) {
|
||||||
worker.onerror = function (data) {
|
worker.onerror = function (data) {
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue