summaryrefslogtreecommitdiff
path: root/internal_rewrite/visual.hpp
diff options
context:
space:
mode:
authorJustSomePwner <crotchyalt@gmail.com>2018-08-30 14:01:54 +0200
committerJustSomePwner <crotchyalt@gmail.com>2018-08-30 14:01:54 +0200
commit7ccb819f867493f8ec202ea3b39c94c198c64584 (patch)
tree94622e61af0ff359e3d6689cf274d74f60b2492a /internal_rewrite/visual.hpp
parent564d979b79e8a5aaa5014eba0ecd36c61575934f (diff)
first
Diffstat (limited to 'internal_rewrite/visual.hpp')
-rw-r--r--internal_rewrite/visual.hpp109
1 files changed, 109 insertions, 0 deletions
diff --git a/internal_rewrite/visual.hpp b/internal_rewrite/visual.hpp
new file mode 100644
index 0000000..8df913e
--- /dev/null
+++ b/internal_rewrite/visual.hpp
@@ -0,0 +1,109 @@
+#pragma once
+#include <vector>
+#include "vector.hpp"
+#include "color.hpp"
+#include <unordered_map>
+#include "strings.hpp"
+#include "IVRenderView.hpp"
+class c_base_player;
+
+enum HitFlag_t {
+ HIT_NONE = 0,
+ HIT_ALERT = 1,
+ HIT_1W = 2
+};
+
+namespace features
+{
+ class c_visuals {
+ private:
+ static const clr_t esp_green( uint8_t alpha = 255 ) {
+ return clr_t( 1, 216, 62, alpha );
+ }
+ static const clr_t esp_red( uint8_t alpha = 255 ) {
+ return clr_t( 240, 0, 0, alpha );
+ }
+ static const clr_t esp_blue( uint8_t alpha = 255 ) {
+ return clr_t( 84, 173, 247, alpha );
+ }
+
+ void draw_line( const vec2_t& a, const vec2_t& b, const clr_t& clr );
+ void draw_line( int x, int y, int x1, int y1, const clr_t& clr );
+ void draw_rect( int x, int y, int w, int h, const clr_t& clr );
+ void draw_filled_rect( int x, int y, int w, int h, const clr_t& clr );
+ void draw_circle( int x, int y, int r, const clr_t& clr, int res = 48 );
+
+ void draw_really_big_string( int x, int y, const clr_t& clr, const char* msg, ... );
+ void draw_string( int x, int y, int align, bool big, const clr_t& clr, const char* msg, ... );
+
+
+ void draw_local( );
+ void draw_players( );
+ void draw_world( );
+
+ void draw_hits( );
+ void spectator_list( );
+ void grenade_prediction( );
+ void draw_firegrenade( );
+
+ struct tracer_t {
+ float m_time;
+ vec3_t m_start;
+ vec3_t m_end;
+ bool m_local;
+ };
+
+ //you should always store the entity index rather than the ptr
+ struct sound_t {
+ float m_time;
+ vec3_t m_pos;
+ int m_ent;
+ };
+
+ struct firegrenade_t {
+ float m_time;
+ vec3_t m_pos;
+ int m_ent;
+ };
+
+ struct shot_t {
+ float time;
+ vec3_t pos;
+ bool hit;
+ };
+
+ std::vector< firegrenade_t > m_firegrenades;
+ std::vector< shot_t > m_shots;
+ std::vector< sound_t > m_sounds;
+ std::vector< tracer_t > m_tracers;
+
+ vec3_t m_stored_pos[ 65 ]{ };
+ float m_anim_progress[ 65 ]{ };
+ float m_last_hit{ };
+ int m_ent_dmg[ 65 ]{ };
+ int m_teamdmg{ 0 };
+ int m_hit_flag[ 65 ]{ };
+ float m_last_roundstart{ };
+ public:
+ void update_glow( );
+ void world_modulate( );
+ void update_position( int index, const vec3_t& pos );
+ void store_tracer( int ent_index, vec3_t shot );
+ void store_sound( int ent, vec3_t origin );
+ void store_firegrenades( int ent, vec3_t origin );
+ void draw_autowall( );
+ void draw_spread( );
+ void out_of_fov( c_base_player* ent, const vec3_t& pos, clr_t col );
+ void store_hit( );
+ void radar( );
+ void draw_tracers( );
+ void store_ent_dmg( int, int, int );
+ void store_shot( vec3_t pos, bool hit = false );
+ void draw_shots( );
+ void reset_local_dmg( );
+ void on_round_start( );
+ void draw_sound( );
+ void update_hit_flags( );
+ void operator()( );
+ };
+} \ No newline at end of file