다음 샘플은 그림 셰이프를 추가하는 방법을 보여 줍니다.
다음 예시는 그림의 투명도를 변경하는 방법을 보여 줍니다.
다음 예시는 그림을 자르는 방법을 보여 줍니다.
다음 예시는 그림의 밝기 및 대비를 설정하는 방법을 보여 줍니다.
다음 예시는 그림을 다시 칠하는 방법을 보여 줍니다.
다음 예시는 그림의 기하 도형 유형을 변경하는 방법을 보여 줍니다.
다음 예시는 그림의 테두리를 설정하는 방법을 보여 줍니다.
그림의 일부가 투명하면 그림의 배경색을 설정할 수 있습니다.
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;
}