vectozavr-shooter/engine/Mesh.h

60 lines
2.2 KiB
C
Raw Normal View History

2021-09-13 15:53:43 +03:00
//
// Created by Иван Ильин on 13.01.2021.
//
#ifndef ENGINE_MESH_H
#define ENGINE_MESH_H
#include <vector>
#include "Triangle.h"
#include "animation/Animatable.h"
#include <SFML/Graphics.hpp>
#include "Object.h"
2021-10-02 20:36:07 +03:00
class Mesh : public Object {
private:
std::vector<Triangle> _tris;
sf::Color _color = sf::Color(255, 245, 194);
2021-09-13 15:53:43 +03:00
bool _visible = true;
Mesh& operator*=(const Matrix4x4& matrix4X4);
2021-09-13 15:53:43 +03:00
public:
Mesh() = default;
Mesh(const Mesh& mesh);
explicit Mesh(const std::vector<Triangle>& tries);
Mesh& operator=(const Mesh& mesh);
explicit Mesh(const std::string& filename, const std::string &materials = "", const Point4D& scale = Point4D{1, 1, 1});
Mesh& loadObj(const std::string& filename, const std::string &materials = "", const Point4D& scale = Point4D{1, 1, 1});
[[nodiscard]] std::vector<Triangle>const &triangles() const { return _tris; }
2021-10-02 20:36:07 +03:00
[[nodiscard]] std::vector<Triangle>& triangles() { return _tris; }
void setTriangles(const std::vector<Triangle>& t) { _tris = t; }
2021-09-13 15:53:43 +03:00
// Translate body
// Rotate body around XYZ axes
2021-09-13 15:53:43 +03:00
void rotate(const Point4D& r) override;
// Rotate body around normalised vector 'v' by 'r' radians
2021-09-13 15:53:43 +03:00
void rotate(const Point4D& v, double r) override;
// Rotate body around XYZ by (r.x, r.y, r.z) radians relative val 'point4D'
2021-09-13 15:53:43 +03:00
void rotateRelativePoint(const Point4D& point4D, const Point4D& r) override;
// Rotate body around normalised vector 'v' by 'r' radians relative val 'point4D'
2021-09-13 15:53:43 +03:00
void rotateRelativePoint(const Point4D& point4D, const Point4D& v, double r) override;
2021-10-02 20:36:07 +03:00
void scale(const Point4D& s) override;
2021-09-13 15:53:43 +03:00
2021-10-02 20:36:07 +03:00
[[nodiscard]] sf::Color color() const { return _color; }
void setColor(sf::Color c);
2021-09-13 15:53:43 +03:00
Mesh static Obj(const std::string& filename);
Mesh static LineTo(const Point4D& from, const Point4D& to, double line_width = 0.1, sf::Color color = {150, 150, 150, 255});
void setVisible(bool visibility) { _visible = visibility; }
[[nodiscard]] bool isVisible() const { return _visible; }
std::vector<std::shared_ptr<Mesh>> static LoadObjects(const std::string& filename, const std::string &materials = "", const Point4D& scale = Point4D{1, 1, 1});
};
#endif //INC_3DZAVR_MESH_H