CFindTemplate.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. #pragma once
  2. #ifndef __CFINDTEMPLATE
  3. #define __CFINGTEMPLATE
  4. #include <stdint.h>
  5. #include <string>
  6. #define _USE_MATH_DEFINES
  7. #include <math.h>
  8. #include "stb_image.h"
  9. #include "stb_image_write.h"
  10. #include "stb_image_resize.h"
  11. class CImageBasis
  12. {
  13. protected:
  14. uint8_t* rgb_image;
  15. int channels;
  16. int width, height, bpp;
  17. bool externalImage;
  18. std::string filename;
  19. void memCopy(uint8_t* _source, uint8_t* _target, int _size);
  20. bool isInImage(int x, int y);
  21. public:
  22. int getWidth(){return this->width;};
  23. int getHeight(){return this->height;};
  24. int getChannels(){return this->channels;};
  25. void drawRect(int x, int y, int dx, int dy, int r = 255, int g = 255, int b = 255, int thickness = 1);
  26. void drawLine(int x1, int y1, int x2, int y2, int r, int g, int b, int thickness = 1);
  27. void drawCircle(int x1, int y1, int rad, int r, int g, int b, int thickness = 1);
  28. void setPixelColor(int x, int y, int r, int g, int b);
  29. void Contrast(float _contrast);
  30. CImageBasis();
  31. CImageBasis(std::string _image);
  32. CImageBasis(uint8_t* _rgb_image, int _channels, int _width, int _height, int _bpp);
  33. uint8_t GetPixelColor(int x, int y, int ch);
  34. ~CImageBasis();
  35. void SaveToFile(std::string _imageout);
  36. };
  37. class CFindTemplate : public CImageBasis
  38. {
  39. public:
  40. int tpl_width, tpl_height, tpl_bpp;
  41. CFindTemplate(std::string _image);
  42. void FindTemplate(std::string _template, int* found_x, int* found_y, std::string _imageout);
  43. void FindTemplate(std::string _template, int* found_x, int* found_y, int _dx, int _dy, std::string _imageout);
  44. void FindTemplate(std::string _template, int* found_x, int* found_y);
  45. void FindTemplate(std::string _template, int* found_x, int* found_y, int _dx, int _dy);
  46. };
  47. class CRotate: public CImageBasis
  48. {
  49. public:
  50. CRotate(std::string _image) : CImageBasis(_image) {};
  51. CRotate(uint8_t* _rgb_image, int _channels, int _width, int _height, int _bpp) : CImageBasis(_rgb_image, _channels, _width, _height, _bpp) {};
  52. void Rotate(float _angle);
  53. void Rotate(float _angle, int _centerx, int _centery);
  54. void Translate(int _dx, int _dy);
  55. };
  56. class CAlignAndCutImage : public CImageBasis
  57. {
  58. public:
  59. int t0_dx, t0_dy, t1_dx, t1_dy;
  60. CAlignAndCutImage(std::string _image) : CImageBasis(_image) {};
  61. void Align(std::string _template1, int x1, int y1, std::string _template2, int x2, int y2, int deltax = 40, int deltay = 40, std::string imageROI = "");
  62. void CutAndSave(std::string _template1, int x1, int y1, int dx, int dy);
  63. };
  64. class CResizeImage : public CImageBasis
  65. {
  66. public:
  67. CResizeImage(std::string _image) : CImageBasis(_image) {};
  68. // CResizeImage(std::string _image, int _new_dx, int _new_dy);
  69. void Resize(int _new_dx, int _new_dy);
  70. };
  71. #endif