/** * Copyright (c) 2021 mol* contributors, licensed under MIT, See LICENSE file for more info. * * @author Alexander Rose */ import { ValueCell } from '../../mol-util/value-cell'; import { Vec2, Vec3, Vec4 } from '../../mol-math/linear-algebra'; import { TextureImage, createTextureImage } from '../../mol-gl/renderable/util'; import { createNullTexture, Texture } from '../../mol-gl/webgl/texture'; import { Material } from '../../mol-util/material'; export type SubstanceData = { tSubstance: ValueCell> uSubstanceTexDim: ValueCell dSubstance: ValueCell, tSubstanceGrid: ValueCell, uSubstanceGridDim: ValueCell, uSubstanceGridTransform: ValueCell, dSubstanceType: ValueCell, } export function applySubstanceMaterial(array: Uint8Array, start: number, end: number, material: Material) { for (let i = start; i < end; ++i) { Material.toArray(material, array, i * 3); array[i * 3 + 2] = 255; } return true; } export function clearSubstance(array: Uint8Array, start: number, end: number) { array.fill(0, start * 3, end * 3); return true; } export function createSubstance(count: number, substanceData?: SubstanceData): SubstanceData { const substance = createTextureImage(Math.max(1, count), 4, Uint8Array, substanceData && substanceData.tSubstance.ref.value.array); if (substanceData) { ValueCell.update(substanceData.tSubstance, substance); ValueCell.update(substanceData.uSubstanceTexDim, Vec2.create(substance.width, substance.height)); ValueCell.updateIfChanged(substanceData.dSubstance, count > 0); return substanceData; } else { return { tSubstance: ValueCell.create(substance), uSubstanceTexDim: ValueCell.create(Vec2.create(substance.width, substance.height)), dSubstance: ValueCell.create(count > 0), tSubstanceGrid: ValueCell.create(createNullTexture()), uSubstanceGridDim: ValueCell.create(Vec3.create(1, 1, 1)), uSubstanceGridTransform: ValueCell.create(Vec4.create(0, 0, 0, 1)), dSubstanceType: ValueCell.create('groupInstance'), }; } } const emptySubstanceTexture = { array: new Uint8Array(4), width: 1, height: 1 }; export function createEmptySubstance(substanceData?: SubstanceData): SubstanceData { if (substanceData) { ValueCell.update(substanceData.tSubstance, emptySubstanceTexture); ValueCell.update(substanceData.uSubstanceTexDim, Vec2.create(1, 1)); return substanceData; } else { return { tSubstance: ValueCell.create(emptySubstanceTexture), uSubstanceTexDim: ValueCell.create(Vec2.create(1, 1)), dSubstance: ValueCell.create(false), tSubstanceGrid: ValueCell.create(createNullTexture()), uSubstanceGridDim: ValueCell.create(Vec3.create(1, 1, 1)), uSubstanceGridTransform: ValueCell.create(Vec4.create(0, 0, 0, 1)), dSubstanceType: ValueCell.create('groupInstance'), }; } }