Implement ResourceHandler.
This commit is contained in:
parent
067baf8c72
commit
80173d580e
@ -0,0 +1,63 @@
|
||||
import { Resource, ResourceNameType, ResourceIdType } from "@ray-lab/renderer-virtual";
|
||||
|
||||
/**
|
||||
* Resource processing tools.
|
||||
* Whenever a new resource setting is received,
|
||||
* an instance of this class will be instantiated to manage the received resource.
|
||||
* @typeParam ResourceOption - Resource option type.
|
||||
*/
|
||||
abstract class ResourceHandler<ResourceOption extends Resource = Resource> {
|
||||
|
||||
/**
|
||||
* Resource type enumeration.
|
||||
*/
|
||||
public static resourceType: ResourceNameType;
|
||||
public static resourceTypeAlias: ResourceNameType;
|
||||
|
||||
/**
|
||||
* Original resource option.
|
||||
*/
|
||||
public resourceOption: ResourceOption;
|
||||
|
||||
/**
|
||||
* Resource unique number.
|
||||
*/
|
||||
public resourceId: ResourceIdType;
|
||||
|
||||
/**
|
||||
* @param resourceOption - Resource option.
|
||||
*/
|
||||
public constructor(resourceOption: ResourceOption) {
|
||||
this.resourceOption = resourceOption;
|
||||
this.resourceId = resourceOption.id ?? Symbol(resourceOption.type);
|
||||
}
|
||||
|
||||
/**
|
||||
* Resource initialization lifecycle.
|
||||
* It will be called once after `WebGLState` is ready.
|
||||
*/
|
||||
public abstract setup(): any;
|
||||
|
||||
/**
|
||||
* Marks whether the instance is destroyed.
|
||||
*/
|
||||
public isDestroyed: boolean = false;
|
||||
|
||||
/**
|
||||
* Resource destruction lifecycle.
|
||||
* Will be called when the resource is destroyed.
|
||||
*/
|
||||
public abstract destroy(): any;
|
||||
|
||||
/**
|
||||
* Resource Settings Update Lifecycle.
|
||||
* Called when the resource settings will to be updated.
|
||||
* At this time, you can access the old settings through `this.resourceOption`.
|
||||
*
|
||||
* Note:
|
||||
* You don't need to execute ```this.resourceOption = newResourceOption``` manually,
|
||||
* The assignment will be done after this function returns.
|
||||
* @param newResourceOption - New resource option.
|
||||
*/
|
||||
public abstract update(newResourceOption: ResourceOption): any;
|
||||
}
|
@ -0,0 +1,8 @@
|
||||
|
||||
/**
|
||||
* Used to manage and process all GL resources.
|
||||
* Rely on adding `ResourceHandler` to extend functions.
|
||||
*/
|
||||
class ResourcePool {
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user