add ResourceLoader plugin

This commit is contained in:
pengfei.zhou
2021-11-18 16:38:35 +08:00
committed by osborn
parent ea85559977
commit d746c5b4d4
22 changed files with 312 additions and 7 deletions

View File

@@ -0,0 +1,6 @@
import { Resource } from "../util/resource";
import { BridgeContext } from "../runtime/global";
export declare function imageDecoder(context: BridgeContext): {
getBitmapInfo: (resource: Resource) => Promise<ArrayBuffer>;
decodeToPixels: (resource: Resource) => Promise<ArrayBuffer>;
};

View File

@@ -0,0 +1,25 @@
/*
* Copyright [2021] [Doric.Pub]
*
* 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.
*/
export function imageDecoder(context) {
return {
getBitmapInfo: (resource) => {
return context.callNative('imageDecoder', 'getBitmapInfo', resource);
},
decodeToPixels: (resource) => {
return context.callNative('imageDecoder', 'decode', resource);
},
};
}

View File

@@ -10,3 +10,4 @@ export * from './statusbar';
export * from './coordinator';
export * from './notch';
export * from './keyboard';
export * from './resourceLoader';

View File

@@ -25,3 +25,4 @@ export * from './statusbar';
export * from './coordinator';
export * from './notch';
export * from './keyboard';
export * from './resourceLoader';

View File

@@ -0,0 +1,5 @@
import { Resource } from "../util/resource";
import { BridgeContext } from "../runtime/global";
export declare function resourceLoader(context: BridgeContext): {
load: (resource: Resource) => Promise<ArrayBuffer>;
};

View File

@@ -0,0 +1,7 @@
export function resourceLoader(context) {
return {
load: (resource) => {
return context.callNative('resourceLoader', 'load', resource.toModel());
},
};
}