direct-volume.ts 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /**
  2. * Copyright (c) 2018-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { Renderable, RenderableState, createRenderable } from '../renderable';
  7. import { WebGLContext } from '../webgl/context';
  8. import { createGraphicsRenderItem, GraphicsRenderVariant } from '../webgl/render-item';
  9. import { AttributeSpec, Values, UniformSpec, GlobalUniformSchema, InternalSchema, TextureSpec, ElementsSpec, DefineSpec, InternalValues, GlobalTextureSchema, BaseSchema } from './schema';
  10. import { DirectVolumeShaderCode } from '../shader-code';
  11. import { ValueCell } from '../../mol-util';
  12. export const DirectVolumeSchema = {
  13. ...BaseSchema,
  14. aPosition: AttributeSpec('float32', 3, 0),
  15. elements: ElementsSpec('uint32'),
  16. uColor: UniformSpec('v3'),
  17. uColorTexDim: UniformSpec('v2'),
  18. tColor: TextureSpec('image-uint8', 'rgb', 'ubyte', 'nearest'),
  19. dColorType: DefineSpec('string', ['uniform', 'attribute', 'instance', 'group', 'groupInstance', 'vertex', 'vertexInstance']),
  20. uIsoValue: UniformSpec('v2'),
  21. uBboxMin: UniformSpec('v3'),
  22. uBboxMax: UniformSpec('v3'),
  23. uBboxSize: UniformSpec('v3'),
  24. uMaxSteps: UniformSpec('i'),
  25. uStepScale: UniformSpec('f'),
  26. uJumpLength: UniformSpec('f'),
  27. uTransform: UniformSpec('m4'),
  28. uGridDim: UniformSpec('v3'),
  29. dRenderMode: DefineSpec('string', ['isosurface', 'volume']),
  30. dSingleLayer: DefineSpec('boolean'),
  31. tTransferTex: TextureSpec('image-uint8', 'rgba', 'ubyte', 'linear'),
  32. uTransferScale: UniformSpec('f'),
  33. dGridTexType: DefineSpec('string', ['2d', '3d']),
  34. uGridTexDim: UniformSpec('v3'),
  35. tGridTex: TextureSpec('texture', 'rgba', 'ubyte', 'linear'),
  36. uGridStats: UniformSpec('v4'), // [min, max, mean, sigma]
  37. uCellDim: UniformSpec('v3'),
  38. uCartnToUnit: UniformSpec('m4'),
  39. uUnitToCartn: UniformSpec('m4'),
  40. dPackedGroup: DefineSpec('boolean'),
  41. dDoubleSided: DefineSpec('boolean'),
  42. dFlipSided: DefineSpec('boolean'),
  43. dFlatShaded: DefineSpec('boolean'),
  44. dIgnoreLight: DefineSpec('boolean'),
  45. dXrayShaded: DefineSpec('boolean'),
  46. };
  47. export type DirectVolumeSchema = typeof DirectVolumeSchema
  48. export type DirectVolumeValues = Values<DirectVolumeSchema>
  49. export function DirectVolumeRenderable(ctx: WebGLContext, id: number, values: DirectVolumeValues, state: RenderableState, materialId: number, variants: GraphicsRenderVariant[]): Renderable<DirectVolumeValues> {
  50. const schema = { ...GlobalUniformSchema, ...GlobalTextureSchema, ...InternalSchema, ...DirectVolumeSchema };
  51. if (!ctx.isWebGL2) {
  52. // workaround for webgl1 limitation that loop counters need to be `const`
  53. (schema.uMaxSteps as any) = DefineSpec('number');
  54. }
  55. const internalValues: InternalValues = {
  56. uObjectId: ValueCell.create(id),
  57. };
  58. const shaderCode = DirectVolumeShaderCode;
  59. const renderItem = createGraphicsRenderItem(ctx, 'triangles', shaderCode, schema, { ...values, ...internalValues }, materialId, variants);
  60. return createRenderable(renderItem, values, state);
  61. }