/* * Copyright (c) 2020 Samsung Electronics Co., Ltd All Rights Reserved * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #ifndef _TVG_SHAPE_PATH_CPP_ #define _TVG_SHAPE_PATH_CPP_ #include "tvgCommon.h" /************************************************************************/ /* Internal Class Implementation */ /************************************************************************/ struct ShapePath { PathCommand* cmds = nullptr; size_t cmdCnt = 0; size_t reservedCmdCnt = 0; Point *pts = nullptr; size_t ptsCnt = 0; size_t reservedPtsCnt = 0; ~ShapePath() { if (cmds) delete(cmds); if (pts) delete(pts); } int reserveCmd(size_t cmdCnt) { if (cmdCnt > reservedCmdCnt) { reservedCmdCnt = cmdCnt; cmds = static_cast(realloc(cmds, sizeof(PathCommand) * reservedCmdCnt)); assert(cmds); } return 0; } int reservePts(size_t ptsCnt) { if (ptsCnt > reservedPtsCnt) { reservedPtsCnt = ptsCnt; pts = static_cast(realloc(pts, sizeof(Point) * reservedPtsCnt)); assert(pts); } return 0; } int reserve(size_t cmdCnt, size_t ptsCnt) { reserveCmd(cmdCnt); reservePts(ptsCnt); return 0; } int clear() { cmdCnt = 0; ptsCnt = 0; return 0; } int moveTo(float x, float y) { if (cmdCnt + 1 > reservedCmdCnt) reserveCmd((cmdCnt + 1) * 2); if (ptsCnt + 2 > reservedPtsCnt) reservePts((ptsCnt + 2) * 2); cmds[cmdCnt++] = PathCommand::MoveTo; pts[ptsCnt++] = {x, y}; return 0; } int lineTo(float x, float y) { if (cmdCnt + 1 > reservedCmdCnt) reserveCmd((cmdCnt + 1) * 2); if (ptsCnt + 2 > reservedPtsCnt) reservePts((ptsCnt + 2) * 2); cmds[cmdCnt++] = PathCommand::LineTo; pts[ptsCnt++] = {x, y}; return 0; } int cubicTo(float cx1, float cy1, float cx2, float cy2, float x, float y) { if (cmdCnt + 1 > reservedCmdCnt) reserveCmd((cmdCnt + 1) * 2); if (ptsCnt + 3 > reservedPtsCnt) reservePts((ptsCnt + 3) * 2); cmds[cmdCnt++] = PathCommand::CubicTo; pts[ptsCnt++] = {cx1, cy1}; pts[ptsCnt++] = {cx2, cy2}; pts[ptsCnt++] = {x, y}; return 0; } int close() { if (cmdCnt + 1 > reservedCmdCnt) reserveCmd((cmdCnt + 1) * 2); cmds[cmdCnt++] = PathCommand::Close; return 0; } int bounds(float& x, float& y, float& w, float& h) { if (ptsCnt == 0) return -1; Point min = { pts[0].x, pts[0].y }; Point max = { pts[0].x, pts[0].y }; for(size_t i = 1; i <= ptsCnt; ++i) { if (pts[i].x < min.x) min.x = pts[i].x; if (pts[i].y < min.y) min.y = pts[i].y; if (pts[i].x > max.x) max.x = pts[i].x; if (pts[i].y > max.y) max.y = pts[i].y; } x = min.x; y = min.y; w = max.x - min.x; h = max.y - min.y; return 0; } }; /************************************************************************/ /* External Class Implementation */ /************************************************************************/ #endif //_TVG_SHAPE_PATH_CPP_