Skip to content
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 3 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -1636,8 +1636,9 @@ The following image-specific constant options are also supported:
* **frameAnchor** - the [frame anchor](#frameanchor); defaults to *middle*
* **preserveAspectRatio** - the [aspect ratio](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/preserveAspectRatio); defaults to “xMidYMid meet”
* **crossOrigin** - the [cross-origin](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/crossorigin) behavior
* **imageRendering** - the [image-rendering attribute](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/image-rendering); defaults to *auto* (bilinear).

To crop the image instead of scaling it to fit, set **preserveAspectRatio** to “xMidYMid slice”.
To crop the image instead of scaling it to fit, set **preserveAspectRatio** to “xMidYMid slice”. The **imageRendering** option may be set to *pixelated* to disable bilinear interpolation on enlarged images; however, note that this is not supported in WebKit.

Images are drawn in input order, with the last data drawn on top. If sorting is needed, say to mitigate overplotting, consider a [sort and reverse transform](#transforms).

Expand Down Expand Up @@ -1834,7 +1835,7 @@ The following raster-specific constant options are supported:
* **imageRendering** - the [image-rendering attribute](https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/image-rendering); defaults to *auto* (bilinear)
* **blur** - a non-negative pixel radius for smoothing; defaults to 0

The **imageRendering** option may be sent to *pixelated* to disable bilinear interpolation for a sharper image; however, note that this is not supported in WebKit. The **interpolate** option is ignored when **fill** or **fillOpacity** is a function of *x* and *y*.
The **imageRendering** option may be set to *pixelated* to disable bilinear interpolation for a sharper image; however, note that this is not supported in WebKit. The **interpolate** option is ignored when **fill** or **fillOpacity** is a function of *x* and *y*.

#### Plot.raster(*data*, *options*)

Expand Down
4 changes: 3 additions & 1 deletion src/marks/image.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ function maybePathChannel(value) {

export class Image extends Mark {
constructor(data, options = {}) {
let {x, y, width, height, src, preserveAspectRatio, crossOrigin, frameAnchor} = options;
let {x, y, width, height, src, preserveAspectRatio, crossOrigin, frameAnchor, imageRendering} = options;
if (width === undefined && height !== undefined) width = height;
else if (height === undefined && width !== undefined) height = width;
const [vs, cs] = maybePathChannel(src);
Expand All @@ -64,6 +64,7 @@ export class Image extends Mark {
this.preserveAspectRatio = impliedString(preserveAspectRatio, "xMidYMid");
this.crossOrigin = string(crossOrigin);
this.frameAnchor = maybeFrameAnchor(frameAnchor);
this.imageRendering = impliedString(imageRendering, "auto");
}
render(index, scales, channels, dimensions, context) {
const {x, y} = scales;
Expand Down Expand Up @@ -104,6 +105,7 @@ export class Image extends Mark {
.call(applyAttr, "href", S ? (i) => S[i] : this.src)
.call(applyAttr, "preserveAspectRatio", this.preserveAspectRatio)
.call(applyAttr, "crossorigin", this.crossOrigin)
.call(applyAttr, "image-rendering", this.imageRendering)
.call(applyChannelStyles, this, channels)
)
.node();
Expand Down
19 changes: 19 additions & 0 deletions test/output/imagePixelated.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
11 changes: 11 additions & 0 deletions test/plots/image-rendering.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import * as Plot from "@observablehq/plot";

export async function imagePixelated() {
return Plot.image([0], {
frameAnchor: "middle",
src: "",
width: 300,
height: 200,
imageRendering: "pixelated"
}).plot({width: 300, height: 200});
}
1 change: 1 addition & 0 deletions test/plots/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -289,6 +289,7 @@ export * from "./federal-funds.js";
export * from "./frame.js";
export * from "./function-contour.js";
export * from "./heatmap.js";
export * from "./image-rendering.js";
export * from "./legend-color.js";
export * from "./legend-opacity.js";
export * from "./legend-symbol.js";
Expand Down