extract explicit mesh with topology information from implicit surfaces with boolean operations, and do surface/volume integrating on them.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

29 lines
969 B

#pragma once
#include <base/primitive.hpp>
#include <subface/simple/plane.hpp>
#include <subface/simple/cone_face.hpp>
namespace internal
{
struct cone_t final : public primitive {
cone_t(primitive_data_center_t *data_center_ptr) : primitive(data_center_ptr)
{
initialize({matrices_ptr<model_matrix::axis::x, false, 0, 0, 1>,
trans_by_target_axis_matrices_ptr<model_matrix::axis::z, true, 0>},
{{}, {}},
k_aabb_up_unit);
}
primitive_type get_type() const override { return PRIMITIVE_TYPE_CONE; };
span<marked_subface_ptr_t<subface>> get_subfaces() const override
{
return {const_cast<marked_subface_ptr_t<subface> *>(subfaces.data()), subfaces.size()};
}
std::vector<surface_type> get_subface_types() const override { return {surface_type::cone, surface_type::plane}; }
std::array<marked_subface_ptr_t<subface>, 2> subfaces{};
};
} // namespace internal