곰픽 gradient 색상 구하는 부분 변경

This commit is contained in:
2025-04-11 17:47:43 +09:00
parent 60154db66f
commit 9158b42941
3 changed files with 21 additions and 48 deletions

View File

@@ -572,9 +572,9 @@
},
"7": {
"type": "gradient",
"ele": "//Layer/Shapes/shape/*[starts-with(name(), 'gradiant')]",
"startColor": "//Layer[contains(Name/@value, 'Layer 3')]//gradient_start_color/@value",
"endColor": "//Layer[contains(Name/@value, 'Layer 3')]//gradient_end_color/@value",
"ele": "//Layer/Shapes/Shape",
"startColor": "gradient_start_color/@value",
"endColor": "gradient_end_color/@value",
"value": {
"startColor": "347813",
"endColor": "041177"

View File

@@ -320,57 +320,30 @@ function getGpdpScore(gpdpData, scoringJson, index) {
scoringResult[key] = 0;
console.log("❌ 정답 없음:", rightAnswer);
}
// let posX = scoringData[key].posX;
// let posY = scoringData[key].posY;
// let answerWidth = rightAnswer["width"];
// let answerHeight = rightAnswer["height"];
// let width = xpath.select(posX, gpdpXmlDoc);
// let height = xpath.select(posY, gpdpXmlDoc);
// width = Math.round(width);
// height = Math.round(height);
// console.log(`width:${answerWidth},${width}, height: ${answerHeight},${height}`);
// if (answerWidth === width && answerHeight === height) {
// totalScore += point;
// scoringResult[key] = point;
// console.log("same size");
// }
// else {
// scoringResult[key] = 0;
// console.log("different size");
// }
}
else if (type == "gradient") {
let getStartColorXpath = scoringData[key].startColor;
let getEndColorXpath = scoringData[key].endColor;
const items = xpath.select(ele, gpdpXmlDoc);
const startColorXpath = scoringData[key].startColor;
const endColorXpath = scoringData[key].endColor;
let matched = false;
let answerStartColor = rightAnswer["startColor"];
let answerEndColor = rightAnswer["endColor"];
for ( const item of items) {
const startColor = parseColorToHex(xpath.select1(startColorXpath, item)?.value);
const endColor = parseColorToHex(xpath.select1(endColorXpath, item)?.value);
let startColor = xpath.select1(getStartColorXpath, gpdpXmlDoc)?.value;
let endColor = xpath.select1(getEndColorXpath, gpdpXmlDoc)?.value;
console.log(startColor + ":" + rightAnswer["startColor"], endColor + ":" + rightAnswer["endColor"]);
// console.log(start[0].value, end[0].value);
if (start.length == 0 || end.length == 0) {
console.log("gradient color not found");
scoringResult[key] = 0;
continue;
}
const startHexColor = parseColorToHex(start[0].value);
const endHexColor = parseColorToHex(end[0].value);
console.log(startHexColor + ":" + answerStartColor, endHexColor + ":" + answerEndColor);
if (startHexColor === answerStartColor && endHexColor === answerEndColor) {
if ( startColor === rightAnswer["startColor"] && endColor === rightAnswer["endColor"]) {
totalScore += point;
scoringResult[key] = point;
console.log("same color");
matched = true;
console.log("✅ 정답 일치:", rightAnswer);
break;
}
else {
}
if (!matched) {
scoringResult[key] = 0;
console.log("different color");
console.log("❌ 정답 없음:", rightAnswer);
}
}
// 그림자 속성이 있는지 여부 파악해서 그림자 속성 별로 점수 1 점씩 부여

View File

@@ -1 +1 @@
[{"kind":2,"language":"xpath","value":"//Layer[Name[@value='Tracking']]/Effects/Item/Name/@value"},{"kind":2,"language":"xpath","value":"//Layer//op_points"}]
[{"kind":2,"language":"xpath","value":"//Layer[Name[@value='Tracking']]/Effects/Item/Name/@value"},{"kind":2,"language":"xpath","value":"//Layer/Shapes/Shape[*[starts-with(name(), 'gradient')]]"},{"kind":2,"language":"xpath","value":"//Layer/Shapes/Shape"}]