[]
        
(Showing Draft Content)

Fill Effects

SpreadJS allows you to add fill effects in shapes in order to enhance their appearance by creating different UI effects.

Solid Fill

You can apply a solid fill to shapes by using ShapeFillType enumeration. It provides solid and none values which create the below fill effects:




The following code example applies solid and no fill to shapes.

// Add a shape with solid fill
var shape1 = activeSheet.shapes.add("myShape1", GC.Spread.Sheets.Shapes.AutoShapeType.diamond, 200, 50, 150, 150);
var style = shape1.style();
style.fill = { type: GC.Spread.Sheets.Shapes.ShapeFillType.solid, color: 'red'};
shape1.style(style);

// Add a shape with no fill
var shape2 = activeSheet.shapes.add("myShape1", GC.Spread.Sheets.Shapes.AutoShapeType.diamond, 400, 50, 150, 150);
var style = shape2.style();
style.fill = { type: GC.Spread.Sheets.Shapes.ShapeFillType.none };
shape2.style(style);

Gradient Fill

You can apply a gradient fill to shapes that provide a 3D color look by creating color blending effects. The start position of every color can be specified in the stops property and the brightness and transparency ratio of colors can be set as well.


SpreadJS provides two types of gradient fills:

  • Linear gradient: Fills the shape defined by the direction or angle. If direction and angle, both are mentioned, direction takes precedence.



  • Radial gradient: Fills the shape defined by the direction of the center point.



The linear or radial values of GradientFillType enumeration can be used to set the type of gradient fill in shapes. The direction of gradients can be set by using LinearGradientFillDirection or RadialGradientFillDirection enumerations.


The following example code applies linear and radial gradient fill to the four shapes as shown in the above image.

// Add linear fill specified by direction
addStyles(sheet.shapes.get('shape1'),
{   type: GC.Spread.Sheets.Shapes.GradientFillType.linear,
    direction: GC.Spread.Sheets.Shapes.LinearGradientFillDirection.linearRight,
    stops: [{color: 'pink', position: 0}, {color: 'blue', position: 1}]
});

// Add linear fill specified by angle
addStyles(sheet.shapes.get('shape2'),
{   type: GC.Spread.Sheets.Shapes.GradientFillType.linear,
    angle: 60,
    stops: [{color: 'yellow', position: 0, transparency: 0.3},
    {color: 'green', position: 0.5, transparency: 0.5},
    {color: 'blue', position: 1, transparency: 0.8, brightness: 0.2}]
});

// Add radial fill specified by center direction
addStyles(sheet.shapes.get('shape3'),
{   type: GC.Spread.Sheets.Shapes.GradientFillType.radial,
    direction: GC.Spread.Sheets.Shapes.RadialGradientFillDirection.fromCenter,
    stops: [{color: 'blue', position: 0}, {color: 'pink', position: 1}]
});

// Add radial fill specified by bottom right direction
addStyles(sheet.shapes.get('shape4'),
{   type: GC.Spread.Sheets.Shapes.GradientFillType.radial,
    direction: GC.Spread.Sheets.Shapes.RadialGradientFillDirection.fromBottomRight,
    stops: [{color: 'yellow', position: 0}, {color: 'green', position: 1}]
});

function addStyles(shapeName, fillType) {
    var style = shapeName.style();
    style.fill = fillType;
    shapeName.style(style);
}

Picture Fill

You can add pictures in shapes by setting the image source as a base64 string. The transparency and offset properties (left, right, top, bottom) can also be set by using the fill options of the IShapePictureFillOption interface.




The following example code adds an image in a shape and sets its transparency.

var shapechart = "";

var GCshape = sheet.shapes.add("myShape1", GC.Spread.Sheets.Shapes.AutoShapeType.rectangle, 20, 50, 400, 300);

// Picture fill style
var stylePic = GCshape.style();
stylePic.fill = { src: shapechart, transparency: 0.2};
GCshape.style(stylePic);

Texture Fill

You can apply texture fill to shapes by adding a picture as texture in a shape. The tilePictureAsTexture property of the IShapeTextureFillOption interface should be set to true so that the picture behaves as a texture. The transparency, offset, scale, alignment, and mirror type properties can also be set by using the fill options of the IShapeTextureFillOption interface.




The following example code adds a picture as texture in a shape.

var grapecityImg = "";

var GCshape2 = sheet.shapes.add("myShape2", GC.Spread.Sheets.Shapes.AutoShapeType.rectangle, 450, 50, 450, 300);

// Texture fill style
var styleTexture = GCshape2.style();
styleTexture.fill = { src: grapecityImg, tilePictureAsTexture: true, 
                    transparency: 0.7, 
                    scaleX: 0.8, 
                    scaleY: 0.8, 
                    alignment: GC.Spread.Sheets.Shapes.TextureFillAlignment.left
                };
GCshape2.style(styleTexture);

Limitations of Picture and Texture fill

  • SpreadJS only supports adding pictures with base64 format.

  • SVG images must have specified dimensions (width and height), for example:

    <svg width="5cm" height="5cm" />

  • Transparency property is not supported while exporting to PDF.

  • While exporting to Excel, the DPI of the picture should be 96 otherwise, the texture filling effects will be inconsistent.