diff --git a/whalesong/image/private/js-impl.js b/whalesong/image/private/js-impl.js index 3abe457..9b05471 100644 --- a/whalesong/image/private/js-impl.js +++ b/whalesong/image/private/js-impl.js @@ -683,12 +683,14 @@ EXPORTS['above/align'] = EXPORTS['empty-scene'] = makePrimitiveProcedure( 'empty-scene', - 2, + plt.baselib.lists.makeList(2, 3), function(MACHINE) { var width = checkNonNegativeReal(MACHINE, 'empty-scene', 0); var height = checkNonNegativeReal(MACHINE, 'empty-scene', 1); - return makeSceneImage(jsnums.toFixnum(width), + var color = (MACHINE.a===3)? checkColor(MACHINE, 'empty-scene', 2) : null; + return makeSceneImage(jsnums.toFixnum(width), jsnums.toFixnum(height), + color, [], true); }); diff --git a/whalesong/image/private/kernel.js b/whalesong/image/private/kernel.js index f465d14..fc2f756 100644 --- a/whalesong/image/private/kernel.js +++ b/whalesong/image/private/kernel.js @@ -288,13 +288,14 @@ var isScene = function(x) { ////////////////////////////////////////////////////////////////////// -// SceneImage: primitive-number primitive-number (listof image) -> Scene -var SceneImage = function(width, height, children, withBorder) { +// SceneImage: primitive-number primitive-number color (listof image) -> Scene +var SceneImage = function(width, height, color, children, withBorder) { BaseImage.call(this); this.width = width; this.height = height; this.children = children; // arrayof [image, number, number] this.withBorder = withBorder; + this.color = color; }; SceneImage.prototype = heir(BaseImage.prototype); @@ -314,7 +315,8 @@ SceneImage.prototype.render = function(ctx, x, y) { var childImage, childX, childY; // create a clipping region around the boundaries of the Scene ctx.save(); - ctx.fillStyle = "rgba(0,0,0,0)"; + // if no color is defined, default to transparent + ctx.fillStyle = this.color? colorString(this.color) : "rgba(0,0,0,0)"; ctx.fillRect(x, y, this.width, this.height); ctx.restore(); // save the context, reset the path, and clip to the path around the scene edge