Subversion Repositories Kolibri OS

Rev

Rev 7150 | Rev 7154 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. struct _colors
  2. {
  3.  
  4.         unsigned rows, columns;
  5.         dword mas[32*32];
  6.         dword img;
  7.         void set_pixel();
  8.         dword get_pixel();
  9.         dword get_image();
  10.         void move();
  11. };
  12.  
  13. void _colors::set_pixel(int _r, _c, _color)
  14. {
  15.         mas[columns*_r + _c] = _color;
  16. }
  17.  
  18. dword _colors::get_pixel(int _r, _c)
  19. {
  20.         return mas[columns*_r + _c];
  21. }
  22.  
  23. dword _colors::get_image()
  24. {
  25.         int r=0, c=0;
  26.         dword i;
  27.  
  28.         free(img);
  29.         i = img = malloc(rows*columns*3);
  30.  
  31.         for (r = 0; r < rows; r++)
  32.         {
  33.                 for (c = 0; c < columns; c++)
  34.                 {
  35.                         rgb.DwordToRgb(get_pixel(r,c));
  36.                         ESBYTE[i] = rgb.b;
  37.                         ESBYTE[i+1] = rgb.g;
  38.                         ESBYTE[i+2] = rgb.r;
  39.                         i += 3;
  40.                 }
  41.         }
  42.         return img;
  43. }
  44.  
  45. enum {
  46.         MOVE_LEFT,
  47.         MOVE_RIGHT,
  48.         MOVE_UP,
  49.         MOVE_DOWN,
  50.         FLIP_VER,
  51.         FLIP_HOR,
  52.         ROTE
  53. };
  54. void _colors::move(int _direction)
  55. {
  56.         int r, c;
  57.         dword first_element_data;
  58.  
  59.         if (_direction == MOVE_LEFT)
  60.         {
  61.                 for (r = 0; r < rows; r++)
  62.                 {
  63.                         first_element_data = get_pixel(r, 0);
  64.                         for (c = 0; c < columns-1; c++) set_pixel(r, c, get_pixel(r, c+1));
  65.                         set_pixel(r, columns-1, first_element_data);
  66.                 }              
  67.         }
  68.         if (_direction == MOVE_RIGHT)
  69.         {
  70.                 for (r = 0; r < rows; r++)
  71.                 {
  72.                         first_element_data = get_pixel(r, columns-1);
  73.                         for (c = columns-1; c > 0; c--) set_pixel(r, c, get_pixel(r, c-1));
  74.                         set_pixel(r, 0, first_element_data);
  75.                 }              
  76.         }
  77.         if (_direction == MOVE_UP)
  78.         {
  79.                 for (c = 0; c < columns; c++)
  80.                 {
  81.                         first_element_data = get_pixel(0, c);
  82.                         for (r = 0; r < rows-1; r++) set_pixel(r, c, get_pixel(r+1, c));
  83.                         set_pixel(rows-1, c, first_element_data);
  84.                 }              
  85.         }
  86.         if (_direction == MOVE_DOWN)
  87.         {
  88.                 for (c = 0; c < columns; c++)
  89.                 {
  90.                         first_element_data = get_pixel(rows-1, c);
  91.                         for (r = rows-1; r > 0; r--) set_pixel(r, c, get_pixel(r-1, c));
  92.                         set_pixel(0, c, first_element_data);
  93.                 }              
  94.         }
  95.  
  96.  
  97.         if (_direction == FLIP_HOR)
  98.         {
  99.                 for (r = 0; r < rows; r++)
  100.                 {
  101.                         for (c = 0; c < columns/2; c++) {
  102.                                 first_element_data = get_pixel(r, c);
  103.                                 set_pixel(r, c, get_pixel(r, columns-c));
  104.                                 set_pixel(r, columns-c, first_element_data);
  105.                         }
  106.                 }              
  107.         }
  108. }
  109.  
  110.  
  111.  
  112.  
  113.  
  114.  
  115.  
  116.