clipping-data.ts 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /**
  2. * Copyright (c) 2020 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 { Clipping } from '../../mol-theme/clipping';
  10. export type ClippingData = {
  11. dClipObjectCount: ValueCell<number>,
  12. dClipVariant: ValueCell<string>,
  13. tClipping: ValueCell<TextureImage<Uint8Array>>
  14. uClippingTexDim: ValueCell<Vec2>
  15. dClipping: ValueCell<boolean>,
  16. }
  17. export function applyClippingGroups(array: Uint8Array, start: number, end: number, groups: Clipping.Groups) {
  18. for (let i = start; i < end; ++i) {
  19. array[i] = groups;
  20. }
  21. return true;
  22. }
  23. export function clearClipping(array: Uint8Array, start: number, end: number) {
  24. array.fill(0, start, end);
  25. }
  26. export function createClipping(count: number, clippingData?: ClippingData): ClippingData {
  27. const clipping = createTextureImage(Math.max(1, count), 1, Uint8Array, clippingData && clippingData.tClipping.ref.value.array);
  28. if (clippingData) {
  29. ValueCell.update(clippingData.tClipping, clipping);
  30. ValueCell.update(clippingData.uClippingTexDim, Vec2.create(clipping.width, clipping.height));
  31. ValueCell.updateIfChanged(clippingData.dClipping, count > 0);
  32. return clippingData;
  33. } else {
  34. return {
  35. dClipObjectCount: ValueCell.create(0),
  36. dClipVariant: ValueCell.create('instance'),
  37. tClipping: ValueCell.create(clipping),
  38. uClippingTexDim: ValueCell.create(Vec2.create(clipping.width, clipping.height)),
  39. dClipping: ValueCell.create(count > 0),
  40. };
  41. }
  42. }
  43. const emptyClippingTexture = { array: new Uint8Array(1), width: 1, height: 1 };
  44. export function createEmptyClipping(clippingData?: ClippingData): ClippingData {
  45. if (clippingData) {
  46. ValueCell.update(clippingData.tClipping, emptyClippingTexture);
  47. ValueCell.update(clippingData.uClippingTexDim, Vec2.create(1, 1));
  48. return clippingData;
  49. } else {
  50. return {
  51. dClipObjectCount: ValueCell.create(0),
  52. dClipVariant: ValueCell.create('instance'),
  53. tClipping: ValueCell.create(emptyClippingTexture),
  54. uClippingTexDim: ValueCell.create(Vec2.create(1, 1)),
  55. dClipping: ValueCell.create(false),
  56. };
  57. }
  58. }