mirror of
https://github.com/niklasvh/html2canvas.git
synced 2023-08-10 21:13:10 +03:00
added support for background-origin: content-box, fixed background-origin related background sizes
This commit is contained in:
parent
bb09a5fc0f
commit
9673adfd59
@ -27,6 +27,7 @@ import {
|
|||||||
calculatePaddingBox,
|
calculatePaddingBox,
|
||||||
calculatePaddingBoxPath
|
calculatePaddingBoxPath
|
||||||
} from './Bounds';
|
} 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';
|
||||||
@ -223,14 +224,35 @@ export default class Renderer {
|
|||||||
if (image) {
|
if (image) {
|
||||||
const bounds = container.bounds;
|
const bounds = container.bounds;
|
||||||
const paddingBox = calculatePaddingBox(bounds, container.style.border);
|
const paddingBox = calculatePaddingBox(bounds, container.style.border);
|
||||||
const backgroundImageSize = calculateBackgroundSize(background, image, bounds);
|
|
||||||
|
|
||||||
// TODO support CONTENT_BOX
|
let backgroundPositioningArea;
|
||||||
const backgroundPositioningArea =
|
switch (container.style.background.backgroundOrigin) {
|
||||||
container.style.background.backgroundOrigin === BACKGROUND_ORIGIN.BORDER_BOX
|
case BACKGROUND_ORIGIN.BORDER_BOX:
|
||||||
? bounds
|
backgroundPositioningArea = bounds;
|
||||||
: paddingBox;
|
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(
|
||||||
|
background,
|
||||||
|
image,
|
||||||
|
backgroundPositioningArea
|
||||||
|
);
|
||||||
const position = calculateBackgroundPosition(
|
const position = calculateBackgroundPosition(
|
||||||
background.position,
|
background.position,
|
||||||
backgroundImageSize,
|
backgroundImageSize,
|
||||||
@ -244,8 +266,8 @@ export default class Renderer {
|
|||||||
bounds
|
bounds
|
||||||
);
|
);
|
||||||
|
|
||||||
const offsetX = Math.round(paddingBox.left + position.x);
|
const offsetX = Math.round(backgroundPositioningArea.left + position.x);
|
||||||
const offsetY = Math.round(paddingBox.top + position.y);
|
const offsetY = Math.round(backgroundPositioningArea.top + position.y);
|
||||||
this.target.renderRepeat(path, image, backgroundImageSize, offsetX, offsetY);
|
this.target.renderRepeat(path, image, backgroundImageSize, offsetX, offsetY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,13 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
import Length from '../Length';
|
import Length from '../Length';
|
||||||
|
|
||||||
|
export const PADDING_SIDES = {
|
||||||
|
TOP: 0,
|
||||||
|
RIGHT: 1,
|
||||||
|
BOTTOM: 2,
|
||||||
|
LEFT: 3
|
||||||
|
};
|
||||||
|
|
||||||
const SIDES = ['top', 'right', 'bottom', 'left'];
|
const SIDES = ['top', 'right', 'bottom', 'left'];
|
||||||
|
|
||||||
export type Padding = Array<Length>;
|
export type Padding = Array<Length>;
|
||||||
|
33
tests/reftests/background/origin.html
Normal file
33
tests/reftests/background/origin.html
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<!doctype html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<style>
|
||||||
|
div {
|
||||||
|
display: inline-block;
|
||||||
|
width: 100px;
|
||||||
|
height: 100px;
|
||||||
|
border: 15px solid blue;
|
||||||
|
padding: 10px;
|
||||||
|
margin: 5px;
|
||||||
|
background-image: url('');
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: content-box"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: padding-box"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: border-box"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: content-box; background-size: cover"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: padding-box; background-size: cover"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: border-box; background-size: cover"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: content-box; background-size: contain"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: padding-box; background-size: contain"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: border-box; background-size: contain"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: content-box; background-position: 15px 20px"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: padding-box; background-position: 15px 20px"></div>
|
||||||
|
<div style="background-repeat: no-repeat; background-origin: border-box; background-position: 15px 20px"></div>
|
||||||
|
<div style="background-repeat: repeat; background-origin: content-box"></div>
|
||||||
|
<div style="background-repeat: repeat; background-origin: padding-box"></div>
|
||||||
|
<div style="background-repeat: repeat; background-origin: border-box"></div>
|
||||||
|
</body>
|
||||||
|
</html>
|
Loading…
x
Reference in New Issue
Block a user