transparency-data.ts 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /**
  2. * Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { ValueCell } from '../../mol-util/value-cell';
  7. import { Vec2 } from '../../mol-math/linear-algebra';
  8. import { TextureImage, createTextureImage } from '../../mol-gl/renderable/util';
  9. import { Transparency } from '../../mol-theme/transparency';
  10. export type TransparencyData = {
  11. tTransparency: ValueCell<TextureImage<Uint8Array>>
  12. uTransparencyTexDim: ValueCell<Vec2>
  13. dTransparency: ValueCell<boolean>,
  14. dTransparencyVariant: ValueCell<string>,
  15. }
  16. export function applyTransparencyValue(array: Uint8Array, start: number, end: number, value: number) {
  17. for (let i = start; i < end; ++i) {
  18. array[i] = value * 255;
  19. }
  20. return true;
  21. }
  22. export function clearTransparency(array: Uint8Array, start: number, end: number) {
  23. array.fill(0, start, end);
  24. }
  25. export function createTransparency(count: number, variant: Transparency.Variant, transparencyData?: TransparencyData): TransparencyData {
  26. const transparency = createTextureImage(Math.max(1, count), 1, Uint8Array, transparencyData && transparencyData.tTransparency.ref.value.array);
  27. if (transparencyData) {
  28. ValueCell.update(transparencyData.tTransparency, transparency);
  29. ValueCell.update(transparencyData.uTransparencyTexDim, Vec2.create(transparency.width, transparency.height));
  30. ValueCell.update(transparencyData.dTransparency, count > 0);
  31. ValueCell.update(transparencyData.dTransparencyVariant, variant);
  32. return transparencyData;
  33. } else {
  34. return {
  35. tTransparency: ValueCell.create(transparency),
  36. uTransparencyTexDim: ValueCell.create(Vec2.create(transparency.width, transparency.height)),
  37. dTransparency: ValueCell.create(count > 0),
  38. dTransparencyVariant: ValueCell.create(variant),
  39. };
  40. }
  41. }
  42. const emptyTransparencyTexture = { array: new Uint8Array(1), width: 1, height: 1 };
  43. export function createEmptyTransparency(transparencyData?: TransparencyData): TransparencyData {
  44. if (transparencyData) {
  45. ValueCell.update(transparencyData.tTransparency, emptyTransparencyTexture);
  46. ValueCell.update(transparencyData.uTransparencyTexDim, Vec2.create(1, 1));
  47. return transparencyData;
  48. } else {
  49. return {
  50. tTransparency: ValueCell.create(emptyTransparencyTexture),
  51. uTransparencyTexDim: ValueCell.create(Vec2.create(1, 1)),
  52. dTransparency: ValueCell.create(false),
  53. dTransparencyVariant: ValueCell.create('single'),
  54. };
  55. }
  56. }