transparency-data.ts 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /**
  2. * Copyright (c) 2019-2021 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, Vec3, Vec4 } from '../../mol-math/linear-algebra';
  8. import { TextureImage, createTextureImage } from '../../mol-gl/renderable/util';
  9. import { createNullTexture, Texture } from '../../mol-gl/webgl/texture';
  10. export type TransparencyData = {
  11. tTransparency: ValueCell<TextureImage<Uint8Array>>
  12. uTransparencyTexDim: ValueCell<Vec2>
  13. dTransparency: ValueCell<boolean>,
  14. transparencyAverage: ValueCell<number>,
  15. tTransparencyGrid: ValueCell<Texture>,
  16. uTransparencyGridDim: ValueCell<Vec3>,
  17. uTransparencyGridTransform: ValueCell<Vec4>,
  18. dTransparencyType: ValueCell<string>,
  19. }
  20. export function applyTransparencyValue(array: Uint8Array, start: number, end: number, value: number) {
  21. for (let i = start; i < end; ++i) {
  22. array[i] = value * 255;
  23. }
  24. return true;
  25. }
  26. export function getTransparencyAverage(array: Uint8Array, count: number): number {
  27. let sum = 0;
  28. for (let i = 0; i < count; ++i) {
  29. sum += array[i];
  30. }
  31. return sum / (255 * count);
  32. }
  33. export function clearTransparency(array: Uint8Array, start: number, end: number) {
  34. array.fill(0, start, end);
  35. }
  36. export function createTransparency(count: number, transparencyData?: TransparencyData): TransparencyData {
  37. const transparency = createTextureImage(Math.max(1, count), 1, Uint8Array, transparencyData && transparencyData.tTransparency.ref.value.array);
  38. if (transparencyData) {
  39. ValueCell.update(transparencyData.tTransparency, transparency);
  40. ValueCell.update(transparencyData.uTransparencyTexDim, Vec2.create(transparency.width, transparency.height));
  41. ValueCell.updateIfChanged(transparencyData.dTransparency, count > 0);
  42. ValueCell.updateIfChanged(transparencyData.transparencyAverage, getTransparencyAverage(transparency.array, count));
  43. return transparencyData;
  44. } else {
  45. return {
  46. tTransparency: ValueCell.create(transparency),
  47. uTransparencyTexDim: ValueCell.create(Vec2.create(transparency.width, transparency.height)),
  48. dTransparency: ValueCell.create(count > 0),
  49. transparencyAverage: ValueCell.create(0),
  50. tTransparencyGrid: ValueCell.create(createNullTexture()),
  51. uTransparencyGridDim: ValueCell.create(Vec3.create(1, 1, 1)),
  52. uTransparencyGridTransform: ValueCell.create(Vec4.create(0, 0, 0, 1)),
  53. dTransparencyType: ValueCell.create('groupInstance'),
  54. };
  55. }
  56. }
  57. const emptyTransparencyTexture = { array: new Uint8Array(1), width: 1, height: 1 };
  58. export function createEmptyTransparency(transparencyData?: TransparencyData): TransparencyData {
  59. if (transparencyData) {
  60. ValueCell.update(transparencyData.tTransparency, emptyTransparencyTexture);
  61. ValueCell.update(transparencyData.uTransparencyTexDim, Vec2.create(1, 1));
  62. return transparencyData;
  63. } else {
  64. return {
  65. tTransparency: ValueCell.create(emptyTransparencyTexture),
  66. uTransparencyTexDim: ValueCell.create(Vec2.create(1, 1)),
  67. dTransparency: ValueCell.create(false),
  68. transparencyAverage: ValueCell.create(0),
  69. tTransparencyGrid: ValueCell.create(createNullTexture()),
  70. uTransparencyGridDim: ValueCell.create(Vec3.create(1, 1, 1)),
  71. uTransparencyGridTransform: ValueCell.create(Vec4.create(0, 0, 0, 1)),
  72. dTransparencyType: ValueCell.create('groupInstance'),
  73. };
  74. }
  75. }