aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrobfram2018-03-19 19:22:38 +0100
committerrobfram2018-03-19 19:22:38 +0100
commit8eedb2afe2b7e00c6317a30e98a388f78be6ac56 (patch)
treed9d00261a0641b2d5fec4ac105cc23cb0d52d888
parentebce36c22f1aa27e3ef449565bf1e35c19a3e830 (diff)
downloadgodot-8eedb2afe2b7e00c6317a30e98a388f78be6ac56.tar.gz
godot-8eedb2afe2b7e00c6317a30e98a388f78be6ac56.tar.zst
godot-8eedb2afe2b7e00c6317a30e98a388f78be6ac56.zip
-rw-r--r--servers/visual/visual_server_canvas.cpp12
1 files changed, 8 insertions, 4 deletions
diff --git a/servers/visual/visual_server_canvas.cpp b/servers/visual/visual_server_canvas.cpp
index 3e6e52411..dd8d07f00 100644
--- a/servers/visual/visual_server_canvas.cpp
+++ b/servers/visual/visual_server_canvas.cpp
@@ -440,13 +440,17 @@ void VisualServerCanvas::canvas_item_add_polyline(RID p_item, const Vector<Point
if (p_antialiased) {
pline->line_colors.push_back(Color(1, 1, 1, 1));
}
- }
- if (p_colors.size() == 1) {
+ } else if (p_colors.size() == 1) {
pline->triangle_colors = p_colors;
pline->line_colors = p_colors;
} else {
- pline->triangle_colors.resize(pline->triangles.size());
- pline->line_colors.resize(pline->lines.size());
+ if (p_colors.size() != p_points.size()) {
+ pline->triangle_colors.push_back(p_colors[0]);
+ pline->line_colors.push_back(p_colors[0]);
+ } else {
+ pline->triangle_colors.resize(pline->triangles.size());
+ pline->line_colors.resize(pline->lines.size());
+ }
}
for (int i = 0; i < p_points.size(); i++) {