overpaint-data.ts 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  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 { Color } from '../../mol-util/color';
  10. export type OverpaintData = {
  11. tOverpaint: ValueCell<TextureImage<Uint8Array>>
  12. uOverpaintTexDim: ValueCell<Vec2>
  13. dOverpaint: ValueCell<boolean>,
  14. }
  15. export function applyOverpaintColor(array: Uint8Array, start: number, end: number, color: Color, alpha: number) {
  16. for (let i = start; i < end; ++i) {
  17. Color.toArray(color, array, i * 4);
  18. array[i * 4 + 3] = alpha * 255;
  19. }
  20. return true;
  21. }
  22. export function clearOverpaint(array: Uint8Array, start: number, end: number) {
  23. array.fill(0, start * 4, end * 4);
  24. return true;
  25. }
  26. export function createOverpaint(count: number, overpaintData?: OverpaintData): OverpaintData {
  27. const overpaint = createTextureImage(Math.max(1, count), 4, Uint8Array, overpaintData && overpaintData.tOverpaint.ref.value.array);
  28. if (overpaintData) {
  29. ValueCell.update(overpaintData.tOverpaint, overpaint);
  30. ValueCell.update(overpaintData.uOverpaintTexDim, Vec2.create(overpaint.width, overpaint.height));
  31. ValueCell.update(overpaintData.dOverpaint, count > 0);
  32. return overpaintData;
  33. } else {
  34. return {
  35. tOverpaint: ValueCell.create(overpaint),
  36. uOverpaintTexDim: ValueCell.create(Vec2.create(overpaint.width, overpaint.height)),
  37. dOverpaint: ValueCell.create(count > 0),
  38. };
  39. }
  40. }
  41. const emptyOverpaintTexture = { array: new Uint8Array(4), width: 1, height: 1 };
  42. export function createEmptyOverpaint(overpaintData?: OverpaintData): OverpaintData {
  43. if (overpaintData) {
  44. ValueCell.update(overpaintData.tOverpaint, emptyOverpaintTexture);
  45. ValueCell.update(overpaintData.uOverpaintTexDim, Vec2.create(1, 1));
  46. return overpaintData;
  47. } else {
  48. return {
  49. tOverpaint: ValueCell.create(emptyOverpaintTexture),
  50. uOverpaintTexDim: ValueCell.create(Vec2.create(1, 1)),
  51. dOverpaint: ValueCell.create(false),
  52. };
  53. }
  54. }