그림 셰이프

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

설명
app.js
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);
다음 샘플은 그림 셰이프를 추가하는 방법을 보여 줍니다. 다음 예시는 그림의 투명도를 변경하는 방법을 보여 줍니다. 다음 예시는 그림을 자르는 방법을 보여 줍니다. 다음 예시는 그림의 밝기 및 대비를 설정하는 방법을 보여 줍니다. 다음 예시는 그림을 다시 칠하는 방법을 보여 줍니다. 다음 예시는 그림의 기하 도형 유형을 변경하는 방법을 보여 줍니다. 다음 예시는 그림의 테두리를 설정하는 방법을 보여 줍니다. 그림의 일부가 투명하면 그림의 배경색을 설정할 수 있습니다.
window.onload = function () { window.workbook = new GC.Spread.Sheets.Workbook(document.getElementById("ss")); window.sheet = workbook.getActiveSheet(); var pictureProp = document.querySelector(".picture-prop"); var tip = document.querySelector(".tip"); var imgInput = document.querySelector(".img"); var geometryTypeInput = document.querySelector(".geometry-type"); var transparencyInput = document.querySelector(".transparency"); // crop var cropLeftInput = document.querySelector(".crop-left"); var cropRightInput = document.querySelector(".crop-right"); var cropTopInput = document.querySelector(".crop-top"); var cropBottomInput = document.querySelector(".crop-bottom"); // brightness/contrast var brightnessInput = document.querySelector(".brightness"); var contrastInput = document.querySelector(".contrast"); // recolor var recolorTypeInput = document.querySelector(".recolor-type"); var blackAndWhiteInput = document.querySelector(".black-and-white"); var duotoneColor1Input = document.querySelector(".duotone-color1"); var duotoneColor2Input = document.querySelector(".duotone-color2"); var duotoneDivs = document.querySelectorAll(".duotoneContent"); // style var borderColorInput = document.querySelector(".border-color"); var borderWidthInput = document.querySelector(".border-width"); var backColorInput = document.querySelector(".back-color"); function 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)' } }); } function 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; } function getFirstSelectedPicture() { return getSelectedPictures()[0]; } function showPictureProp() { pictureProp.style.display = ''; tip.style.display = 'none'; } function hiddenPictureProp() { pictureProp.style.display = 'none'; tip.style.display = ''; } function 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(''); } function syncState(pic) { let format = pic.pictureFormat(); let style = pic.style(); let crop = format.crop; geometryTypeInput.value = pic.geometryType(); cropLeftInput.value = crop.left; cropRightInput.value = crop.right; cropTopInput.value = crop.top; cropBottomInput.value = crop.bottom; transparencyInput.value = format.transparency; brightnessInput.value = format.brightness; contrastInput.value = format.contrast; for (let i = 0; i < duotoneDivs.length; i++) { duotoneDivs[i].style.display = "none"; } let recolorType = 'none'; if (format.grayscale) { recolorType = 'gray-scale'; } else if (format.blackAndWhite !== undefined) { recolorType = 'black-and-white'; blackAndWhiteInput.value = format.blackAndWhite; } else if (format.duotone) { recolorType = 'duotone'; for (let i = 0; i < duotoneDivs.length; i++) { duotoneDivs[i].style.display = "block"; } duotoneColor1Input.value = rgbToHex(format.duotone.color1); duotoneColor2Input.value = rgbToHex(format.duotone.color2); } recolorTypeInput.value = recolorType; backColorInput.value = rgbToHex(style.fill.color); borderColorInput.value = rgbToHex(style.line.color); borderWidthInput.value = style.line.width; } function clearRecolorAndBrightnessContrast(format) { format.grayscale = false; format.blackAndWhite = undefined; format.duotone = undefined; format.brightness = 0; format.contrast = 0; } function onDuotoneColorChange() { recolorTypeInput.value = 'duotone'; let duotone = { color1: duotoneColor1Input.value, color2: duotoneColor2Input.value }; setPictureFormat(function (format) { clearRecolorAndBrightnessContrast(format); format.duotone = duotone; }); } function setPictureFormat(changeFormatFunc) { var pic = getFirstSelectedPicture(); var format = pic.pictureFormat(); changeFormatFunc(format); pic.pictureFormat(format); syncState(pic); } function bindPanelEvent() { sheet.bind(GC.Spread.Sheets.Events.ShapeSelectionChanged, function () { var pictures = getSelectedPictures(); if (pictures.length === 1) { showPictureProp(); syncState(pictures[0]) } else { hiddenPictureProp(); } }); imgInput.addEventListener("change", function () { var blob = imgInput.files[0]; var fileReader = new FileReader(); fileReader.addEventListener('load', function () { getFirstSelectedPicture().src(fileReader.result); }); fileReader.readAsDataURL(blob); }); geometryTypeInput.addEventListener("input", function () { var value = Number(geometryTypeInput.value); getFirstSelectedPicture().geometryType(value); }); cropLeftInput.addEventListener("input", function () { var value = Number(cropLeftInput.value); setPictureFormat(function (format) { format.crop.left = value; }); }); cropRightInput.addEventListener("input", function () { var value = Number(cropRightInput.value); setPictureFormat(function (format) { format.crop.right = value; }); }); cropTopInput.addEventListener("input", function () { var value = Number(cropTopInput.value); setPictureFormat(function (format) { format.crop.top = value; }); }); cropBottomInput.addEventListener("input", function () { var value = Number(cropBottomInput.value); setPictureFormat(function (format) { format.crop.bottom = value; }); }); transparencyInput.addEventListener("input", function () { var value = Number(transparencyInput.value); setPictureFormat(function (format) { format.transparency = value; }); }); brightnessInput.addEventListener("input", function () { var value = Number(brightnessInput.value); setPictureFormat(function (format) { format.brightness = value; }); }); contrastInput.addEventListener("input", function () { var value = Number(contrastInput.value); setPictureFormat(function (format) { format.contrast = value; }); }); recolorTypeInput.addEventListener("change", function () { let type = recolorTypeInput.value; setPictureFormat(function (format) { clearRecolorAndBrightnessContrast(format); if (type === 'gray-scale') { format.grayscale = true; } else if (type === 'black-and-white') { format.blackAndWhite = Number(blackAndWhiteInput.value); } else if (type === 'duotone') { format.duotone = { color1: duotoneColor1Input.value, color2: duotoneColor2Input.value } } }); }); blackAndWhiteInput.addEventListener("input", function () { recolorTypeInput.value = 'black-and-white'; setPictureFormat(function (format) { clearRecolorAndBrightnessContrast(format); format.blackAndWhite = Number(blackAndWhiteInput.value); }); }); duotoneColor1Input.addEventListener("change", onDuotoneColorChange); duotoneColor2Input.addEventListener("change", onDuotoneColorChange); backColorInput.addEventListener("input", function () { var value = backColorInput.value; var picture = getFirstSelectedPicture(); var style = picture.style(); style.fill = { type: 1, color: value, transparency: 0 }; picture.style(style); }); borderColorInput.addEventListener("input", function () { var value = borderColorInput.value; var picture = getFirstSelectedPicture(); var style = picture.style(); style.line.color = value; picture.style(style); }); borderWidthInput.addEventListener("input", function () { var value = Number(borderWidthInput.value); var picture = getFirstSelectedPicture(); var style = picture.style(); style.line.color = borderColorInput.value; style.line.width = value; picture.style(style); }); } function start() { bindPanelEvent(); addDefaultShape(); } start(); }
<!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" /> <meta name="spreadjs culture" content="ko-kr" /> <link rel="stylesheet" type="text/css" href="$DEMOROOT$/ko/purejs/node_modules/@mescius/spread-sheets/styles/gc.spread.sheets.excel2013white.css"> <script src="$DEMOROOT$/ko/purejs/node_modules/@mescius/spread-sheets/dist/gc.spread.sheets.all.min.js" type="text/javascript"></script> <script src="$DEMOROOT$/ko/purejs/node_modules/@mescius/spread-sheets-shapes/dist/gc.spread.sheets.shapes.min.js" type="text/javascript"></script> <script src="$DEMOROOT$/ko/purejs/node_modules/@mescius/spread-sheets-resources-ko/dist/gc.spread.sheets.resources.ko.min.js" type="text/javascript"></script> <script src="$DEMOROOT$/spread/source/js/license.js" type="text/javascript"></script> <script src="app.js" type="text/javascript"></script> <link rel="stylesheet" type="text/css" href="styles.css"> </head> <body> <div class="sample-tutorial"> <div id="ss" class="sample-spreadsheets"></div> <div class="picture-prop options-container" style="display: none;"> <h3>Picture Format</h3> <div class="option-row"> <label>Image</label><input class="img" type="file" accept="image/*"> </div> <div class="option-row"> <label>Geometry Type</label> <select class="geometry-type"> <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="0"> </div> <div class="divide-line"></div> <details> <summary>Crop</summary> <div class="option-row"> <label>Left</label><input class="crop-left" type="number" max="0.99" step="0.01" value="0"> </div> <div class="option-row"> <label>Right</label><input class="crop-right" type="number" max="0.99" step="0.01" value="0"> </div> <div class="option-row"> <label>Top</label><input class="crop-top" type="number" max="0.99" step="0.01" value="0"> </div> <div class="option-row"> <label>Bottom</label><input class="crop-bottom" type="number" max="0.99" step="0.01" value="0"> </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="0"> </div> <div class="option-row"> <label>Contrast</label><input class="contrast" type="number" min="-1" max="1" step="0.01" value="0"> </div> </details> <div class="divide-line"></div> <details> <summary>Recolor</summary> <div class="option-row"> <label>Recolor Type</label> <select class="recolor-type"> <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="0.5"> </div> <div class="option-row duotoneContent"> <label>Duotone Color1</label><input class="duotone-color1" type="color"> </div> <div class="option-row duotoneContent"> <label>Duotone Color2</label><input class="duotone-color2" type="color" value="#FF0000"> </div> </details> <div class="divide-line"></div> <details> <summary>Style</summary> <div class="option-row"> <label>Background Color</label><input class="back-color" type="color"> </div> <div class="option-row"> <label>Border Color</label><input class="border-color" type="color"> </div> <div class="option-row"> <label>Border Width</label><input class="border-width" type="number" min="-1" step="1" value="0"> </div> </details> </div> <div class="tip options-container"> Try selecting a shape. </div> </div> </body> </html>
body { position: absolute; top: 0; bottom: 0; left: 0; right: 0; } .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; }