Fix tests and refactor background calculations out from Renderer

This commit is contained in:
Niklas von Hertzen 2017-12-09 17:45:58 +08:00
parent 850338a76a
commit a6a3c1bd0f
4 changed files with 52 additions and 41 deletions

View File

@ -1,6 +1,8 @@
### Changelog ### ### Changelog ###
#### v1.0.0-alpha3 - TBD #### #### v1.0.0-alpha3 - TBD ####
* Fix background-size when using background-origin and background-size: cover/contain (#1299)
* Added support for background-origin: content-box (#1299)
#### v1.0.0-alpha2 - 7.12.2017 #### #### v1.0.0-alpha2 - 7.12.2017 ####
* Fix scroll positions for CanvasRenderer (#1259) * Fix scroll positions for CanvasRenderer (#1259)

View File

@ -20,20 +20,13 @@ import type NodeContainer from './NodeContainer';
import type StackingContext from './StackingContext'; import type StackingContext from './StackingContext';
import type {TextBounds} from './TextBounds'; import type {TextBounds} from './TextBounds';
import { import {Bounds, parsePathForBorder, calculateContentBox, calculatePaddingBoxPath} from './Bounds';
Bounds,
parsePathForBorder,
calculateContentBox,
calculatePaddingBox,
calculatePaddingBoxPath
} from './Bounds';
import {PADDING_SIDES} from './parsing/padding';
import {FontMetrics} from './Font'; import {FontMetrics} from './Font';
import {parseGradient} from './Gradient'; import {parseGradient} from './Gradient';
import TextContainer from './TextContainer'; import TextContainer from './TextContainer';
import { import {
BACKGROUND_ORIGIN, calculateBackgroungPositioningArea,
calculateBackgroungPaintingArea, calculateBackgroungPaintingArea,
calculateBackgroundPosition, calculateBackgroundPosition,
calculateBackgroundRepeatPath, calculateBackgroundRepeatPath,
@ -222,32 +215,12 @@ export default class Renderer {
renderBackgroundRepeat(container: NodeContainer, background: BackgroundImage) { renderBackgroundRepeat(container: NodeContainer, background: BackgroundImage) {
const image = this.options.imageStore.get(background.source.args[0]); const image = this.options.imageStore.get(background.source.args[0]);
if (image) { if (image) {
const bounds = container.bounds; const backgroundPositioningArea = calculateBackgroungPositioningArea(
const paddingBox = calculatePaddingBox(bounds, container.style.border); container.style.background.backgroundOrigin,
container.bounds,
let backgroundPositioningArea; container.style.padding,
switch (container.style.background.backgroundOrigin) { container.style.border
case BACKGROUND_ORIGIN.BORDER_BOX:
backgroundPositioningArea = bounds;
break;
case BACKGROUND_ORIGIN.CONTENT_BOX:
const paddingLeft = container.style.padding[PADDING_SIDES.LEFT].value;
const paddingRight = container.style.padding[PADDING_SIDES.RIGHT].value;
const paddingTop = container.style.padding[PADDING_SIDES.TOP].value;
const paddingBottom = container.style.padding[PADDING_SIDES.BOTTOM].value;
backgroundPositioningArea = new Bounds(
paddingBox.left + paddingLeft,
paddingBox.top + paddingTop,
paddingBox.width - paddingLeft - paddingRight,
paddingBox.height - paddingTop - paddingBottom
); );
break;
case BACKGROUND_ORIGIN.PADDING_BOX:
default:
backgroundPositioningArea = paddingBox;
break;
}
const backgroundImageSize = calculateBackgroundSize( const backgroundImageSize = calculateBackgroundSize(
background, background,
image, image,
@ -263,7 +236,7 @@ export default class Renderer {
position, position,
backgroundImageSize, backgroundImageSize,
backgroundPositioningArea, backgroundPositioningArea,
bounds container.bounds
); );
const offsetX = Math.round(backgroundPositioningArea.left + position.x); const offsetX = Math.round(backgroundPositioningArea.left + position.x);

View File

@ -1,14 +1,22 @@
/* @flow */ /* @flow */
'use strict'; 'use strict';
import type {Path} from '../drawing/Path'; import type {Path} from '../drawing/Path';
import type {Bounds, BoundCurves} from '../Bounds'; import type {BoundCurves} from '../Bounds';
import type ResourceLoader, {ImageElement} from '../ResourceLoader'; import type ResourceLoader, {ImageElement} from '../ResourceLoader';
import type {Border} from './border';
import type {Padding} from './padding';
import Color from '../Color'; import Color from '../Color';
import Length from '../Length'; import Length from '../Length';
import Size from '../drawing/Size'; import Size from '../drawing/Size';
import Vector from '../drawing/Vector'; import Vector from '../drawing/Vector';
import {calculateBorderBoxPath, calculatePaddingBoxPath} from '../Bounds'; import {
calculateBorderBoxPath,
calculatePaddingBoxPath,
calculatePaddingBox,
Bounds
} from '../Bounds';
import {PADDING_SIDES} from './padding';
export type Background = { export type Background = {
backgroundImage: Array<BackgroundImage>, backgroundImage: Array<BackgroundImage>,
@ -121,7 +129,6 @@ export const calculateBackgroungPaintingArea = (
curves: BoundCurves, curves: BoundCurves,
clip: BackgroundClip clip: BackgroundClip
): Path => { ): Path => {
// TODO support CONTENT_BOX
switch (clip) { switch (clip) {
case BACKGROUND_CLIP.BORDER_BOX: case BACKGROUND_CLIP.BORDER_BOX:
return calculateBorderBoxPath(curves); return calculateBorderBoxPath(curves);
@ -131,6 +138,34 @@ export const calculateBackgroungPaintingArea = (
} }
}; };
export const calculateBackgroungPositioningArea = (
backgroundOrigin: BackgroundOrigin,
bounds: Bounds,
padding: Padding,
border: Array<Border>
): Bounds => {
const paddingBox = calculatePaddingBox(bounds, border);
switch (backgroundOrigin) {
case BACKGROUND_ORIGIN.BORDER_BOX:
return bounds;
case BACKGROUND_ORIGIN.CONTENT_BOX:
const paddingLeft = padding[PADDING_SIDES.LEFT].getAbsoluteValue(bounds.width);
const paddingRight = padding[PADDING_SIDES.RIGHT].getAbsoluteValue(bounds.width);
const paddingTop = padding[PADDING_SIDES.TOP].getAbsoluteValue(bounds.width);
const paddingBottom = padding[PADDING_SIDES.BOTTOM].getAbsoluteValue(bounds.width);
return new Bounds(
paddingBox.left + paddingLeft,
paddingBox.top + paddingTop,
paddingBox.width - paddingLeft - paddingRight,
paddingBox.height - paddingTop - paddingBottom
);
case BACKGROUND_ORIGIN.PADDING_BOX:
default:
return paddingBox;
}
};
export const calculateBackgroundPosition = ( export const calculateBackgroundPosition = (
position: [Length, Length], position: [Length, Length],
size: Size, size: Size,

View File

@ -1,6 +1,7 @@
<!doctype html> <!doctype html>
<html> <html>
<head> <head>
<script type="text/javascript" src="../../test.js"></script>
<style> <style>
div { div {
display: inline-block; display: inline-block;
@ -9,7 +10,7 @@
border: 15px solid blue; border: 15px solid blue;
padding: 10px; padding: 10px;
margin: 5px; margin: 5px;
background-image: url(''); background-image: url(../../assets/image.jpg);
} }
</style> </style>
</head> </head>