Skip to content
Snippets Groups Projects
Select Git revision
  • 8ec1f63ca162db4b2e9bd3e7b0eeb3547c7b8620
  • master default protected
  • rednatco-v2
  • base-pairs-ladder
  • rednatco
  • test
  • ntc-tube-uniform-color
  • ntc-tube-missing-atoms
  • restore-vertex-array-per-program
  • watlas2
  • dnatco_new
  • cleanup-old-nodejs
  • webmmb
  • fix_auth_seq_id
  • update_deps
  • ext_dev
  • ntc_balls
  • nci-2
  • plugin
  • bugfix-0.4.5
  • nci
  • v0.5.0-dev.1
  • v0.4.5
  • v0.4.4
  • v0.4.3
  • v0.4.2
  • v0.4.1
  • v0.4.0
  • v0.3.12
  • v0.3.11
  • v0.3.10
  • v0.3.9
  • v0.3.8
  • v0.3.7
  • v0.3.6
  • v0.3.5
  • v0.3.4
  • v0.3.3
  • v0.3.2
  • v0.3.1
  • v0.3.0
41 results

scene.ts

Blame
  • user avatar
    Alexander Rose authored
    8ec1f63c
    History
    scene.ts 3.42 KiB
    /**
     * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
     *
     * @author Alexander Rose <alexander.rose@weirdbyte.de>
     */
    
    import { PointRenderable, MeshRenderable, Renderable } from './renderable'
    
    import { ValueCell } from 'mol-util';
    import { Context } from './webgl/context';
    
    let _renderObjectId = 0;
    function getNextId() {
        return _renderObjectId++ % 0x7FFFFFFF;
    }
    
    export type RenderData = { [k: string]: ValueCell<Helpers.TypedArray> }
    
    export interface BaseRenderObject { id: number, type: string, props: {}, visible: boolean, transparent: boolean }
    export interface MeshRenderObject extends BaseRenderObject { type: 'mesh', props: MeshRenderable.Props }
    export interface PointRenderObject extends BaseRenderObject { type: 'point', props: PointRenderable.Props }
    export type RenderObject = MeshRenderObject | PointRenderObject
    
    export function createMeshRenderObject(props: MeshRenderable.Props): MeshRenderObject {
        return { id: getNextId(), type: 'mesh', props, visible: true, transparent: props.alpha < 1 }
    }
    export function createPointRenderObject(props: PointRenderable.Props): PointRenderObject {
        return { id: getNextId(), type: 'point', props, visible: true, transparent: props.alpha < 1 }
    }
    
    export function createRenderable(ctx: Context, o: RenderObject) {
        switch (o.type) {
            case 'mesh': return MeshRenderable.create(ctx, o.props)
            case 'point': return PointRenderable.create(ctx, o.props)
        }
    }
    
    interface Scene {
        add: (o: RenderObject) => void
        remove: (o: RenderObject) => void
        clear: () => void
        forEach: (callbackFn: (value: Renderable<any>, key: RenderObject) => void) => void
        eachOpaque: (callbackFn: (value: Renderable<any>, key: RenderObject) => void) => void
        eachTransparent: (callbackFn: (value: Renderable<any>, key: RenderObject) => void) => void
        count: number
    }
    
    namespace Scene {
        export function create(ctx: Context): Scene {
            const renderableMap = new Map<RenderObject, Renderable<any>>()
    
            return {
                add: (o: RenderObject) => {
                    if (!renderableMap.has(o)) {
                        renderableMap.set(o, createRenderable(ctx, o))
                    } else {
                        console.warn(`RenderObject with id '${o.id}' already present`)
                    }
                },
                remove: (o: RenderObject) => {
                    const renderable = renderableMap.get(o)
                    if (renderable) {
                        renderable.dispose()
                        renderableMap.delete(o)
                    }
                },
                clear: () => {
                    renderableMap.forEach(renderable => renderable.dispose())
                    renderableMap.clear()
                },
                forEach: (callbackFn: (value: Renderable<any>, key: RenderObject) => void) => {
                    renderableMap.forEach(callbackFn)
                },
                eachOpaque: (callbackFn: (value: Renderable<any>, key: RenderObject) => void) => {
                    renderableMap.forEach((r, o) => {
                        if (!o.transparent) callbackFn(r, o)
                    })
                },
                eachTransparent: (callbackFn: (value: Renderable<any>, key: RenderObject) => void) => {
                    renderableMap.forEach((r, o) => {
                        if (o.transparent) callbackFn(r, o)
                    })
                },
                get count() {
                    return renderableMap.size
                }
            }
        }
    }
    
    export default Scene