#pragma once #include #include namespace internal { struct box_t final : public primitive { box_t(primitive_data_center_t *data_center_ptr) : primitive(data_center_ptr) { initialize({trans_by_target_axis_matrices_ptr, trans_by_target_axis_matrices_ptr, trans_by_target_axis_matrices_ptr, trans_by_target_axis_matrices_ptr, trans_by_target_axis_matrices_ptr, trans_by_target_axis_matrices_ptr}, {{}, {}, {}, {}, {}, {}}, k_aabb_unit); for(auto s : get_subfaces()) { std::cout << (s->world_to_local * Eigen::Vector4d{0, 0, 0, 1}).transpose() << std::endl; // std::cout << s->local_to_world.matrix() << std::endl; // std::cout << (s->local_to_world * Eigen::Vector4d{0, 0, 0, 1}).transpose() << std::endl; // std::cout << s.get_mark() << std::endl; s.set_mark(~s.get_mark()); } } primitive_type get_type() const override { return PRIMITIVE_TYPE_BOX; }; span> get_subfaces() const override { return {const_cast *>(subfaces.data()), subfaces.size()}; } std::vector get_subface_types() const override { return {surface_type::plane, surface_type::plane, surface_type::plane, surface_type::plane, surface_type::plane, surface_type::plane}; } std::array, 6> subfaces{}; }; } // namespace internal