From d69df3065f08bb8f7fd3d738978a56b4afc6f830 Mon Sep 17 00:00:00 2001 From: ocornut Date: Fri, 6 Mar 2015 23:47:26 +0000 Subject: [PATCH] AA primitives: using a single vector for storage and accessing via raw pointers. --- imgui.cpp | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/imgui.cpp b/imgui.cpp index f23a3b1e..637386e2 100644 --- a/imgui.cpp +++ b/imgui.cpp @@ -6798,9 +6798,7 @@ void ImDrawList::AddVtxUV(const ImVec2& pos, ImU32 col, const ImVec2& uv) vtx_write++; } -static ImVector temp_inner; -static ImVector temp_outer; -static ImVector temp_normals; +static ImVector GTempPolyData; void ImDrawList::AddPolyline(const ImVec2* points, const int points_count, ImU32 col, bool closed) { @@ -6809,9 +6807,11 @@ void ImDrawList::AddPolyline(const ImVec2* points, const int points_count, ImU32 const float aa_size = 1.0f; - temp_inner.resize(points_count); - temp_outer.resize(points_count); - temp_normals.resize(points_count); + // Temporary buffer + GTempPolyData.resize(points_count * 3); + ImVec2* temp_inner = >empPolyData[0]; + ImVec2* temp_outer = >empPolyData[points_count]; + ImVec2* temp_normals = >empPolyData[points_count * 2]; int start = 0, count = points_count; if (!closed) @@ -6894,10 +6894,11 @@ void ImDrawList::AddConvexPolyFilled(const ImVec2* points, const int points_coun const float aa_size = 1.0f; - temp_inner.resize(points_count); - temp_outer.resize(points_count); - temp_normals.resize(points_count); - + // Temporary buffer + GTempPolyData.resize(points_count * 3); + ImVec2* temp_inner = >empPolyData[0]; + ImVec2* temp_outer = >empPolyData[points_count]; + ImVec2* temp_normals = >empPolyData[points_count * 2]; for (int i = 0, j = points_count-1; i < points_count; j=i++) { const ImVec2& v0 = points[j];