그림 셰이프

그림 셰이프는 그림을 표시할 수 있는 셰이프입니다. 자르고 조정할 수 있으며 다른 셰이프와 함께 그림을 그룹화하거나 연결할 수 있습니다.

설명
app.jsx
app-func.jsx
app-class.jsx
index.html
styles.css

다음 샘플은 그림 셰이프를 추가하는 방법을 보여 줍니다.

    // When adding a picture, the picture's source can be a base64 image or url.
    var picture = sheet.shapes.addPictureShape("pic1", "./test.png", 100, 100, 200, 200);

다음 예시는 그림의 투명도를 변경하는 방법을 보여 줍니다.

    // Set the transparency of the picture to 0.5
    picture.pictureFormat({ transparency: 0.5 });

다음 예시는 그림을 자르는 방법을 보여 줍니다.

    picture.pictureFormat({
        crop: {
            left: 0.15, // The left 15% of the image will be cropped
            right: 0.15, // The right 15% of the image will be cropped
            top: 0.2, // The top 20% of the image will be cropped
            bottom: 0.2 // The bottom 20% of the image will be cropped
        }
    });

다음 예시는 그림의 밝기 및 대비를 설정하는 방법을 보여 줍니다.

    // Set the brightness and contrast of the picture
    picture.pictureFormat({ brightness: 0.4, contrast: -0.4 });

다음 예시는 그림을 다시 칠하는 방법을 보여 줍니다.

    // Set the grayscale effect
    picture.pictureFormat({ grayscale: true });

    // Set blackAndWhite effect
    // Pixels with brightness greater than or equal to 0.5 are white, otherwise black
    picture.pictureFormat({ blackAndWhite: 0.5 });

    // Set the duotone effect
    picture.pictureFormat({ duotone: { color1: 'black', color2: 'red' } });

다음 예시는 그림의 기하 도형 유형을 변경하는 방법을 보여 줍니다.

    // Change the geometry type of the picture to oval
    picture.geometryType(GC.Spread.Sheets.Shapes.AutoShapeType.oval);

    // Change the geometry type of the picture to roundedRectangle
    picture.geometryType(GC.Spread.Sheets.Shapes.AutoShapeType.roundedRectangle)

다음 예시는 그림의 테두리를 설정하는 방법을 보여 줍니다.

    var style = picture.style();
    style.line.color = 'red';
    style.line.lineStyle = GC.Spread.Sheets.Shapes.PresetLineDashStyle.dashDot;
    style.line.width = 4;
    style.line.capType = GC.Spread.Sheets.Shapes.LineCapStyle.square;
    style.line.joinType = GC.Spread.Sheets.Shapes.LineJoinStyle.miter;
    picture.style(style);

그림의 일부가 투명하면 그림의 배경색을 설정할 수 있습니다.

    let style = picture.style();
    style.fill = { type: GC.Spread.Sheets.Shapes.ShapeFillType.solid, color: 'blue' };
    picture.style(style);
다음 샘플은 그림 셰이프를 추가하는 방법을 보여 줍니다. 다음 예시는 그림의 투명도를 변경하는 방법을 보여 줍니다. 다음 예시는 그림을 자르는 방법을 보여 줍니다. 다음 예시는 그림의 밝기 및 대비를 설정하는 방법을 보여 줍니다. 다음 예시는 그림을 다시 칠하는 방법을 보여 줍니다. 다음 예시는 그림의 기하 도형 유형을 변경하는 방법을 보여 줍니다. 다음 예시는 그림의 테두리를 설정하는 방법을 보여 줍니다. 그림의 일부가 투명하면 그림의 배경색을 설정할 수 있습니다.
import * as React from 'react'; import * as ReactDOM from 'react-dom'; import './styles.css'; import { AppFunc } from './app-func'; // import { App } from './app-class'; // 1. Functional Component sample ReactDOM.render(<AppFunc />, document.getElementById('app')); // 2. Class Component sample // ReactDOM.render(<App />, document.getElementById('app'));
import * as React from 'react'; import GC from '@mescius/spread-sheets'; import "@mescius/spread-sheets-shapes"; import { SpreadSheets } from "@mescius/spread-sheets-react"; import '@mescius/spread-sheets-resources-ko'; GC.Spread.Common.CultureManager.culture("ko-kr"); let spread = null; let sheet = null; export function AppFunc() { const [pictureShapeOption, setPictureShapeOption] = React.useState({ active: false, isShow: false, geometryType: 1, crop: { left: 0, right: 0, top: 0, bottom: 0 }, transparency: 0, brightness: 0, contrast: 0, recolorType: 'none', blackAndWhite: 0.5, duotoneColor1: '#000000', duotoneColor2: '#FF0000', backgroundColor: '', borderColor: '', borderWidth: -1 }); const initSpread = (currSpread) => { spread = currSpread; sheet = spread.getActiveSheet(); sheet.bind(GC.Spread.Sheets.Events.ShapeSelectionChanged, shapeSelectionChangedHandler); addDefaultShape(); } const addDefaultShape = () => { var splogoImg = ""; var foodImg = ""; var pic1 = sheet.shapes.addPictureShape('pic1', splogoImg, 80, 80, 150, 150); var pic2 = sheet.shapes.addPictureShape('pic2', splogoImg, 310, 80, 150, 150); var pic3 = sheet.shapes.addPictureShape('pic3', splogoImg, 540, 80, 150, 150); var pic4 = sheet.shapes.addPictureShape('pic4', foodImg, 80, 300, 285, 180); var pic5 = sheet.shapes.addPictureShape('pic5', foodImg, 420, 300, 285, 180); pic1.isSelected(true); // set pic2 style var style = pic2.style(); style.fill = { type: 1, color: '#666666' }; pic2.style(style); // set pic3 geometry type pic3.geometryType(GC.Spread.Sheets.Shapes.AutoShapeType.roundedRectangle); // set pic3 style var style = pic3.style(); style.fill = { type: 1, color: '#666666' }; pic3.style(style); // set pic5 duotone effect pic5.pictureFormat({ duotone: { color1: 'black', color2: 'rgb(150, 242, 21)' } }); } const shapeSelectionChangedHandler = () => { var pictures = getSelectedPictures(); var active = pictures.length === 1; if (active) { syncState(pictures[0]); } } const syncState = (pic) => { let geometryType = pic.geometryType(); let format = pic.pictureFormat(); let style = pic.style(); let newState = { ...pictureShapeOption, geometryType, crop: format.crop, transparency: format.transparency, brightness: format.brightness, contrast: format.contrast, recolorType: 'none', isShow: false, active: true }; if (format.grayscale) { newState.recolorType = 'gray-scale'; } else if (format.blackAndWhite !== undefined) { newState.recolorType = 'black-and-white'; newState.blackAndWhite = format.blackAndWhite; } else if (format.duotone) { newState.recolorType = 'duotone'; newState.isShow = true; newState.duotoneColor1 = rgbToHex(format.duotone.color1); newState.duotoneColor2 = rgbToHex(format.duotone.color2); } newState.backgroundColor = rgbToHex(style.fill.color); newState.borderColor = rgbToHex(style.line.color); newState.borderWidth = style.line.width; setPictureShapeOption(newState); } const onImgChange = (e) => { var blob = e.target.files[0]; var fileReader = new FileReader(); fileReader.addEventListener('load', function () { getFirstSelectedPicture().src(fileReader.result); }); fileReader.readAsDataURL(blob); } const onGeometryTypeChange = (e) => { let value = Number(e.target.value); setPictureShapeOption({ ...pictureShapeOption, geometryType: value }); getFirstSelectedPicture().geometryType(value); } const onCropPropChange = (e, propName) => { let value = Number(e.target.value); let crop = JSON.parse(JSON.stringify(pictureShapeOption.crop)); crop[propName] = value; setPictureShapeOption({ ...pictureShapeOption, crop }); let pic = getFirstSelectedPicture(); var format = pic.pictureFormat(); format.crop = crop; pic.pictureFormat(format); } const onPictureFormatChange = (e, propName) => { let value = e.target.value; let numberValue = Number(value); let pic = getFirstSelectedPicture(); var format = pic.pictureFormat(); if (propName === 'transparency') { format.transparency = numberValue; } else if (propName === 'brightness') { format.brightness = numberValue; } else if (propName === 'contrast') { format.contrast = numberValue; } else if (propName === 'recolorType') { clearRecolorAndBrightnessContrast(format); if (value === 'gray-scale') { format.grayscale = true; } else if (value === 'black-and-white') { format.blackAndWhite = pictureShapeOption.blackAndWhite; } else if (value === 'duotone') { format.duotone = { color1: pictureShapeOption.duotoneColor1, color2: pictureShapeOption.duotoneColor2 } } } else if (propName === 'blackAndWhite') { clearRecolorAndBrightnessContrast(format); format.blackAndWhite = numberValue; } else if (propName === 'duotoneColor1') { clearRecolorAndBrightnessContrast(format); format.duotone = { color1: value, color2: pictureShapeOption.duotoneColor2 } } else if (propName === 'duotoneColor2') { clearRecolorAndBrightnessContrast(format); format.duotone = { color1: pictureShapeOption.duotoneColor1, color2: value } } pic.pictureFormat(format); syncState(pic); } const clearRecolorAndBrightnessContrast = (format) => { format.grayscale = false; format.blackAndWhite = undefined; format.duotone = undefined; format.brightness = 0; format.contrast = 0; } const onBackgroundColorChange = (e) => { let value = e.target.value; setPictureShapeOption({ ...pictureShapeOption, backgroundColor: value }); var picture = getFirstSelectedPicture(); var style = picture.style(); style.fill = { type: 1, color: value, transparency: 0 }; picture.style(style); } const onBorderColorChange = (e) => { let value = e.target.value; setPictureShapeOption({ ...pictureShapeOption, borderColor: value }); var picture = getFirstSelectedPicture(); var style = picture.style(); style.line.color = value; picture.style(style); } const onBorderWidthChange = (e) => { let value = Number(e.target.value); setPictureShapeOption({ ...pictureShapeOption, borderWidth: value }); var picture = getFirstSelectedPicture(); var style = picture.style(); style.line.color = pictureShapeOption.borderColor; style.line.width = value; picture.style(style); } const getSelectedPictures = () => { var pictures = []; var shapes = sheet.shapes.all(); for (var i = 0; i < shapes.length; i++) { var shape = shapes[i]; if (shape.isSelected() && shape instanceof GC.Spread.Sheets.Shapes.PictureShape) { pictures.push(shape); } } return pictures; } const rgbToHex = (color) => { let rgb = color.match(/rgb\((\d+),(\d+),(\d+)\)/); if (!rgb || rgb.length < 4) { return '#000000'; } return '#' + rgb.slice(1, 4).map(function (v) { let hex = Number(v).toString(16); return hex.length === 1 ? "0" + hex : hex; }).join(''); } const getFirstSelectedPicture = () => { return getSelectedPictures()[0]; } const tipEl = <div class="options-container">Try selecting a shape.</div>; let duotone; if (pictureShapeOption.isShow) { duotone = <div> <div class="option-row"> <label>Duotone Color1</label><input class="duotone-color1" type="color" value={pictureShapeOption.duotoneColor1} onChange={(e) => onPictureFormatChange(e, 'duotoneColor1')}></input> </div> <div class="option-row"> <label>Duotone Color2</label><input class="duotone-color2" type="color" value={pictureShapeOption.duotoneColor2} onChange={(e) => onPictureFormatChange(e, 'duotoneColor2')}></input> </div> </div> } const picturePropEl = <div class="options-container"> <h3>Picture Format</h3> <div class="option-row"> <label>Image</label><input class="img" type="file" accept="image/*" onChange={onImgChange}></input> </div> <div class="option-row"> <label>Geometry Type</label> <select class="geometry-type" value={pictureShapeOption.geometryType} onChange={onGeometryTypeChange}> <option value="1">rectangle</option> <option value="5">rounded rectangle</option> <option value="9">oval</option> <option value="21">heart</option> <option value="178">cloud</option> </select> </div> <div class="option-row"> <label>Transparency</label><input class="transparency" type="number" min="0" max="1" step="0.01" value={pictureShapeOption.transparency} onChange={(e) => onPictureFormatChange(e, 'transparency')}></input> </div> <div class="divide-line"></div> <details> <summary>Crop</summary> <div class="option-row"> <label>Crop Left</label><input class="crop-left" type="number" max="0.99" step="0.01" value={pictureShapeOption.crop.left} onChange={(e) => onCropPropChange(e, 'left')}></input> </div> <div class="option-row"> <label>Crop Right</label><input class="crop-right" type="number" max="0.99" step="0.01" value={pictureShapeOption.crop.right} onChange={(e) => onCropPropChange(e, 'right')}></input> </div> <div class="option-row"> <label>Crop Top</label><input class="crop-top" type="number" max="0.99" step="0.01" value={pictureShapeOption.crop.top} onChange={(e) => onCropPropChange(e, 'top')}></input> </div> <div class="option-row"> <label>Crop Bottom</label><input class="crop-bottom" type="number" max="0.99" step="0.01" value={pictureShapeOption.crop.bottom} onChange={(e) => onCropPropChange(e, 'bottom')}></input> </div> </details> <div class="divide-line"></div> <details> <summary>Brightness/Contrast</summary> <div class="option-row"> <label>Brightness</label><input class="brightness" type="number" min="-1" max="1" step="0.01" value={pictureShapeOption.brightness} onChange={(e) => onPictureFormatChange(e, 'brightness')}></input> </div> <div class="option-row"> <label>Contrast</label><input class="contrast" type="number" min="-1" max="1" step="0.01" value={pictureShapeOption.contrast} onChange={(e) => onPictureFormatChange(e, 'contrast')}></input> </div> </details> <div class="divide-line"></div> <details> <summary>Recolor</summary> <div class="option-row"> <label>Recolor Type</label> <select class="recolor-type" value={pictureShapeOption.recolorType} onChange={(e) => onPictureFormatChange(e, 'recolorType')}> <option value="none">none</option> <option value="gray-scale">grayscale</option> <option value="black-and-white">blackAndWhite</option> <option value="duotone">duotone</option> </select> </div> <div class="option-row"> <label>BlackAndWhite</label><input class="black-and-white" type="number" min="0" max="1" step="0.05" value={pictureShapeOption.blackAndWhite} onChange={(e) => onPictureFormatChange(e, 'blackAndWhite')}></input> </div> {duotone} </details> <div class="divide-line"></div> <details> <summary>Style</summary> <div class="option-row"> <label>Background Color</label><input class="background-color" type="color" value={pictureShapeOption.backgroundColor} onChange={onBackgroundColorChange}></input> </div> <div class="option-row"> <label>Border Color</label><input class="border-color" type="color" value={pictureShapeOption.borderColor} onChange={onBorderColorChange}></input> </div> <div class="option-row"> <label>Border Width</label><input class="border-width" type="number" min="-1" step="1" value={pictureShapeOption.borderWidth} onChange={onBorderWidthChange}></input> </div> </details> </div>; return ( <div class="sample-tutorial"> <div id="ss" class="sample-spreadsheets"> <SpreadSheets workbookInitialized={spread => initSpread(spread)}> </SpreadSheets> </div> {pictureShapeOption.active ? picturePropEl : tipEl} </div> ); }
import * as React from 'react'; import GC from '@mescius/spread-sheets'; import "@mescius/spread-sheets-shapes"; import { SpreadSheets } from "@mescius/spread-sheets-react"; import '@mescius/spread-sheets-resources-ko'; GC.Spread.Common.CultureManager.culture("ko-kr"); const Component = React.Component; export class App extends Component { constructor(props) { super(props); this.spread = null; this.state = { active: false, isShow: false, geometryType: 1, crop: { left: 0, right: 0, top: 0, bottom: 0 }, transparency: 0, brightness: 0, contrast: 0, recolorType: 'none', blackAndWhite: 0.5, duotoneColor1: '#000000', duotoneColor2: '#FF0000', backgroundColor: '', borderColor: '', borderWidth: -1 } this.shapeSelectionChangedHandler = this.shapeSelectionChangedHandler.bind(this); this.onImgChange = this.onImgChange.bind(this); this.onGeometryTypeChange = this.onGeometryTypeChange.bind(this); this.onCropPropChange = this.onCropPropChange.bind(this); this.onPictureFormatChange = this.onPictureFormatChange.bind(this); this.onBackgroundColorChange = this.onBackgroundColorChange.bind(this); this.onBorderColorChange = this.onBorderColorChange.bind(this); this.onBorderWidthChange = this.onBorderWidthChange.bind(this); } render() { const tipEl = <div class="options-container">Try selecting a shape.</div>; let duotone; if (this.state.isShow) { duotone = <div> <div class="option-row"> <label>Duotone Color1</label><input class="duotone-color1" type="color" value={this.state.duotoneColor1} onChange={(e) => this.onPictureFormatChange(e, 'duotoneColor1')}></input> </div> <div class="option-row"> <label>Duotone Color2</label><input class="duotone-color2" type="color" value={this.state.duotoneColor2} onChange={(e) => this.onPictureFormatChange(e, 'duotoneColor2')}></input> </div> </div> } const picturePropEl = <div class="options-container"> <h3>Picture Format</h3> <div class="option-row"> <label>Image</label><input class="img" type="file" accept="image/*" onChange={this.onImgChange}></input> </div> <div class="option-row"> <label>Geometry Type</label> <select class="geometry-type" value={this.state.geometryType} onChange={this.onGeometryTypeChange}> <option value="1">rectangle</option> <option value="5">rounded rectangle</option> <option value="9">oval</option> <option value="21">heart</option> <option value="178">cloud</option> </select> </div> <div class="option-row"> <label>Transparency</label><input class="transparency" type="number" min="0" max="1" step="0.01" value={this.state.transparency} onChange={(e) => this.onPictureFormatChange(e, 'transparency')}></input> </div> <div class="divide-line"></div> <details> <summary>Crop</summary> <div class="option-row"> <label>Crop Left</label><input class="crop-left" type="number" max="0.99" step="0.01" value={this.state.crop.left} onChange={(e) => this.onCropPropChange(e, 'left')}></input> </div> <div class="option-row"> <label>Crop Right</label><input class="crop-right" type="number" max="0.99" step="0.01" value={this.state.crop.right} onChange={(e) => this.onCropPropChange(e, 'right')}></input> </div> <div class="option-row"> <label>Crop Top</label><input class="crop-top" type="number" max="0.99" step="0.01" value={this.state.crop.top} onChange={(e) => this.onCropPropChange(e, 'top')}></input> </div> <div class="option-row"> <label>Crop Bottom</label><input class="crop-bottom" type="number" max="0.99" step="0.01" value={this.state.crop.bottom} onChange={(e) => this.onCropPropChange(e, 'bottom')}></input> </div> </details> <div class="divide-line"></div> <details> <summary>Brightness/Contrast</summary> <div class="option-row"> <label>Brightness</label><input class="brightness" type="number" min="-1" max="1" step="0.01" value={this.state.brightness} onChange={(e) => this.onPictureFormatChange(e, 'brightness')}></input> </div> <div class="option-row"> <label>Contrast</label><input class="contrast" type="number" min="-1" max="1" step="0.01" value={this.state.contrast} onChange={(e) => this.onPictureFormatChange(e, 'contrast')}></input> </div> </details> <div class="divide-line"></div> <details> <summary>Recolor</summary> <div class="option-row"> <label>Recolor Type</label> <select class="recolor-type" value={this.state.recolorType} onChange={(e) => this.onPictureFormatChange(e, 'recolorType')}> <option value="none">none</option> <option value="gray-scale">grayscale</option> <option value="black-and-white">blackAndWhite</option> <option value="duotone">duotone</option> </select> </div> <div class="option-row"> <label>BlackAndWhite</label><input class="black-and-white" type="number" min="0" max="1" step="0.05" value={this.state.blackAndWhite} onChange={(e) => this.onPictureFormatChange(e, 'blackAndWhite')}></input> </div> {duotone} </details> <div class="divide-line"></div> <details> <summary>Style</summary> <div class="option-row"> <label>Background Color</label><input class="background-color" type="color" value={this.state.backgroundColor} onChange={this.onBackgroundColorChange}></input> </div> <div class="option-row"> <label>Border Color</label><input class="border-color" type="color" value={this.state.borderColor} onChange={this.onBorderColorChange}></input> </div> <div class="option-row"> <label>Border Width</label><input class="border-width" type="number" min="-1" step="1" value={this.state.borderWidth} onChange={this.onBorderWidthChange}></input> </div> </details> </div>; return ( <div class="sample-tutorial"> <div id="ss" class="sample-spreadsheets"> <SpreadSheets workbookInitialized={spread => this.initSpread(spread)}> </SpreadSheets> </div> {this.state.active ? picturePropEl : tipEl} </div> ); } initSpread(spread) { this.spread = spread; this.sheet = this.spread.getActiveSheet(); this.sheet.bind(GC.Spread.Sheets.Events.ShapeSelectionChanged, this.shapeSelectionChangedHandler); this.addDefaultShape(); } addDefaultShape() { var sheet = this.sheet; var splogoImg = ""; var foodImg = ""; var pic1 = sheet.shapes.addPictureShape('pic1', splogoImg, 80, 80, 150, 150); var pic2 = sheet.shapes.addPictureShape('pic2', splogoImg, 310, 80, 150, 150); var pic3 = sheet.shapes.addPictureShape('pic3', splogoImg, 540, 80, 150, 150); var pic4 = sheet.shapes.addPictureShape('pic4', foodImg, 80, 300, 285, 180); var pic5 = sheet.shapes.addPictureShape('pic5', foodImg, 420, 300, 285, 180); pic1.isSelected(true); // set pic2 style var style = pic2.style(); style.fill = { type: 1, color: '#666666' }; pic2.style(style); // set pic3 geometry type pic3.geometryType(GC.Spread.Sheets.Shapes.AutoShapeType.roundedRectangle); // set pic3 style var style = pic3.style(); style.fill = { type: 1, color: '#666666' }; pic3.style(style); // set pic5 duotone effect pic5.pictureFormat({ duotone: { color1: 'black', color2: 'rgb(150, 242, 21)' } }); } shapeSelectionChangedHandler() { var pictures = this.getSelectedPictures(); var active = pictures.length === 1; this.setState({ active }); if (active) { this.syncState(pictures[0]); } } syncState(pic) { let geometryType = pic.geometryType(); let format = pic.pictureFormat(); let style = pic.style(); let newState = { geometryType, crop: format.crop, transparency: format.transparency, brightness: format.brightness, contrast: format.contrast, recolorType: 'none', isShow: false }; if (format.grayscale) { newState.recolorType = 'gray-scale'; } else if (format.blackAndWhite !== undefined) { newState.recolorType = 'black-and-white'; newState.blackAndWhite = format.blackAndWhite; } else if (format.duotone) { newState.recolorType = 'duotone'; newState.isShow = true; newState.duotoneColor1 = this.rgbToHex(format.duotone.color1); newState.duotoneColor2 = this.rgbToHex(format.duotone.color2); } newState.backgroundColor = this.rgbToHex(style.fill.color); newState.borderColor = this.rgbToHex(style.line.color); newState.borderWidth = style.line.width; this.setState(newState); } onImgChange(e) { var self = this; var blob = e.target.files[0]; var fileReader = new FileReader(); fileReader.addEventListener('load', function () { self.getFirstSelectedPicture().src(fileReader.result); }); fileReader.readAsDataURL(blob); } onGeometryTypeChange(e) { let value = Number(e.target.value); this.setState({ geometryType: value }); this.getFirstSelectedPicture().geometryType(value); } onCropPropChange(e, propName) { let value = Number(e.target.value); let crop = JSON.parse(JSON.stringify(this.state.crop)); crop[propName] = value; this.setState({ crop }); let pic = this.getFirstSelectedPicture(); var format = pic.pictureFormat(); format.crop = crop; pic.pictureFormat(format); } onPictureFormatChange(e, propName) { let value = e.target.value; let numberValue = Number(value); let pic = this.getFirstSelectedPicture(); var format = pic.pictureFormat(); if (propName === 'transparency') { format.transparency = numberValue; } else if (propName === 'brightness') { format.brightness = numberValue; } else if (propName === 'contrast') { format.contrast = numberValue; } else if (propName === 'recolorType') { this.clearRecolorAndBrightnessContrast(format); if (value === 'gray-scale') { format.grayscale = true; } else if (value === 'black-and-white') { format.blackAndWhite = this.state.blackAndWhite; } else if (value === 'duotone') { format.duotone = { color1: this.state.duotoneColor1, color2: this.state.duotoneColor2 } } } else if (propName === 'blackAndWhite') { this.clearRecolorAndBrightnessContrast(format); format.blackAndWhite = numberValue; } else if (propName === 'duotoneColor1') { this.clearRecolorAndBrightnessContrast(format); format.duotone = { color1: value, color2: this.state.duotoneColor2 } } else if (propName === 'duotoneColor2') { this.clearRecolorAndBrightnessContrast(format); format.duotone = { color1: this.state.duotoneColor1, color2: value } } pic.pictureFormat(format); this.syncState(pic); } clearRecolorAndBrightnessContrast(format) { format.grayscale = false; format.blackAndWhite = undefined; format.duotone = undefined; format.brightness = 0; format.contrast = 0; } onBackgroundColorChange(e) { let value = e.target.value; this.setState({ backgroundColor: value }); var picture = this.getFirstSelectedPicture(); var style = picture.style(); style.fill = { type: 1, color: value, transparency: 0 }; picture.style(style); } onBorderColorChange(e) { let value = e.target.value; this.setState({ borderColor: value }); var picture = this.getFirstSelectedPicture(); var style = picture.style(); style.line.color = value; picture.style(style); } onBorderWidthChange(e) { let value = Number(e.target.value); this.setState({ borderWidth: value }); var picture = this.getFirstSelectedPicture(); var style = picture.style(); style.line.color = this.state.borderColor; style.line.width = value; picture.style(style); } getSelectedPictures() { var pictures = []; var shapes = this.sheet.shapes.all(); for (var i = 0; i < shapes.length; i++) { var shape = shapes[i]; if (shape.isSelected() && shape instanceof GC.Spread.Sheets.Shapes.PictureShape) { pictures.push(shape); } } return pictures; } rgbToHex(color) { let rgb = color.match(/rgb\((\d+),(\d+),(\d+)\)/); if (!rgb || rgb.length < 4) { return '#000000'; } return '#' + rgb.slice(1, 4).map(function (v) { let hex = Number(v).toString(16); return hex.length === 1 ? "0" + hex : hex; }).join(''); } getFirstSelectedPicture() { return this.getSelectedPictures()[0]; } }
<!doctype html> <html style="height:100%;font-size:14px;"> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <link rel="stylesheet" type="text/css" href="$DEMOROOT$/ko/react/node_modules/@mescius/spread-sheets/styles/gc.spread.sheets.excel2013white.css"> <!-- SystemJS --> <script src="$DEMOROOT$/ko/react/node_modules/systemjs/dist/system.src.js"></script> <script src="systemjs.config.js"></script> <script> System.import('$DEMOROOT$/ko/lib/react/license.js').then(function () { System.import('./src/app'); }); </script> </head> <body> <div id="app"></div> </body> </html>
body { position: absolute; top: 0; bottom: 0; left: 0; right: 0; } #app { width: 100%; height: 100%; } .sample-tutorial { position: relative; height: 100%; overflow: hidden; } .sample-spreadsheets { width: calc(100% - 300px); height: 100%; overflow: hidden; } .options-container { position: absolute; top: 0px; right: 0px; width: 300px; height: 100%; padding: 12px; box-sizing: border-box; background: #fbfbfb; overflow: auto; } h3 { text-align: center; } .option-row { background: #fbfbfb; position: relative; margin: 12px 0px; } details { margin: 12px 0px; } .option-row input { position: absolute; box-sizing: border-box; right: 20px; width: 126px; height: 26px; } .option-row select { position: absolute; right: 20px; width: 126px; height: 26px; } .divide-line { width: 100%; height: 1px; background: #cbcbcb; margin-top: 10px; margin-bottom: 3px; }
(function (global) { System.config({ transpiler: 'plugin-babel', babelOptions: { es2015: true, react: true }, meta: { '*.css': { loader: 'css' } }, paths: { // paths serve as alias 'npm:': 'node_modules/' }, // map tells the System loader where to look for things map: { '@mescius/spread-sheets': 'npm:@mescius/spread-sheets/index.js', '@mescius/spread-sheets-shapes': 'npm:@mescius/spread-sheets-shapes/index.js', '@mescius/spread-sheets-resources-ko': 'npm:@mescius/spread-sheets-resources-ko/index.js', '@mescius/spread-sheets-react': 'npm:@mescius/spread-sheets-react/index.js', '@grapecity/jsob-test-dependency-package/react-components': 'npm:@grapecity/jsob-test-dependency-package/react-components/index.js', 'react': 'npm:react/umd/react.production.min.js', 'react-dom': 'npm:react-dom/umd/react-dom.production.min.js', 'css': 'npm:systemjs-plugin-css/css.js', 'plugin-babel': 'npm:systemjs-plugin-babel/plugin-babel.js', 'systemjs-babel-build':'npm:systemjs-plugin-babel/systemjs-babel-browser.js' }, // packages tells the System loader how to load when no filename and/or no extension packages: { src: { defaultExtension: 'jsx' }, "node_modules": { defaultExtension: 'js' }, } }); })(this);