|
|
|
@ -9232,20 +9232,6 @@ void ImDrawList::AddConvexPolyFilled(const ImVec2* points, const int points_coun
|
|
|
|
|
{
|
|
|
|
|
// Anti-aliased Fill
|
|
|
|
|
const float AA_SIZE = 1.0f;
|
|
|
|
|
|
|
|
|
|
// Temporary buffer
|
|
|
|
|
GTempPolyData.resize(points_count);
|
|
|
|
|
ImVec2* temp_normals = >empPolyData[0];
|
|
|
|
|
for (int i0 = points_count-1, i1 = 0; i1 < points_count; i0 = i1++)
|
|
|
|
|
{
|
|
|
|
|
const ImVec2& p0 = points[i0];
|
|
|
|
|
const ImVec2& p1 = points[i1];
|
|
|
|
|
ImVec2 diff = p1 - p0;
|
|
|
|
|
diff *= ImInvLength(diff, 1.0f);
|
|
|
|
|
temp_normals[i0].x = diff.y;
|
|
|
|
|
temp_normals[i0].y = -diff.x;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const ImU32 col_trans = col & 0x00ffffff;
|
|
|
|
|
const int idx_count = (points_count-2)*3 + points_count*6;
|
|
|
|
|
const int vtx_count = (points_count*2);
|
|
|
|
@ -9260,6 +9246,18 @@ void ImDrawList::AddConvexPolyFilled(const ImVec2* points, const int points_coun
|
|
|
|
|
idx_write += 3;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Compute normals
|
|
|
|
|
ImVec2* temp_normals = (ImVec2*)alloca(points_count * sizeof(ImVec2));
|
|
|
|
|
for (int i0 = points_count-1, i1 = 0; i1 < points_count; i0 = i1++)
|
|
|
|
|
{
|
|
|
|
|
const ImVec2& p0 = points[i0];
|
|
|
|
|
const ImVec2& p1 = points[i1];
|
|
|
|
|
ImVec2 diff = p1 - p0;
|
|
|
|
|
diff *= ImInvLength(diff, 1.0f);
|
|
|
|
|
temp_normals[i0].x = diff.y;
|
|
|
|
|
temp_normals[i0].y = -diff.x;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for (int i0 = points_count-1, i1 = 0; i1 < points_count; i0 = i1++)
|
|
|
|
|
{
|
|
|
|
|
// Average normals
|
|
|
|
|