Subversion Repositories Kolibri OS

Rev

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

  1. #ifndef INCLUDE_DRAW_BUF_H
  2. #define INCLUDE_DRAW_BUF_H
  3. #print "[include <draw_buf.h>]\n"
  4.  
  5. #ifndef INCLUDE_KOLIBRI_H
  6. #include "../lib/kolibri.h"
  7. #endif
  8.  
  9. dword buf_data=0;
  10.  
  11.  
  12. struct DrawBufer {
  13.         dword bufx, bufy, bufw, bufh;
  14.         dword fill_color;
  15.  
  16.         bool Init();
  17.         void Show();
  18.         void Fill();
  19.         void DrawBar();
  20.         void WriteText();
  21.         void PutPixel();
  22.         void AlignCenter();
  23.         void AlignRight();
  24.         void IncreaseBufSize();
  25. };
  26.  
  27. char draw_buf_not_enaught_ram[] =
  28. "'DrawBufer needs more memory than currenly available.
  29. Application could be unstable.
  30.  
  31. Requested size: %i Mb
  32. Free RAM: %i Mb' -E";
  33.  
  34. bool DrawBufer::Init(dword i_bufx, i_bufy, i_bufw, i_bufh)
  35. {
  36.         bufx = i_bufx;
  37.         bufy = i_bufy;
  38.         bufw = i_bufw;
  39.         bufh = i_bufh;
  40.         if (buf_data) buf_data = free(buf_data);
  41.         IncreaseBufSize();
  42.         if (!buf_data) return false;
  43.         ESDWORD[buf_data] = bufw;
  44.         ESDWORD[buf_data+4] = bufh;
  45.         return true;
  46. }
  47.  
  48. void DrawBufer::Fill(dword start_pointer, i_fill_color)
  49. {
  50.         dword i;
  51.         dword max_i = bufw * bufh * 4 + buf_data + 8;
  52.         fill_color = i_fill_color;
  53.         MEMSETD(buf_data+start_pointer+8, max_i-buf_data-start_pointer-8/4, fill_color);
  54. }
  55.  
  56. void DrawBufer::DrawBar(dword x, y, w, h, color)
  57. {
  58.         dword i, j;
  59.         if (y + h >= bufh) IncreaseBufSize();
  60.         for (j=0; j<h; j++)     {
  61.                 for (i = y+j*bufw+x<<2+8+buf_data; i<y+j*bufw+x+w<<2+8+buf_data; i+=4) {
  62.                         ESDWORD[i] = color;
  63.                 }
  64.         }
  65. }
  66.  
  67. void DrawBufer::WriteText(dword x, y, byte fontType, dword color, str_offset, strlen)
  68. {
  69.         #define BUGFIX_32000 32000
  70.         dword ydiv=0;
  71.         dword reserve_data_1, reserve_data_2;
  72.         dword new_buf_offset;
  73.         if (y + 30 >= bufh) IncreaseBufSize();
  74.         if (y < BUGFIX_32000) {
  75.                 ESI = strlen;
  76.                 WriteBufText(x, y, fontType, color, str_offset, buf_data);
  77.         }
  78.         else {
  79.                 ydiv = y / BUGFIX_32000 * BUGFIX_32000;
  80.                 y -= ydiv;
  81.                 new_buf_offset = ydiv * bufw * 4 + buf_data;
  82.  
  83.                 reserve_data_1 = ESDWORD[new_buf_offset];
  84.                 reserve_data_2 = ESDWORD[new_buf_offset+4];
  85.  
  86.                 ESDWORD[new_buf_offset] = bufw;
  87.                 ESDWORD[new_buf_offset+4] = bufh - y;
  88.                 ESI = strlen;
  89.                 WriteBufText(x, y, fontType, color, str_offset, new_buf_offset);
  90.  
  91.                 ESDWORD[new_buf_offset] = reserve_data_1;
  92.                 ESDWORD[new_buf_offset+4] = reserve_data_2;
  93.         }
  94. }
  95.  
  96. void DrawBufer::PutPixel(dword x, y, color)
  97. {
  98.         dword pos = y*bufw+x*4+8+buf_data;
  99.         ESDWORD[pos] = color;
  100. }
  101.  
  102. void DrawBufer::AlignRight(dword x,y,w,h, content_width)
  103. {
  104.         dword i, j, l;
  105.         dword content_left = w - content_width / 2;
  106.         for (j=0; j<h; j++)
  107.         {
  108.                 for (i=j*w+w-x*4, l=j*w+content_width+x*4; (i>=j*w+content_left*4) && (l>=j*w*4); i-=4, l-=4)
  109.                 {
  110.                         ESDWORD[buf_data+8+i] >< ESDWORD[buf_data+8+l];
  111.                 }
  112.         }
  113. }
  114.  
  115. void DrawBufer::AlignCenter(dword x,y,w,h, content_width)
  116. {
  117.         dword i, j, l;
  118.         dword content_left = w - content_width / 2;
  119.         for (j=0; j<h; j++)
  120.         {
  121.                 for (i=j*w+content_width+content_left*4, l=j*w+content_width+x*4; (i>=j*w+content_left*4) && (l>=j*w*4); i-=4, l-=4)
  122.                 {
  123.                         ESDWORD[buf_data+8+i] >< ESDWORD[buf_data+8+l];
  124.                 }
  125.         }
  126. }
  127.  
  128. /*
  129. void DrawBufer::Zoom2x(int zoom)
  130. {
  131.         int i, s;
  132.         dword point_x, max_i, zline_w, s_inc;
  133.  
  134.         point_x = 0;
  135.         max_i = bufw * bufh * 4 + buf_data+8;
  136.         s_inc = zoom * 4;
  137.         zline_w = zbufw * 4;
  138.  
  139.         for (i=buf_data+8, s=zbuf_data+8; i<max_i; i+=4, s+= s_inc) {
  140.                 ESDWORD[s] = ESDWORD[i];
  141.                 ESDWORD[s+4] = ESDWORD[i];
  142.                 ESDWORD[s+zline_w] = ESDWORD[i];
  143.                 ESDWORD[s+zline_w+4] = ESDWORD[i];
  144.                 if (zoom==3)
  145.                 {
  146.                         ESDWORD[s+8] = ESDWORD[i];
  147.                         ESDWORD[zline_w+s+8] = ESDWORD[i];
  148.                         ESDWORD[zline_w*2+s] = ESDWORD[i];
  149.                         ESDWORD[zline_w*2+s+4] = ESDWORD[i];
  150.                         ESDWORD[zline_w*2+s+8] = ESDWORD[i];
  151.                 }
  152.  
  153.                 point_x++;
  154.                 if (point_x >= bufw)
  155.                 {
  156.                         s += zoom - 1 * zline_w;
  157.                         point_x = 0;
  158.                 }
  159.         }
  160. }
  161. */
  162.  
  163.  
  164. void DrawBufer::Show()
  165. {
  166.         PutPaletteImage(buf_data+8, bufw, bufh, bufx, bufy, 32, 0);    
  167. }
  168.  
  169. void DrawBufer::IncreaseBufSize()
  170. {
  171.         static dword alloc_counter;
  172.         static dword bufh_initial;
  173.         dword alloc_size;
  174.         dword free_ram_size;
  175.         char error_str[256];
  176.  
  177.         if (!buf_data) {
  178.                 alloc_counter = 1;
  179.                 bufh_initial = bufh;
  180.                 alloc_size = bufw * bufh * 4 + 8;
  181.                 buf_data = malloc(alloc_size);
  182.         }
  183.         else {
  184.                 alloc_counter++;
  185.                 bufh = bufh_initial * alloc_counter;
  186.                 alloc_size = bufw * bufh * 4 + 8;
  187.                 buf_data = realloc(buf_data, alloc_size);
  188.                 Fill(alloc_counter - 1 * bufw * bufh_initial * 4 + 8, fill_color);
  189.         }
  190.  
  191.         free_ram_size = GetFreeRAM() * 1024;
  192.         if (alloc_size >= free_ram_size) {
  193.                 sprintf(#error_str, #draw_buf_not_enaught_ram, alloc_size/1048576, free_ram_size/1048576);
  194.                 notify(#error_str);
  195.         }
  196. }
  197.  
  198.  
  199.  
  200. #endif