sprunk-engine
    Preparing search index...

    A RenderBehavior already set up to render a textured object with UV coordinates (GPUBindGroupLayoutDescriptor and GPUVertexBufferLayout are already set up). BindGroupLayout can be used to set up the bind group layout for the texture and sampler.

    Hierarchy (View Summary)

    Index

    Constructors

    • Create a new BasicUVTexturedRenderBehavior with a predetermined descriptor and buffer layout.

      Parameters

      • spriteImageUrl: RequestInfo | URL

        The URL of the sprite image (will automatically load the texture in the GPU)

      • vertexData: Float32Array

        The vertex data (3 floats for position and 2 float for UV coordinates)

      • indexData: Uint16Array

        The index data (to form triangles)

      • vertexWGSLShader: string

        The vertex shader in WGSL (source code in string). Ensure that the shader has a uniform mat4 mvpMatrix and is compatible with the layout.

      • fragmentWGSLShader: string

        The fragment shader in WGSL (source code in string). Ensure that the shader has a texture and sampler and is compatible with the layout.

      • sampler: GPUSamplerDescriptor

        The sampler configuration

      Returns BasicUVTexturedRenderBehavior

    Properties

    _bindGroup: null | GPUBindGroup = null
    _bindGroupLayouts: null | GPUBindGroupLayout[] = null
    _indexBuffer: null | GPUBuffer = null
    _indexData: Uint16Array
    _mvpUniformBuffer: null | GPUBuffer = null
    _pipeline: null | GPURenderPipeline = null
    _renderEngine: Renderer
    _spriteTexture: null | GPUTexture = null
    _vertexBuffer: null | GPUBuffer = null

    Accessors

    Methods

    • Detach this behavior from the GameObject it is attached to.

      Parameters

      • from: GameObject

        The GameObject to detach this behavior from.

      Returns void

      Error if the behavior is not attached to the GameObject.

    • Protected

      Observe a LogicBehavior and call the observer function when the data changes.

      Type Parameters

      Parameters

      • BehaviorClass: new (...args: any[]) => T

        The specific LogicBehavior class type to observe.

      • observer: (data: U) => void

        The function to call when the data changes.

      Returns void

    • Like onEnable, but should only be for internal use, so some non-abstact direct behaviors could expose attachedOn to the user.

      Parameters

      • attachedOn: GameObject

        The GameObject this behavior is attached to.

      Returns void

      Error if the behavior is already attached to a GameObject.

    • Protected

      Called every frame. Override this method to add custom behavior.

      Parameters

      • _deltaTime: number

        The time in seconds since the last frame.

        • This method should not be called directly except by the GameEngineWindowComponent.

      Returns void