From d3e39e6a7facbdf091bb19e918821974a39e414a Mon Sep 17 00:00:00 2001 From: ffreyer Date: Thu, 3 Oct 2024 23:22:00 +0200 Subject: [PATCH] add fallback for MetaMesh --- src/basic_recipes/mesh.jl | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/src/basic_recipes/mesh.jl b/src/basic_recipes/mesh.jl index 120a60f40cd..b116dc90332 100644 --- a/src/basic_recipes/mesh.jl +++ b/src/basic_recipes/mesh.jl @@ -1,6 +1,25 @@ function plot!(p::Mesh{<: Tuple{<: GeometryBasics.MetaMesh}}) metamesh = p[1][] meshes = GeometryBasics.split_mesh(metamesh.mesh) + + if !haskey(metamesh, :material_names) || !haskey(metamesh, :materials) + @error "The given mesh has no :material_names or :materials. Drawing without material information." + for (i, m) in enumerate(meshes) + attr = Attributes() + # Differentiate colors? + attr[:color] = i + attr[:colorrange] = (1, length(meshes)) + + for k in Makie.attribute_names(Makie.Mesh) + get!(attr, k, map(identity, p.attributes[k])) + end + + mesh!(p, attr, m) + end + + return p + end + names = metamesh[:material_names] for (name, m) in zip(names, meshes) @@ -46,10 +65,10 @@ function plot!(p::Mesh{<: Tuple{<: GeometryBasics.MetaMesh}}) end for k in Makie.attribute_names(Makie.Mesh) - get!(attr, k, p.attributes[k]) + get!(attr, k, map(identity, p.attributes[k])) end - plt = mesh!(p, attr, m) + mesh!(p, attr, m) end return p