html2canvas-pro 2.0.4 → 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -6
- package/dist/html2canvas-pro.esm.js +10103 -9993
- package/dist/html2canvas-pro.esm.js.map +1 -1
- package/dist/html2canvas-pro.js +10102 -9993
- package/dist/html2canvas-pro.js.map +1 -1
- package/dist/html2canvas-pro.min.js +5 -5
- package/dist/lib/config.js +3 -4
- package/dist/lib/core/bitwise.js +0 -1
- package/dist/lib/core/cache-storage.js +36 -50
- package/dist/lib/core/context.js +0 -1
- package/dist/lib/core/debugger.js +0 -1
- package/dist/lib/core/features.js +2 -3
- package/dist/lib/core/logger.js +0 -1
- package/dist/lib/core/origin-checker.js +0 -1
- package/dist/lib/core/performance-monitor.js +1 -24
- package/dist/lib/core/render-element.js +210 -0
- package/dist/lib/core/util.js +0 -1
- package/dist/lib/core/validator.js +0 -1
- package/dist/lib/css/index.js +149 -90
- package/dist/lib/css/layout/bounds.js +0 -1
- package/dist/lib/css/layout/text.js +0 -1
- package/dist/lib/css/{ITypeDescriptor.js → property-descriptor.js} +0 -1
- package/dist/lib/css/property-descriptors/background-clip.js +0 -1
- package/dist/lib/css/property-descriptors/background-color.js +0 -1
- package/dist/lib/css/property-descriptors/background-image.js +0 -1
- package/dist/lib/css/property-descriptors/background-origin.js +0 -1
- package/dist/lib/css/property-descriptors/background-position.js +0 -1
- package/dist/lib/css/property-descriptors/background-repeat.js +0 -1
- package/dist/lib/css/property-descriptors/background-size.js +0 -1
- package/dist/lib/css/property-descriptors/border-color.js +0 -1
- package/dist/lib/css/property-descriptors/border-radius.js +0 -1
- package/dist/lib/css/property-descriptors/border-style.js +0 -1
- package/dist/lib/css/property-descriptors/border-width.js +0 -1
- package/dist/lib/css/property-descriptors/box-shadow.js +0 -1
- package/dist/lib/css/property-descriptors/clip-path.js +0 -1
- package/dist/lib/css/property-descriptors/color.js +0 -1
- package/dist/lib/css/property-descriptors/content.js +0 -1
- package/dist/lib/css/property-descriptors/counter-increment.js +0 -1
- package/dist/lib/css/property-descriptors/counter-reset.js +0 -1
- package/dist/lib/css/property-descriptors/direction.js +0 -1
- package/dist/lib/css/property-descriptors/display.js +0 -1
- package/dist/lib/css/property-descriptors/duration.js +0 -1
- package/dist/lib/css/property-descriptors/float.js +0 -1
- package/dist/lib/css/property-descriptors/font-family.js +0 -1
- package/dist/lib/css/property-descriptors/font-size.js +0 -1
- package/dist/lib/css/property-descriptors/font-style.js +0 -1
- package/dist/lib/css/property-descriptors/font-variant.js +0 -1
- package/dist/lib/css/property-descriptors/font-weight.js +0 -1
- package/dist/lib/css/property-descriptors/image-rendering.js +0 -1
- package/dist/lib/css/property-descriptors/letter-spacing.js +0 -1
- package/dist/lib/css/property-descriptors/line-break.js +0 -1
- package/dist/lib/css/property-descriptors/line-height.js +0 -1
- package/dist/lib/css/property-descriptors/list-style-image.js +0 -1
- package/dist/lib/css/property-descriptors/list-style-position.js +0 -1
- package/dist/lib/css/property-descriptors/list-style-type.js +0 -1
- package/dist/lib/css/property-descriptors/margin.js +0 -1
- package/dist/lib/css/property-descriptors/mix-blend-mode.js +31 -0
- package/dist/lib/css/property-descriptors/object-fit.js +0 -1
- package/dist/lib/css/property-descriptors/opacity.js +0 -1
- package/dist/lib/css/property-descriptors/overflow-wrap.js +0 -1
- package/dist/lib/css/property-descriptors/overflow.js +0 -1
- package/dist/lib/css/property-descriptors/padding.js +0 -1
- package/dist/lib/css/property-descriptors/paint-order.js +0 -1
- package/dist/lib/css/property-descriptors/position.js +0 -1
- package/dist/lib/css/property-descriptors/quotes.js +0 -1
- package/dist/lib/css/property-descriptors/rotate.js +0 -1
- package/dist/lib/css/property-descriptors/text-align.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-color.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-line.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-style.js +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-thickness.js +0 -1
- package/dist/lib/css/property-descriptors/text-overflow.js +0 -1
- package/dist/lib/css/property-descriptors/text-shadow.js +0 -1
- package/dist/lib/css/property-descriptors/text-transform.js +0 -1
- package/dist/lib/css/property-descriptors/text-underline-offset.js +0 -1
- package/dist/lib/css/property-descriptors/transform-origin.js +0 -1
- package/dist/lib/css/property-descriptors/transform.js +0 -1
- package/dist/lib/css/property-descriptors/visibility.js +0 -1
- package/dist/lib/css/property-descriptors/webkit-line-clamp.js +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-color.js +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-width.js +0 -1
- package/dist/lib/css/property-descriptors/word-break.js +0 -1
- package/dist/lib/css/property-descriptors/writing-mode.js +0 -1
- package/dist/lib/css/property-descriptors/z-index.js +0 -1
- package/dist/lib/css/syntax/parser.js +0 -1
- package/dist/lib/css/syntax/tokenizer.js +14 -1
- package/dist/lib/css/{IPropertyDescriptor.js → type-descriptor.js} +0 -1
- package/dist/lib/css/types/angle.js +0 -1
- package/dist/lib/css/types/color-math.js +0 -1
- package/dist/lib/css/types/color-spaces/a98.js +0 -1
- package/dist/lib/css/types/color-spaces/p3.js +0 -1
- package/dist/lib/css/types/color-spaces/pro-photo.js +0 -1
- package/dist/lib/css/types/color-spaces/rec2020.js +0 -1
- package/dist/lib/css/types/color-spaces/srgb.js +0 -1
- package/dist/lib/css/types/color-utilities.js +0 -1
- package/dist/lib/css/types/color.js +0 -1
- package/dist/lib/css/types/functions/-prefix-linear-gradient.js +0 -1
- package/dist/lib/css/types/functions/-prefix-radial-gradient.js +0 -1
- package/dist/lib/css/types/functions/-webkit-gradient.js +0 -1
- package/dist/lib/css/types/functions/counter.js +0 -1
- package/dist/lib/css/types/functions/gradient.js +0 -1
- package/dist/lib/css/types/functions/linear-gradient.js +0 -1
- package/dist/lib/css/types/functions/radial-gradient.js +0 -1
- package/dist/lib/css/types/image.js +0 -1
- package/dist/lib/css/types/index.js +0 -1
- package/dist/lib/css/types/length-percentage.js +0 -1
- package/dist/lib/css/types/length.js +0 -1
- package/dist/lib/css/types/time.js +0 -1
- package/dist/lib/dom/document-cloner.js +27 -22
- package/dist/lib/dom/dom-normalizer.js +0 -1
- package/dist/lib/dom/element-container.js +7 -6
- package/dist/lib/dom/elements/li-element-container.js +0 -1
- package/dist/lib/dom/elements/ol-element-container.js +0 -1
- package/dist/lib/dom/elements/select-element-container.js +0 -1
- package/dist/lib/dom/elements/textarea-element-container.js +0 -1
- package/dist/lib/dom/node-parser.js +37 -53
- package/dist/lib/dom/node-type-guards.js +62 -25
- package/dist/lib/dom/replaced-elements/canvas-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/iframe-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/image-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/index.js +0 -1
- package/dist/lib/dom/replaced-elements/input-element-container.js +0 -1
- package/dist/lib/dom/replaced-elements/pseudo-elements.js +0 -1
- package/dist/lib/dom/replaced-elements/svg-element-container.js +0 -1
- package/dist/lib/dom/text-container.js +0 -1
- package/dist/lib/index.js +32 -210
- package/dist/lib/options.js +2 -0
- package/dist/lib/render/background.js +0 -1
- package/dist/lib/render/bezier-curve.js +0 -1
- package/dist/lib/render/border.js +0 -1
- package/dist/lib/render/bound-curves.js +0 -1
- package/dist/lib/render/box-sizing.js +0 -1
- package/dist/lib/render/canvas/background-renderer.js +8 -24
- package/dist/lib/render/canvas/border-renderer.js +0 -1
- package/dist/lib/render/canvas/canvas-path.js +25 -0
- package/dist/lib/render/canvas/canvas-renderer.js +28 -97
- package/dist/lib/render/canvas/effects-renderer.js +3 -1
- package/dist/lib/render/canvas/foreignobject-renderer.js +13 -17
- package/dist/lib/render/canvas/text-renderer.js +61 -117
- package/dist/lib/render/effects.js +11 -2
- package/dist/lib/render/font-metrics.js +0 -1
- package/dist/lib/render/object-fit.js +87 -0
- package/dist/lib/render/path.js +0 -1
- package/dist/lib/render/renderer-interface.js +0 -1
- package/dist/lib/render/stacking-context.js +16 -8
- package/dist/lib/render/vector.js +0 -1
- package/dist/types/core/cache-storage.d.ts +5 -6
- package/dist/types/core/performance-monitor.d.ts +0 -11
- package/dist/types/core/render-element.d.ts +3 -0
- package/dist/types/css/index.d.ts +3 -0
- package/dist/types/css/property-descriptors/background-clip.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-image.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-origin.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-position.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-repeat.d.ts +1 -1
- package/dist/types/css/property-descriptors/background-size.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-radius.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-style.d.ts +1 -1
- package/dist/types/css/property-descriptors/border-width.d.ts +1 -1
- package/dist/types/css/property-descriptors/box-shadow.d.ts +1 -1
- package/dist/types/css/property-descriptors/clip-path.d.ts +1 -1
- package/dist/types/css/property-descriptors/color.d.ts +1 -1
- package/dist/types/css/property-descriptors/content.d.ts +1 -1
- package/dist/types/css/property-descriptors/counter-increment.d.ts +1 -1
- package/dist/types/css/property-descriptors/counter-reset.d.ts +1 -1
- package/dist/types/css/property-descriptors/direction.d.ts +1 -1
- package/dist/types/css/property-descriptors/display.d.ts +1 -1
- package/dist/types/css/property-descriptors/duration.d.ts +1 -1
- package/dist/types/css/property-descriptors/float.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-family.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-size.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-style.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-variant.d.ts +1 -1
- package/dist/types/css/property-descriptors/font-weight.d.ts +1 -1
- package/dist/types/css/property-descriptors/image-rendering.d.ts +1 -1
- package/dist/types/css/property-descriptors/letter-spacing.d.ts +1 -1
- package/dist/types/css/property-descriptors/line-break.d.ts +1 -1
- package/dist/types/css/property-descriptors/line-height.d.ts +1 -1
- package/dist/types/css/property-descriptors/list-style-image.d.ts +1 -1
- package/dist/types/css/property-descriptors/list-style-position.d.ts +1 -1
- package/dist/types/css/property-descriptors/list-style-type.d.ts +1 -1
- package/dist/types/css/property-descriptors/margin.d.ts +1 -1
- package/dist/types/css/property-descriptors/mix-blend-mode.d.ts +21 -0
- package/dist/types/css/property-descriptors/object-fit.d.ts +1 -1
- package/dist/types/css/property-descriptors/opacity.d.ts +1 -1
- package/dist/types/css/property-descriptors/overflow-wrap.d.ts +1 -1
- package/dist/types/css/property-descriptors/overflow.d.ts +1 -1
- package/dist/types/css/property-descriptors/padding.d.ts +1 -1
- package/dist/types/css/property-descriptors/paint-order.d.ts +1 -1
- package/dist/types/css/property-descriptors/position.d.ts +1 -1
- package/dist/types/css/property-descriptors/quotes.d.ts +1 -1
- package/dist/types/css/property-descriptors/rotate.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-align.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-line.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-style.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-decoration-thickness.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-overflow.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-shadow.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-transform.d.ts +1 -1
- package/dist/types/css/property-descriptors/text-underline-offset.d.ts +1 -1
- package/dist/types/css/property-descriptors/transform-origin.d.ts +1 -1
- package/dist/types/css/property-descriptors/transform.d.ts +1 -1
- package/dist/types/css/property-descriptors/visibility.d.ts +1 -1
- package/dist/types/css/property-descriptors/webkit-line-clamp.d.ts +1 -1
- package/dist/types/css/property-descriptors/webkit-text-stroke-color.d.ts +1 -1
- package/dist/types/css/property-descriptors/webkit-text-stroke-width.d.ts +1 -1
- package/dist/types/css/property-descriptors/word-break.d.ts +1 -1
- package/dist/types/css/property-descriptors/writing-mode.d.ts +1 -1
- package/dist/types/css/property-descriptors/z-index.d.ts +1 -1
- package/dist/types/css/syntax/tokenizer.d.ts +5 -0
- package/dist/types/css/types/angle.d.ts +1 -1
- package/dist/types/css/types/color.d.ts +1 -1
- package/dist/types/css/types/image.d.ts +1 -1
- package/dist/types/css/types/time.d.ts +1 -1
- package/dist/types/dom/element-container.d.ts +4 -11
- package/dist/types/dom/node-parser.d.ts +2 -15
- package/dist/types/dom/node-type-guards.d.ts +21 -22
- package/dist/types/index.d.ts +28 -48
- package/dist/types/options.d.ts +51 -0
- package/dist/types/render/canvas/background-renderer.d.ts +0 -6
- package/dist/types/render/canvas/canvas-path.d.ts +3 -0
- package/dist/types/render/canvas/canvas-renderer.d.ts +4 -2
- package/dist/types/render/canvas/foreignobject-renderer.d.ts +2 -3
- package/dist/types/render/canvas/text-renderer.d.ts +5 -0
- package/dist/types/render/effects.d.ts +9 -1
- package/dist/types/render/object-fit.d.ts +18 -0
- package/package.json +44 -44
- package/demo/image-smoothing-demo.html +0 -256
- package/demo/refactoring-test.html +0 -602
- package/dist/lib/__tests__/index.js +0 -85
- package/dist/lib/__tests__/index.js.map +0 -1
- package/dist/lib/config.js.map +0 -1
- package/dist/lib/core/__mocks__/cache-storage.js +0 -7
- package/dist/lib/core/__mocks__/cache-storage.js.map +0 -1
- package/dist/lib/core/__mocks__/context.js +0 -19
- package/dist/lib/core/__mocks__/context.js.map +0 -1
- package/dist/lib/core/__mocks__/features.js +0 -12
- package/dist/lib/core/__mocks__/features.js.map +0 -1
- package/dist/lib/core/__mocks__/logger.js +0 -16
- package/dist/lib/core/__mocks__/logger.js.map +0 -1
- package/dist/lib/core/__tests__/cache-storage.js +0 -225
- package/dist/lib/core/__tests__/cache-storage.js.map +0 -1
- package/dist/lib/core/__tests__/cache-storage.test.js +0 -158
- package/dist/lib/core/__tests__/cache-storage.test.js.map +0 -1
- package/dist/lib/core/__tests__/logger.js +0 -27
- package/dist/lib/core/__tests__/logger.js.map +0 -1
- package/dist/lib/core/__tests__/validator.js +0 -296
- package/dist/lib/core/__tests__/validator.js.map +0 -1
- package/dist/lib/core/bitwise.js.map +0 -1
- package/dist/lib/core/cache-storage.js.map +0 -1
- package/dist/lib/core/context.js.map +0 -1
- package/dist/lib/core/debugger.js.map +0 -1
- package/dist/lib/core/features.js.map +0 -1
- package/dist/lib/core/logger.js.map +0 -1
- package/dist/lib/core/origin-checker.js.map +0 -1
- package/dist/lib/core/performance-monitor.js.map +0 -1
- package/dist/lib/core/util.js.map +0 -1
- package/dist/lib/core/validator.js.map +0 -1
- package/dist/lib/css/IPropertyDescriptor.js.map +0 -1
- package/dist/lib/css/ITypeDescriptor.js.map +0 -1
- package/dist/lib/css/index.js.map +0 -1
- package/dist/lib/css/layout/__mocks__/bounds.js +0 -9
- package/dist/lib/css/layout/__mocks__/bounds.js.map +0 -1
- package/dist/lib/css/layout/bounds.js.map +0 -1
- package/dist/lib/css/layout/text.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/background-tests.js +0 -49
- package/dist/lib/css/property-descriptors/__tests__/background-tests.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/clip-path.test.js +0 -273
- package/dist/lib/css/property-descriptors/__tests__/clip-path.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/font-family.js +0 -19
- package/dist/lib/css/property-descriptors/__tests__/font-family.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-integration.test.js +0 -143
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-integration.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-performance.test.js +0 -167
- package/dist/lib/css/property-descriptors/__tests__/image-rendering-performance.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/image-rendering.test.js +0 -61
- package/dist/lib/css/property-descriptors/__tests__/image-rendering.test.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/paint-order.js +0 -66
- package/dist/lib/css/property-descriptors/__tests__/paint-order.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/text-shadow.js +0 -82
- package/dist/lib/css/property-descriptors/__tests__/text-shadow.js.map +0 -1
- package/dist/lib/css/property-descriptors/__tests__/transform-tests.js +0 -14
- package/dist/lib/css/property-descriptors/__tests__/transform-tests.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-clip.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-image.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-origin.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-position.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-repeat.js.map +0 -1
- package/dist/lib/css/property-descriptors/background-size.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-radius.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-style.js.map +0 -1
- package/dist/lib/css/property-descriptors/border-width.js.map +0 -1
- package/dist/lib/css/property-descriptors/box-shadow.js.map +0 -1
- package/dist/lib/css/property-descriptors/clip-path.js.map +0 -1
- package/dist/lib/css/property-descriptors/color.js.map +0 -1
- package/dist/lib/css/property-descriptors/content.js.map +0 -1
- package/dist/lib/css/property-descriptors/counter-increment.js.map +0 -1
- package/dist/lib/css/property-descriptors/counter-reset.js.map +0 -1
- package/dist/lib/css/property-descriptors/direction.js.map +0 -1
- package/dist/lib/css/property-descriptors/display.js.map +0 -1
- package/dist/lib/css/property-descriptors/duration.js.map +0 -1
- package/dist/lib/css/property-descriptors/float.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-family.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-size.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-style.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-variant.js.map +0 -1
- package/dist/lib/css/property-descriptors/font-weight.js.map +0 -1
- package/dist/lib/css/property-descriptors/image-rendering.js.map +0 -1
- package/dist/lib/css/property-descriptors/letter-spacing.js.map +0 -1
- package/dist/lib/css/property-descriptors/line-break.js.map +0 -1
- package/dist/lib/css/property-descriptors/line-height.js.map +0 -1
- package/dist/lib/css/property-descriptors/list-style-image.js.map +0 -1
- package/dist/lib/css/property-descriptors/list-style-position.js.map +0 -1
- package/dist/lib/css/property-descriptors/list-style-type.js.map +0 -1
- package/dist/lib/css/property-descriptors/margin.js.map +0 -1
- package/dist/lib/css/property-descriptors/object-fit.js.map +0 -1
- package/dist/lib/css/property-descriptors/opacity.js.map +0 -1
- package/dist/lib/css/property-descriptors/overflow-wrap.js.map +0 -1
- package/dist/lib/css/property-descriptors/overflow.js.map +0 -1
- package/dist/lib/css/property-descriptors/padding.js.map +0 -1
- package/dist/lib/css/property-descriptors/paint-order.js.map +0 -1
- package/dist/lib/css/property-descriptors/position.js.map +0 -1
- package/dist/lib/css/property-descriptors/quotes.js.map +0 -1
- package/dist/lib/css/property-descriptors/rotate.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-align.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-line.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-style.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-decoration-thickness.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-overflow.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-shadow.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-transform.js.map +0 -1
- package/dist/lib/css/property-descriptors/text-underline-offset.js.map +0 -1
- package/dist/lib/css/property-descriptors/transform-origin.js.map +0 -1
- package/dist/lib/css/property-descriptors/transform.js.map +0 -1
- package/dist/lib/css/property-descriptors/visibility.js.map +0 -1
- package/dist/lib/css/property-descriptors/webkit-line-clamp.js.map +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-color.js.map +0 -1
- package/dist/lib/css/property-descriptors/webkit-text-stroke-width.js.map +0 -1
- package/dist/lib/css/property-descriptors/word-break.js.map +0 -1
- package/dist/lib/css/property-descriptors/writing-mode.js.map +0 -1
- package/dist/lib/css/property-descriptors/z-index.js.map +0 -1
- package/dist/lib/css/syntax/__tests__/tokernizer-tests.js +0 -26
- package/dist/lib/css/syntax/__tests__/tokernizer-tests.js.map +0 -1
- package/dist/lib/css/syntax/parser.js.map +0 -1
- package/dist/lib/css/syntax/tokenizer.js.map +0 -1
- package/dist/lib/css/types/__tests__/color-tests.js +0 -111
- package/dist/lib/css/types/__tests__/color-tests.js.map +0 -1
- package/dist/lib/css/types/__tests__/image-tests.js +0 -215
- package/dist/lib/css/types/__tests__/image-tests.js.map +0 -1
- package/dist/lib/css/types/angle.js.map +0 -1
- package/dist/lib/css/types/color-math.js.map +0 -1
- package/dist/lib/css/types/color-spaces/a98.js.map +0 -1
- package/dist/lib/css/types/color-spaces/p3.js.map +0 -1
- package/dist/lib/css/types/color-spaces/pro-photo.js.map +0 -1
- package/dist/lib/css/types/color-spaces/rec2020.js.map +0 -1
- package/dist/lib/css/types/color-spaces/srgb.js.map +0 -1
- package/dist/lib/css/types/color-utilities.js.map +0 -1
- package/dist/lib/css/types/color.js.map +0 -1
- package/dist/lib/css/types/functions/-prefix-linear-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/-prefix-radial-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/-webkit-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/__tests__/radial-gradient.js +0 -63
- package/dist/lib/css/types/functions/__tests__/radial-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/counter.js.map +0 -1
- package/dist/lib/css/types/functions/gradient.js.map +0 -1
- package/dist/lib/css/types/functions/linear-gradient.js.map +0 -1
- package/dist/lib/css/types/functions/radial-gradient.js.map +0 -1
- package/dist/lib/css/types/image.js.map +0 -1
- package/dist/lib/css/types/index.js.map +0 -1
- package/dist/lib/css/types/length-percentage.js.map +0 -1
- package/dist/lib/css/types/length.js.map +0 -1
- package/dist/lib/css/types/time.js.map +0 -1
- package/dist/lib/dom/__mocks__/document-cloner.js +0 -23
- package/dist/lib/dom/__mocks__/document-cloner.js.map +0 -1
- package/dist/lib/dom/__tests__/dom-normalizer.test.js +0 -113
- package/dist/lib/dom/__tests__/dom-normalizer.test.js.map +0 -1
- package/dist/lib/dom/__tests__/element-container.test.js +0 -109
- package/dist/lib/dom/__tests__/element-container.test.js.map +0 -1
- package/dist/lib/dom/document-cloner.js.map +0 -1
- package/dist/lib/dom/dom-normalizer.js.map +0 -1
- package/dist/lib/dom/element-container.js.map +0 -1
- package/dist/lib/dom/elements/li-element-container.js.map +0 -1
- package/dist/lib/dom/elements/ol-element-container.js.map +0 -1
- package/dist/lib/dom/elements/select-element-container.js.map +0 -1
- package/dist/lib/dom/elements/textarea-element-container.js.map +0 -1
- package/dist/lib/dom/node-parser.js.map +0 -1
- package/dist/lib/dom/node-type-guards.js.map +0 -1
- package/dist/lib/dom/replaced-elements/canvas-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/iframe-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/image-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/index.js.map +0 -1
- package/dist/lib/dom/replaced-elements/input-element-container.js.map +0 -1
- package/dist/lib/dom/replaced-elements/pseudo-elements.js.map +0 -1
- package/dist/lib/dom/replaced-elements/svg-element-container.js.map +0 -1
- package/dist/lib/dom/text-container.js.map +0 -1
- package/dist/lib/index.js.map +0 -1
- package/dist/lib/invariant.js +0 -10
- package/dist/lib/invariant.js.map +0 -1
- package/dist/lib/render/background.js.map +0 -1
- package/dist/lib/render/bezier-curve.js.map +0 -1
- package/dist/lib/render/border.js.map +0 -1
- package/dist/lib/render/bound-curves.js.map +0 -1
- package/dist/lib/render/box-sizing.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/background-renderer.test.js +0 -65
- package/dist/lib/render/canvas/__tests__/background-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/border-renderer.test.js +0 -23
- package/dist/lib/render/canvas/__tests__/border-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/effects-renderer.test.js +0 -30
- package/dist/lib/render/canvas/__tests__/effects-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/__tests__/text-renderer.test.js +0 -402
- package/dist/lib/render/canvas/__tests__/text-renderer.test.js.map +0 -1
- package/dist/lib/render/canvas/background-renderer.js.map +0 -1
- package/dist/lib/render/canvas/border-renderer.js.map +0 -1
- package/dist/lib/render/canvas/canvas-renderer.js.map +0 -1
- package/dist/lib/render/canvas/effects-renderer.js.map +0 -1
- package/dist/lib/render/canvas/foreignobject-renderer.js.map +0 -1
- package/dist/lib/render/canvas/text-renderer.js.map +0 -1
- package/dist/lib/render/effects.js.map +0 -1
- package/dist/lib/render/font-metrics.js.map +0 -1
- package/dist/lib/render/path.js.map +0 -1
- package/dist/lib/render/renderer-interface.js.map +0 -1
- package/dist/lib/render/renderer.js +0 -11
- package/dist/lib/render/renderer.js.map +0 -1
- package/dist/lib/render/stacking-context.js.map +0 -1
- package/dist/lib/render/vector.js.map +0 -1
- package/dist/types/__tests__/index.d.ts +0 -1
- package/dist/types/core/__mocks__/cache-storage.d.ts +0 -2
- package/dist/types/core/__mocks__/context.d.ts +0 -9
- package/dist/types/core/__mocks__/features.d.ts +0 -8
- package/dist/types/core/__mocks__/logger.d.ts +0 -9
- package/dist/types/core/__tests__/cache-storage.d.ts +0 -1
- package/dist/types/core/__tests__/cache-storage.test.d.ts +0 -1
- package/dist/types/core/__tests__/logger.d.ts +0 -1
- package/dist/types/core/__tests__/validator.d.ts +0 -1
- package/dist/types/css/layout/__mocks__/bounds.d.ts +0 -2
- package/dist/types/css/property-descriptors/__tests__/background-tests.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/clip-path.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/font-family.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/image-rendering-integration.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/image-rendering-performance.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/image-rendering.test.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/paint-order.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/text-shadow.d.ts +0 -1
- package/dist/types/css/property-descriptors/__tests__/transform-tests.d.ts +0 -1
- package/dist/types/css/syntax/__tests__/tokernizer-tests.d.ts +0 -1
- package/dist/types/css/types/__tests__/color-tests.d.ts +0 -1
- package/dist/types/css/types/__tests__/image-tests.d.ts +0 -1
- package/dist/types/css/types/functions/__tests__/radial-gradient.d.ts +0 -1
- package/dist/types/dom/__mocks__/document-cloner.d.ts +0 -6
- package/dist/types/dom/__tests__/dom-normalizer.test.d.ts +0 -1
- package/dist/types/dom/__tests__/element-container.test.d.ts +0 -1
- package/dist/types/invariant.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/background-renderer.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/border-renderer.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/effects-renderer.test.d.ts +0 -1
- package/dist/types/render/canvas/__tests__/text-renderer.test.d.ts +0 -1
- package/dist/types/render/renderer.d.ts +0 -7
- package/eslint.config.js +0 -35
- package/jest.config.cjs +0 -5
- package/karma.conf.cjs +0 -300
- /package/dist/types/css/{IPropertyDescriptor.d.ts → property-descriptor.d.ts} +0 -0
- /package/dist/types/css/{ITypeDescriptor.d.ts → type-descriptor.d.ts} +0 -0
|
@@ -5,7 +5,6 @@ const stacking_context_1 = require("../stacking-context");
|
|
|
5
5
|
const color_utilities_1 = require("../../css/types/color-utilities");
|
|
6
6
|
const path_1 = require("../path");
|
|
7
7
|
const bound_curves_1 = require("../bound-curves");
|
|
8
|
-
const bezier_curve_1 = require("../bezier-curve");
|
|
9
8
|
const vector_1 = require("../vector");
|
|
10
9
|
const background_1 = require("../background");
|
|
11
10
|
const text_1 = require("../../css/layout/text");
|
|
@@ -23,17 +22,23 @@ const input_element_container_1 = require("../../dom/replaced-elements/input-ele
|
|
|
23
22
|
const textarea_element_container_1 = require("../../dom/elements/textarea-element-container");
|
|
24
23
|
const select_element_container_1 = require("../../dom/elements/select-element-container");
|
|
25
24
|
const iframe_element_container_1 = require("../../dom/replaced-elements/iframe-element-container");
|
|
26
|
-
const renderer_1 = require("../renderer");
|
|
27
25
|
const background_renderer_1 = require("./background-renderer");
|
|
28
26
|
const border_renderer_1 = require("./border-renderer");
|
|
29
27
|
const effects_renderer_1 = require("./effects-renderer");
|
|
30
28
|
const text_renderer_1 = require("./text-renderer");
|
|
29
|
+
const canvas_path_1 = require("./canvas-path");
|
|
30
|
+
const object_fit_1 = require("../object-fit");
|
|
31
31
|
const MASK_OFFSET = 10000;
|
|
32
|
-
class CanvasRenderer
|
|
32
|
+
class CanvasRenderer {
|
|
33
33
|
constructor(context, options) {
|
|
34
|
-
|
|
34
|
+
this.context = context;
|
|
35
|
+
this.options = options;
|
|
35
36
|
this.canvas = options.canvas ? options.canvas : document.createElement('canvas');
|
|
36
|
-
|
|
37
|
+
const ctx = this.canvas.getContext('2d');
|
|
38
|
+
if (!ctx) {
|
|
39
|
+
throw new Error('Failed to get 2D rendering context from canvas');
|
|
40
|
+
}
|
|
41
|
+
this.ctx = ctx;
|
|
37
42
|
if (!options.canvas) {
|
|
38
43
|
this.canvas.width = Math.floor(options.width * options.scale);
|
|
39
44
|
this.canvas.height = Math.floor(options.height * options.scale);
|
|
@@ -81,7 +86,7 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
81
86
|
}
|
|
82
87
|
}
|
|
83
88
|
async renderNode(paint) {
|
|
84
|
-
if (
|
|
89
|
+
if (paint.container.debugRender) {
|
|
85
90
|
debugger;
|
|
86
91
|
}
|
|
87
92
|
if (paint.container.styles.isVisible()) {
|
|
@@ -103,80 +108,7 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
103
108
|
this.path(path);
|
|
104
109
|
this.ctx.save();
|
|
105
110
|
this.ctx.clip();
|
|
106
|
-
|
|
107
|
-
const { objectFit } = container.styles;
|
|
108
|
-
const boxRatio = dw / dh;
|
|
109
|
-
const imgRatio = sw / sh;
|
|
110
|
-
if (objectFit === 2 /* OBJECT_FIT.CONTAIN */) {
|
|
111
|
-
if (imgRatio > boxRatio) {
|
|
112
|
-
dh = dw / imgRatio;
|
|
113
|
-
dy += (box.height - dh) / 2;
|
|
114
|
-
}
|
|
115
|
-
else {
|
|
116
|
-
dw = dh * imgRatio;
|
|
117
|
-
dx += (box.width - dw) / 2;
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
else if (objectFit === 4 /* OBJECT_FIT.COVER */) {
|
|
121
|
-
if (imgRatio > boxRatio) {
|
|
122
|
-
sw = sh * boxRatio;
|
|
123
|
-
sx += (intrinsicWidth - sw) / 2;
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
sh = sw / boxRatio;
|
|
127
|
-
sy += (intrinsicHeight - sh) / 2;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
else if (objectFit === 8 /* OBJECT_FIT.NONE */) {
|
|
131
|
-
if (sw > dw) {
|
|
132
|
-
sx += (sw - dw) / 2;
|
|
133
|
-
sw = dw;
|
|
134
|
-
}
|
|
135
|
-
else {
|
|
136
|
-
dx += (dw - sw) / 2;
|
|
137
|
-
dw = sw;
|
|
138
|
-
}
|
|
139
|
-
if (sh > dh) {
|
|
140
|
-
sy += (sh - dh) / 2;
|
|
141
|
-
sh = dh;
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
dy += (dh - sh) / 2;
|
|
145
|
-
dh = sh;
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
else if (objectFit === 16 /* OBJECT_FIT.SCALE_DOWN */) {
|
|
149
|
-
const containW = imgRatio > boxRatio ? dw : dh * imgRatio;
|
|
150
|
-
const noneW = sw > dw ? sw : dw;
|
|
151
|
-
if (containW < noneW) {
|
|
152
|
-
if (imgRatio > boxRatio) {
|
|
153
|
-
dh = dw / imgRatio;
|
|
154
|
-
dy += (box.height - dh) / 2;
|
|
155
|
-
}
|
|
156
|
-
else {
|
|
157
|
-
dw = dh * imgRatio;
|
|
158
|
-
dx += (box.width - dw) / 2;
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
else {
|
|
162
|
-
if (sw > dw) {
|
|
163
|
-
sx += (sw - dw) / 2;
|
|
164
|
-
sw = dw;
|
|
165
|
-
}
|
|
166
|
-
else {
|
|
167
|
-
dx += (dw - sw) / 2;
|
|
168
|
-
dw = sw;
|
|
169
|
-
}
|
|
170
|
-
if (sh > dh) {
|
|
171
|
-
sy += (sh - dh) / 2;
|
|
172
|
-
sh = dh;
|
|
173
|
-
}
|
|
174
|
-
else {
|
|
175
|
-
dy += (dh - sh) / 2;
|
|
176
|
-
dh = sh;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
}
|
|
111
|
+
const { sx, sy, sw, sh, dx, dy, dw, dh } = (0, object_fit_1.calculateObjectFitRendering)(intrinsicWidth, intrinsicHeight, box, container.styles.objectFit);
|
|
180
112
|
this.ctx.drawImage(image, sx, sy, sw, sh, dx, dy, dw, dh);
|
|
181
113
|
this.ctx.restore();
|
|
182
114
|
}
|
|
@@ -343,17 +275,22 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
343
275
|
}
|
|
344
276
|
}
|
|
345
277
|
async renderStackContent(stack) {
|
|
346
|
-
if (
|
|
278
|
+
if (stack.element.container.debugRender) {
|
|
347
279
|
debugger;
|
|
348
280
|
}
|
|
281
|
+
const signal = this.options.signal;
|
|
349
282
|
// https://www.w3.org/TR/css-position-3/#painting-order
|
|
350
283
|
// 1. the background and borders of the element forming the stacking context.
|
|
351
284
|
await this.renderNodeBackgroundAndBorders(stack.element);
|
|
352
285
|
// 2. the child stacking contexts with negative stack levels (most negative first).
|
|
353
286
|
for (const child of stack.negativeZIndex) {
|
|
287
|
+
if (signal?.aborted)
|
|
288
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
354
289
|
await this.renderStack(child);
|
|
355
290
|
}
|
|
356
291
|
// 3. For all its in-flow, non-positioned, block-level descendants in tree order:
|
|
292
|
+
if (signal?.aborted)
|
|
293
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
357
294
|
await this.renderNodeContent(stack.element);
|
|
358
295
|
for (const child of stack.nonInlineLevel) {
|
|
359
296
|
await this.renderNode(child);
|
|
@@ -363,10 +300,14 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
363
300
|
// which actually create a new stacking context should be considered part of the parent stacking context,
|
|
364
301
|
// not this new one.
|
|
365
302
|
for (const child of stack.nonPositionedFloats) {
|
|
303
|
+
if (signal?.aborted)
|
|
304
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
366
305
|
await this.renderStack(child);
|
|
367
306
|
}
|
|
368
307
|
// 5. the in-flow, inline-level, non-positioned descendants, including inline tables and inline blocks.
|
|
369
308
|
for (const child of stack.nonPositionedInlineLevel) {
|
|
309
|
+
if (signal?.aborted)
|
|
310
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
370
311
|
await this.renderStack(child);
|
|
371
312
|
}
|
|
372
313
|
for (const child of stack.inlineLevel) {
|
|
@@ -383,11 +324,15 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
383
324
|
//
|
|
384
325
|
// All transform descendants with transform other than none
|
|
385
326
|
for (const child of stack.zeroOrAutoZIndexOrTransformedOrOpacity) {
|
|
327
|
+
if (signal?.aborted)
|
|
328
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
386
329
|
await this.renderStack(child);
|
|
387
330
|
}
|
|
388
331
|
// 7. Stacking contexts formed by positioned descendants with z-indices greater than or equal to 1 in z-index
|
|
389
332
|
// order (smallest first) then tree order.
|
|
390
333
|
for (const child of stack.positiveZIndex) {
|
|
334
|
+
if (signal?.aborted)
|
|
335
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
391
336
|
await this.renderStack(child);
|
|
392
337
|
}
|
|
393
338
|
}
|
|
@@ -405,23 +350,10 @@ class CanvasRenderer extends renderer_1.Renderer {
|
|
|
405
350
|
this.ctx.closePath();
|
|
406
351
|
}
|
|
407
352
|
path(paths) {
|
|
408
|
-
this.ctx
|
|
409
|
-
this.formatPath(paths);
|
|
410
|
-
this.ctx.closePath();
|
|
353
|
+
(0, canvas_path_1.createCanvasPath)(this.ctx, paths);
|
|
411
354
|
}
|
|
412
355
|
formatPath(paths) {
|
|
413
|
-
|
|
414
|
-
const start = (0, bezier_curve_1.isBezierCurve)(point) ? point.start : point;
|
|
415
|
-
if (index === 0) {
|
|
416
|
-
this.ctx.moveTo(start.x, start.y);
|
|
417
|
-
}
|
|
418
|
-
else {
|
|
419
|
-
this.ctx.lineTo(start.x, start.y);
|
|
420
|
-
}
|
|
421
|
-
if ((0, bezier_curve_1.isBezierCurve)(point)) {
|
|
422
|
-
this.ctx.bezierCurveTo(point.startControl.x, point.startControl.y, point.endControl.x, point.endControl.y, point.end.x, point.end.y);
|
|
423
|
-
}
|
|
424
|
-
});
|
|
356
|
+
(0, canvas_path_1.formatCanvasPath)(this.ctx, paths);
|
|
425
357
|
}
|
|
426
358
|
async renderNodeBackgroundAndBorders(paint) {
|
|
427
359
|
this.effectsRenderer.applyEffects(paint.getEffects(2 /* EffectTarget.BACKGROUND_BORDERS */));
|
|
@@ -536,4 +468,3 @@ const canvasTextAlign = (textAlign) => {
|
|
|
536
468
|
return 'left';
|
|
537
469
|
}
|
|
538
470
|
};
|
|
539
|
-
//# sourceMappingURL=canvas-renderer.js.map
|
|
@@ -63,6 +63,9 @@ class EffectsRenderer {
|
|
|
63
63
|
// Clip-path: delegate shape drawing (beginPath … clip()) to the effect.
|
|
64
64
|
effect.applyClip(this.ctx);
|
|
65
65
|
}
|
|
66
|
+
else if ((0, effects_1.isBlendEffect)(effect)) {
|
|
67
|
+
this.ctx.globalCompositeOperation = effect.compositeOperation;
|
|
68
|
+
}
|
|
66
69
|
this.activeEffects.push(effect);
|
|
67
70
|
}
|
|
68
71
|
/**
|
|
@@ -91,4 +94,3 @@ class EffectsRenderer {
|
|
|
91
94
|
}
|
|
92
95
|
}
|
|
93
96
|
exports.EffectsRenderer = EffectsRenderer;
|
|
94
|
-
//# sourceMappingURL=effects-renderer.js.map
|
|
@@ -1,15 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.ForeignObjectRenderer = void 0;
|
|
4
4
|
const features_1 = require("../../core/features");
|
|
5
5
|
const color_utilities_1 = require("../../css/types/color-utilities");
|
|
6
|
-
|
|
7
|
-
class ForeignObjectRenderer extends renderer_1.Renderer {
|
|
6
|
+
class ForeignObjectRenderer {
|
|
8
7
|
constructor(context, options) {
|
|
9
|
-
|
|
10
|
-
this.canvas = options.canvas ? options.canvas : document.createElement('canvas');
|
|
11
|
-
this.ctx = this.canvas.getContext('2d');
|
|
8
|
+
this.context = context;
|
|
12
9
|
this.options = options;
|
|
10
|
+
this.canvas = options.canvas ? options.canvas : document.createElement('canvas');
|
|
11
|
+
const ctx = this.canvas.getContext('2d');
|
|
12
|
+
if (!ctx) {
|
|
13
|
+
throw new Error('Failed to get 2D rendering context from canvas');
|
|
14
|
+
}
|
|
15
|
+
this.ctx = ctx;
|
|
13
16
|
this.canvas.width = Math.floor(options.width * options.scale);
|
|
14
17
|
this.canvas.height = Math.floor(options.height * options.scale);
|
|
15
18
|
this.canvas.style.width = `${options.width}px`;
|
|
@@ -19,8 +22,11 @@ class ForeignObjectRenderer extends renderer_1.Renderer {
|
|
|
19
22
|
this.context.logger.debug(`EXPERIMENTAL ForeignObject renderer initialized (${options.width}x${options.height} at ${options.x},${options.y}) with scale ${options.scale}`);
|
|
20
23
|
}
|
|
21
24
|
async render(element) {
|
|
25
|
+
if (this.options.signal?.aborted) {
|
|
26
|
+
throw new DOMException('The operation was aborted.', 'AbortError');
|
|
27
|
+
}
|
|
22
28
|
const svg = (0, features_1.createForeignObjectSVG)(this.options.width * this.options.scale, this.options.height * this.options.scale, this.options.scale, this.options.scale, element);
|
|
23
|
-
const img = await (0,
|
|
29
|
+
const img = await (0, features_1.loadSerializedSVG)(svg);
|
|
24
30
|
if (this.options.backgroundColor) {
|
|
25
31
|
this.ctx.fillStyle = (0, color_utilities_1.asString)(this.options.backgroundColor);
|
|
26
32
|
this.ctx.fillRect(0, 0, this.options.width * this.options.scale, this.options.height * this.options.scale);
|
|
@@ -30,13 +36,3 @@ class ForeignObjectRenderer extends renderer_1.Renderer {
|
|
|
30
36
|
}
|
|
31
37
|
}
|
|
32
38
|
exports.ForeignObjectRenderer = ForeignObjectRenderer;
|
|
33
|
-
const loadSerializedSVG = (svg) => new Promise((resolve, reject) => {
|
|
34
|
-
const img = new Image();
|
|
35
|
-
img.onload = () => {
|
|
36
|
-
resolve(img);
|
|
37
|
-
};
|
|
38
|
-
img.onerror = reject;
|
|
39
|
-
img.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(new XMLSerializer().serializeToString(svg))}`;
|
|
40
|
-
});
|
|
41
|
-
exports.loadSerializedSVG = loadSerializedSVG;
|
|
42
|
-
//# sourceMappingURL=foreignobject-renderer.js.map
|
|
@@ -80,6 +80,10 @@ const fixIOSSystemFonts = (fontFamilies) => {
|
|
|
80
80
|
}
|
|
81
81
|
return fontFamilies;
|
|
82
82
|
};
|
|
83
|
+
const getTextStrokeLineJoin = () => {
|
|
84
|
+
const currentWindow = typeof window !== 'undefined' ? window : undefined;
|
|
85
|
+
return currentWindow?.chrome ? 'miter' : 'round';
|
|
86
|
+
};
|
|
83
87
|
/**
|
|
84
88
|
* Text Renderer
|
|
85
89
|
*
|
|
@@ -156,7 +160,13 @@ class TextRenderer {
|
|
|
156
160
|
* grapheme is drawn individually so spacing and CJK baseline are applied correctly.
|
|
157
161
|
*/
|
|
158
162
|
renderTextWithLetterSpacing(text, letterSpacing, baseline, writingMode = 0 /* WRITING_MODE.HORIZONTAL_TB */) {
|
|
159
|
-
|
|
163
|
+
this.renderFillText(text, letterSpacing, baseline, writingMode);
|
|
164
|
+
}
|
|
165
|
+
canRenderWholeText(letterSpacing, writingMode) {
|
|
166
|
+
return letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(writingMode);
|
|
167
|
+
}
|
|
168
|
+
renderFillText(text, letterSpacing, baseline, writingMode) {
|
|
169
|
+
if (this.canRenderWholeText(letterSpacing, writingMode)) {
|
|
160
170
|
this.ctx.fillText(text.text, text.bounds.left, text.bounds.top + baseline);
|
|
161
171
|
}
|
|
162
172
|
else {
|
|
@@ -165,6 +175,49 @@ class TextRenderer {
|
|
|
165
175
|
});
|
|
166
176
|
}
|
|
167
177
|
}
|
|
178
|
+
renderStrokeText(text, letterSpacing, baseline, writingMode) {
|
|
179
|
+
if (this.canRenderWholeText(letterSpacing, writingMode)) {
|
|
180
|
+
this.ctx.strokeText(text.text, text.bounds.left, text.bounds.top + baseline);
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
this.iterateLettersWithLetterSpacing(text, letterSpacing, baseline, writingMode, (letter, x, y) => {
|
|
184
|
+
this.ctx.strokeText(letter, x, y);
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
renderTextStrokeWithStyle(text, styles) {
|
|
189
|
+
if (!styles.webkitTextStrokeWidth || !text.text.trim().length) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
193
|
+
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
194
|
+
this.ctx.lineJoin = getTextStrokeLineJoin();
|
|
195
|
+
this.renderStrokeText(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
196
|
+
this.ctx.strokeStyle = '';
|
|
197
|
+
this.ctx.lineWidth = 0;
|
|
198
|
+
this.ctx.lineJoin = 'miter';
|
|
199
|
+
}
|
|
200
|
+
renderTextFillWithShadows(text, styles) {
|
|
201
|
+
this.ctx.fillStyle = (0, color_utilities_1.asString)(styles.color);
|
|
202
|
+
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
203
|
+
const textShadows = styles.textShadow;
|
|
204
|
+
if (textShadows.length && text.text.trim().length) {
|
|
205
|
+
textShadows
|
|
206
|
+
.slice(0)
|
|
207
|
+
.reverse()
|
|
208
|
+
.forEach((textShadow) => {
|
|
209
|
+
this.ctx.shadowColor = (0, color_utilities_1.asString)(textShadow.color);
|
|
210
|
+
this.ctx.shadowOffsetX = textShadow.offsetX.number * this.options.scale;
|
|
211
|
+
this.ctx.shadowOffsetY = textShadow.offsetY.number * this.options.scale;
|
|
212
|
+
this.ctx.shadowBlur = textShadow.blur.number;
|
|
213
|
+
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
214
|
+
});
|
|
215
|
+
this.ctx.shadowColor = '';
|
|
216
|
+
this.ctx.shadowOffsetX = 0;
|
|
217
|
+
this.ctx.shadowOffsetY = 0;
|
|
218
|
+
this.ctx.shadowBlur = 0;
|
|
219
|
+
}
|
|
220
|
+
}
|
|
168
221
|
/**
|
|
169
222
|
* Helper method to render text with paint order support
|
|
170
223
|
* Reduces code duplication in line-clamp and normal rendering
|
|
@@ -177,21 +230,7 @@ class TextRenderer {
|
|
|
177
230
|
this.renderTextWithLetterSpacing(textBound, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
178
231
|
break;
|
|
179
232
|
case 1 /* PAINT_ORDER_LAYER.STROKE */:
|
|
180
|
-
|
|
181
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
182
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
183
|
-
this.ctx.lineJoin =
|
|
184
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
185
|
-
if (styles.letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(styles.writingMode)) {
|
|
186
|
-
this.ctx.strokeText(textBound.text, textBound.bounds.left, textBound.bounds.top + styles.fontSize.number);
|
|
187
|
-
}
|
|
188
|
-
else {
|
|
189
|
-
this.iterateLettersWithLetterSpacing(textBound, styles.letterSpacing, styles.fontSize.number, styles.writingMode, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
190
|
-
}
|
|
191
|
-
this.ctx.strokeStyle = '';
|
|
192
|
-
this.ctx.lineWidth = 0;
|
|
193
|
-
this.ctx.lineJoin = 'miter';
|
|
194
|
-
}
|
|
233
|
+
this.renderTextStrokeWithStyle(textBound, styles);
|
|
195
234
|
break;
|
|
196
235
|
}
|
|
197
236
|
});
|
|
@@ -422,29 +461,10 @@ class TextRenderer {
|
|
|
422
461
|
switch (paintOrderLayer) {
|
|
423
462
|
case 0 /* PAINT_ORDER_LAYER.FILL */:
|
|
424
463
|
this.ctx.fillStyle = (0, color_utilities_1.asString)(styles.color);
|
|
425
|
-
|
|
426
|
-
this.ctx.fillText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
427
|
-
}
|
|
428
|
-
else {
|
|
429
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode, (letter, x, y) => this.ctx.fillText(letter, x, y));
|
|
430
|
-
}
|
|
464
|
+
this.renderTextWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
431
465
|
break;
|
|
432
466
|
case 1 /* PAINT_ORDER_LAYER.STROKE */:
|
|
433
|
-
|
|
434
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
435
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
436
|
-
this.ctx.lineJoin =
|
|
437
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
438
|
-
if (styles.letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(styles.writingMode)) {
|
|
439
|
-
this.ctx.strokeText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
440
|
-
}
|
|
441
|
-
else {
|
|
442
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
443
|
-
}
|
|
444
|
-
this.ctx.strokeStyle = '';
|
|
445
|
-
this.ctx.lineWidth = 0;
|
|
446
|
-
this.ctx.lineJoin = 'miter';
|
|
447
|
-
}
|
|
467
|
+
this.renderTextStrokeWithStyle(truncatedBounds, styles);
|
|
448
468
|
break;
|
|
449
469
|
}
|
|
450
470
|
});
|
|
@@ -493,53 +513,11 @@ class TextRenderer {
|
|
|
493
513
|
paintOrder.forEach((paintOrderLayer) => {
|
|
494
514
|
switch (paintOrderLayer) {
|
|
495
515
|
case 0 /* PAINT_ORDER_LAYER.FILL */: {
|
|
496
|
-
this.
|
|
497
|
-
if (styles.letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(styles.writingMode)) {
|
|
498
|
-
this.ctx.fillText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
499
|
-
}
|
|
500
|
-
else {
|
|
501
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode, (letter, x, y) => this.ctx.fillText(letter, x, y));
|
|
502
|
-
}
|
|
503
|
-
const textShadows = styles.textShadow;
|
|
504
|
-
if (textShadows.length && truncatedText.trim().length) {
|
|
505
|
-
textShadows
|
|
506
|
-
.slice(0)
|
|
507
|
-
.reverse()
|
|
508
|
-
.forEach((textShadow) => {
|
|
509
|
-
this.ctx.shadowColor = (0, color_utilities_1.asString)(textShadow.color);
|
|
510
|
-
this.ctx.shadowOffsetX = textShadow.offsetX.number * this.options.scale;
|
|
511
|
-
this.ctx.shadowOffsetY = textShadow.offsetY.number * this.options.scale;
|
|
512
|
-
this.ctx.shadowBlur = textShadow.blur.number;
|
|
513
|
-
if (styles.letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(styles.writingMode)) {
|
|
514
|
-
this.ctx.fillText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
515
|
-
}
|
|
516
|
-
else {
|
|
517
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode, (letter, x, y) => this.ctx.fillText(letter, x, y));
|
|
518
|
-
}
|
|
519
|
-
});
|
|
520
|
-
this.ctx.shadowColor = '';
|
|
521
|
-
this.ctx.shadowOffsetX = 0;
|
|
522
|
-
this.ctx.shadowOffsetY = 0;
|
|
523
|
-
this.ctx.shadowBlur = 0;
|
|
524
|
-
}
|
|
516
|
+
this.renderTextFillWithShadows(truncatedBounds, styles);
|
|
525
517
|
break;
|
|
526
518
|
}
|
|
527
519
|
case 1 /* PAINT_ORDER_LAYER.STROKE */:
|
|
528
|
-
|
|
529
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
530
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
531
|
-
this.ctx.lineJoin =
|
|
532
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
533
|
-
if (styles.letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(styles.writingMode)) {
|
|
534
|
-
this.ctx.strokeText(truncatedText, firstBound.bounds.left, firstBound.bounds.top + styles.fontSize.number);
|
|
535
|
-
}
|
|
536
|
-
else {
|
|
537
|
-
this.iterateLettersWithLetterSpacing(truncatedBounds, styles.letterSpacing, styles.fontSize.number, styles.writingMode, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
538
|
-
}
|
|
539
|
-
this.ctx.strokeStyle = '';
|
|
540
|
-
this.ctx.lineWidth = 0;
|
|
541
|
-
this.ctx.lineJoin = 'miter';
|
|
542
|
-
}
|
|
520
|
+
this.renderTextStrokeWithStyle(truncatedBounds, styles);
|
|
543
521
|
break;
|
|
544
522
|
}
|
|
545
523
|
});
|
|
@@ -550,47 +528,14 @@ class TextRenderer {
|
|
|
550
528
|
paintOrder.forEach((paintOrderLayer) => {
|
|
551
529
|
switch (paintOrderLayer) {
|
|
552
530
|
case 0 /* PAINT_ORDER_LAYER.FILL */: {
|
|
553
|
-
this.
|
|
554
|
-
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
555
|
-
const textShadows = styles.textShadow;
|
|
556
|
-
if (textShadows.length && text.text.trim().length) {
|
|
557
|
-
textShadows
|
|
558
|
-
.slice(0)
|
|
559
|
-
.reverse()
|
|
560
|
-
.forEach((textShadow) => {
|
|
561
|
-
this.ctx.shadowColor = (0, color_utilities_1.asString)(textShadow.color);
|
|
562
|
-
this.ctx.shadowOffsetX = textShadow.offsetX.number * this.options.scale;
|
|
563
|
-
this.ctx.shadowOffsetY = textShadow.offsetY.number * this.options.scale;
|
|
564
|
-
this.ctx.shadowBlur = textShadow.blur.number;
|
|
565
|
-
this.renderTextWithLetterSpacing(text, styles.letterSpacing, styles.fontSize.number, styles.writingMode);
|
|
566
|
-
});
|
|
567
|
-
this.ctx.shadowColor = '';
|
|
568
|
-
this.ctx.shadowOffsetX = 0;
|
|
569
|
-
this.ctx.shadowOffsetY = 0;
|
|
570
|
-
this.ctx.shadowBlur = 0;
|
|
571
|
-
}
|
|
531
|
+
this.renderTextFillWithShadows(text, styles);
|
|
572
532
|
if (styles.textDecorationLine.length) {
|
|
573
533
|
this.renderTextDecoration(text.bounds, styles);
|
|
574
534
|
}
|
|
575
535
|
break;
|
|
576
536
|
}
|
|
577
537
|
case 1 /* PAINT_ORDER_LAYER.STROKE */: {
|
|
578
|
-
|
|
579
|
-
this.ctx.strokeStyle = (0, color_utilities_1.asString)(styles.webkitTextStrokeColor);
|
|
580
|
-
this.ctx.lineWidth = styles.webkitTextStrokeWidth;
|
|
581
|
-
this.ctx.lineJoin =
|
|
582
|
-
typeof window !== 'undefined' && !!window.chrome ? 'miter' : 'round';
|
|
583
|
-
const baseline = styles.fontSize.number;
|
|
584
|
-
if (styles.letterSpacing === 0 && !(0, writing_mode_1.isVerticalWritingMode)(styles.writingMode)) {
|
|
585
|
-
this.ctx.strokeText(text.text, text.bounds.left, text.bounds.top + baseline);
|
|
586
|
-
}
|
|
587
|
-
else {
|
|
588
|
-
this.iterateLettersWithLetterSpacing(text, styles.letterSpacing, baseline, styles.writingMode, (letter, x, y) => this.ctx.strokeText(letter, x, y));
|
|
589
|
-
}
|
|
590
|
-
this.ctx.strokeStyle = '';
|
|
591
|
-
this.ctx.lineWidth = 0;
|
|
592
|
-
this.ctx.lineJoin = 'miter';
|
|
593
|
-
}
|
|
538
|
+
this.renderTextStrokeWithStyle(text, styles);
|
|
594
539
|
break;
|
|
595
540
|
}
|
|
596
541
|
}
|
|
@@ -599,4 +544,3 @@ class TextRenderer {
|
|
|
599
544
|
}
|
|
600
545
|
}
|
|
601
546
|
exports.TextRenderer = TextRenderer;
|
|
602
|
-
//# sourceMappingURL=text-renderer.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.isClipPathEffect = exports.isOpacityEffect = exports.isClipEffect = exports.isTransformEffect = exports.ClipPathEffect = exports.OpacityEffect = exports.ClipEffect = exports.TransformEffect = void 0;
|
|
3
|
+
exports.isBlendEffect = exports.isClipPathEffect = exports.isOpacityEffect = exports.isClipEffect = exports.isTransformEffect = exports.BlendEffect = exports.ClipPathEffect = exports.OpacityEffect = exports.ClipEffect = exports.TransformEffect = void 0;
|
|
4
4
|
class TransformEffect {
|
|
5
5
|
constructor(offsetX, offsetY, matrix) {
|
|
6
6
|
this.offsetX = offsetX;
|
|
@@ -41,6 +41,14 @@ class ClipPathEffect {
|
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
exports.ClipPathEffect = ClipPathEffect;
|
|
44
|
+
class BlendEffect {
|
|
45
|
+
constructor(compositeOperation) {
|
|
46
|
+
this.compositeOperation = compositeOperation;
|
|
47
|
+
this.type = 4 /* EffectType.BLEND */;
|
|
48
|
+
this.target = 2 /* EffectTarget.BACKGROUND_BORDERS */ | 4 /* EffectTarget.CONTENT */;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
exports.BlendEffect = BlendEffect;
|
|
44
52
|
const isTransformEffect = (effect) => effect.type === 0 /* EffectType.TRANSFORM */;
|
|
45
53
|
exports.isTransformEffect = isTransformEffect;
|
|
46
54
|
const isClipEffect = (effect) => effect.type === 1 /* EffectType.CLIP */;
|
|
@@ -49,4 +57,5 @@ const isOpacityEffect = (effect) => effect.type === 2 /* EffectType.OPACITY */;
|
|
|
49
57
|
exports.isOpacityEffect = isOpacityEffect;
|
|
50
58
|
const isClipPathEffect = (effect) => effect.type === 3 /* EffectType.CLIP_PATH */;
|
|
51
59
|
exports.isClipPathEffect = isClipPathEffect;
|
|
52
|
-
|
|
60
|
+
const isBlendEffect = (effect) => effect.type === 4 /* EffectType.BLEND */;
|
|
61
|
+
exports.isBlendEffect = isBlendEffect;
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateObjectFitRendering = void 0;
|
|
4
|
+
const calculateObjectFitRendering = (intrinsicWidth, intrinsicHeight, box, objectFit) => {
|
|
5
|
+
let sx = 0;
|
|
6
|
+
let sy = 0;
|
|
7
|
+
let sw = intrinsicWidth;
|
|
8
|
+
let sh = intrinsicHeight;
|
|
9
|
+
let dx = box.left;
|
|
10
|
+
let dy = box.top;
|
|
11
|
+
let dw = box.width;
|
|
12
|
+
let dh = box.height;
|
|
13
|
+
const boxRatio = dw / dh;
|
|
14
|
+
const imgRatio = sw / sh;
|
|
15
|
+
if (objectFit === 2 /* OBJECT_FIT.CONTAIN */) {
|
|
16
|
+
if (imgRatio > boxRatio) {
|
|
17
|
+
dh = dw / imgRatio;
|
|
18
|
+
dy += (box.height - dh) / 2;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
dw = dh * imgRatio;
|
|
22
|
+
dx += (box.width - dw) / 2;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
else if (objectFit === 4 /* OBJECT_FIT.COVER */) {
|
|
26
|
+
if (imgRatio > boxRatio) {
|
|
27
|
+
sw = sh * boxRatio;
|
|
28
|
+
sx += (intrinsicWidth - sw) / 2;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
sh = sw / boxRatio;
|
|
32
|
+
sy += (intrinsicHeight - sh) / 2;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else if (objectFit === 8 /* OBJECT_FIT.NONE */) {
|
|
36
|
+
if (sw > dw) {
|
|
37
|
+
sx += (sw - dw) / 2;
|
|
38
|
+
sw = dw;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
dx += (dw - sw) / 2;
|
|
42
|
+
dw = sw;
|
|
43
|
+
}
|
|
44
|
+
if (sh > dh) {
|
|
45
|
+
sy += (sh - dh) / 2;
|
|
46
|
+
sh = dh;
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
dy += (dh - sh) / 2;
|
|
50
|
+
dh = sh;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
else if (objectFit === 16 /* OBJECT_FIT.SCALE_DOWN */) {
|
|
54
|
+
const containW = imgRatio > boxRatio ? dw : dh * imgRatio;
|
|
55
|
+
const noneW = sw > dw ? sw : dw;
|
|
56
|
+
if (containW < noneW) {
|
|
57
|
+
if (imgRatio > boxRatio) {
|
|
58
|
+
dh = dw / imgRatio;
|
|
59
|
+
dy += (box.height - dh) / 2;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
dw = dh * imgRatio;
|
|
63
|
+
dx += (box.width - dw) / 2;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
if (sw > dw) {
|
|
68
|
+
sx += (sw - dw) / 2;
|
|
69
|
+
sw = dw;
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
dx += (dw - sw) / 2;
|
|
73
|
+
dw = sw;
|
|
74
|
+
}
|
|
75
|
+
if (sh > dh) {
|
|
76
|
+
sy += (sh - dh) / 2;
|
|
77
|
+
sh = dh;
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
dy += (dh - sh) / 2;
|
|
81
|
+
dh = sh;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return { sx, sy, sw, sh, dx, dy, dw, dh };
|
|
86
|
+
};
|
|
87
|
+
exports.calculateObjectFitRendering = calculateObjectFitRendering;
|
package/dist/lib/render/path.js
CHANGED