Optimize unify panel hook after code
This commit is contained in:
		| @@ -18,7 +18,7 @@ import { loge } from "../util/log"; | ||||
| import "reflect-metadata"; | ||||
| function hookBeforeNativeCall(context) { | ||||
|     if (context) { | ||||
|         Reflect.defineMetadata('__doric_context__', context, global); | ||||
|         setContext(context); | ||||
|         context.hookBeforeNativeCall(); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -166,74 +166,37 @@ export class Panel { | ||||
|         return this.context.callNative("shader", "render", model); | ||||
|     } | ||||
|     hookBeforeNativeCall() { | ||||
|         if (Environment.platform !== 'web') { | ||||
|             this.__root__.clean(); | ||||
|             for (let map of this.headviews.values()) { | ||||
|                 for (let v of map.values()) { | ||||
|                     v.clean(); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     hookAfterNativeCall() { | ||||
|         if (this.destroyed) { | ||||
|             return; | ||||
|         } | ||||
|         const promises = []; | ||||
|         if (Environment.platform !== 'web') { | ||||
|             //Here insert a native call to ensure the promise is resolved done. | ||||
|             //nativeEmpty() | ||||
|             if (this.__root__.isDirty()) { | ||||
|                 const model = this.__root__.toModel(); | ||||
|                 promises.push(this.nativeRender(model)); | ||||
|             } | ||||
|             for (let map of this.headviews.values()) { | ||||
|                 for (let v of map.values()) { | ||||
|                     if (v.isDirty()) { | ||||
|                         const model = v.toModel(); | ||||
|                         promises.push(this.nativeRender(model)); | ||||
|                     } | ||||
|         if (this.__root__.isDirty()) { | ||||
|             const model = this.__root__.toModel(); | ||||
|             promises.push(this.nativeRender(model)); | ||||
|             this.__root__.clean(); | ||||
|         } | ||||
|         for (let map of this.headviews.values()) { | ||||
|             for (let v of map.values()) { | ||||
|                 if (v.isDirty()) { | ||||
|                     const model = v.toModel(); | ||||
|                     promises.push(this.nativeRender(model)); | ||||
|                     v.clean(); | ||||
|                 } | ||||
|             } | ||||
|             if (this.__rendering__) { | ||||
|                 //skip | ||||
|                 Promise.all(promises).then(_ => { | ||||
|                 }); | ||||
|             } | ||||
|             else { | ||||
|                 this.__rendering__ = true; | ||||
|                 Promise.all(promises).then(_ => { | ||||
|                     this.__rendering__ = false; | ||||
|                     this.onRenderFinished(); | ||||
|                 }); | ||||
|             } | ||||
|         } | ||||
|         if (this.__rendering__) { | ||||
|             //skip | ||||
|             Promise.all(promises).then(_ => { | ||||
|             }); | ||||
|         } | ||||
|         else { | ||||
|             if (this.__rendering__) { | ||||
|                 //skip | ||||
|                 return; | ||||
|             } | ||||
|             this.__rendering__ = true; | ||||
|             Function("return this")().setTimeout(() => { | ||||
|                 if (this.__root__.isDirty()) { | ||||
|                     const model = this.__root__.toModel(); | ||||
|                     promises.push(this.nativeRender(model)); | ||||
|                     this.__root__.clean(); | ||||
|                 } | ||||
|                 for (let map of this.headviews.values()) { | ||||
|                     for (let v of map.values()) { | ||||
|                         if (v.isDirty()) { | ||||
|                             const model = v.toModel(); | ||||
|                             promises.push(this.nativeRender(model)); | ||||
|                             v.clean(); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             Promise.all(promises).then(_ => { | ||||
|                 this.__rendering__ = false; | ||||
|                 Promise.all(promises).then(_ => { | ||||
|                     this.onRenderFinished(); | ||||
|                 }); | ||||
|             }, 0); | ||||
|                 this.onRenderFinished(); | ||||
|             }); | ||||
|         } | ||||
|     } | ||||
|     onRenderFinished() { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user