Subversion Repositories Kolibri OS

Rev

Rev 7910 | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. #ifndef INCLUDE_GUI_H
  2. #define INCLUDE_GUI_H
  3.  
  4. #ifndef INCLUDE_KOLIBRI_H
  5. #include "../lib/kolibri.h"
  6. #endif
  7.  
  8. #ifndef INCLUDE_STRING_H
  9. #include "../lib/strings.h"
  10. #endif
  11.  
  12. #ifndef INCLUDE_RGB_H
  13. #include "../lib/patterns/rgb.h"
  14. #endif
  15.  
  16. #ifndef INCLUDE_MATH_H
  17. #include "../lib/math.h"
  18. #endif
  19.  
  20. #include "../lib/gui/tabs.h"
  21. #include "../lib/gui/sensor.h"
  22. #include "../lib/gui/more_less_box.h"
  23.  
  24. #ifndef INCLUDE_CHECKBOX
  25. #include "../lib/gui/checkbox.h"
  26. #endif
  27.  
  28. #include "../lib/gui/child_window.h"
  29. #include "../lib/gui/text_view_area.h"
  30.  
  31. #ifndef INCLUDE_MENU_H
  32. #include "../lib/gui/menu.h"
  33. #endif
  34.  
  35. :int last_free_button_id = 1000;
  36. :int GetFreeButtonId()
  37. {
  38.         last_free_button_id++;
  39.         return last_free_button_id;
  40. }
  41.  
  42. :void DrawRectangle(dword x,y,w,h,color1)
  43. {
  44.         DrawRectangle3D(x,y,w,h,color1,color1);
  45.         /*
  46.         DrawBar(x,y,w,1,color1);
  47.         DrawBar(x,y+h,w,1,color1);
  48.         DrawBar(x,y,1,h,color1);
  49.         DrawBar(x+w,y,1,h+1,color1);
  50.         */
  51. }
  52.  
  53. :void DrawWideRectangle(dword x,y,w,h,boder,color1)
  54. {
  55.         DrawBar(x, y, w, boder, color1);
  56.         DrawBar(x, y+h-boder, w, boder, color1);
  57.         DrawBar(x, y+boder, boder, h-boder-boder, color1);
  58.         DrawBar(x+w-boder, y+boder, boder, h-boder-boder, color1);
  59. }
  60.  
  61. :void DrawRectangle3D(dword x,y,w,h,color1,color2)
  62. {
  63.         DrawBar(x,y,w+1,1,color1);
  64.         DrawBar(x,y+1,1,h-1,color1);
  65.         DrawBar(x+w,y+1,1,h,color2);
  66.         DrawBar(x,y+h,w,1,color2);
  67. }
  68.  
  69. :void DrawCaptButton(dword x,y,w,h,id,color_b, color_t,text)
  70. {
  71.         dword tx = -strlen(text)*8+w/2+x;
  72.         dword ty = h/2-7+y;
  73.  
  74.         if (id>0) DefineButton(x,y,w,h,id,color_b);
  75.         WriteText(tx+1,ty+1,0x90,MixColors(color_b,0,230),text);
  76.         WriteText(tx,ty,0x90,color_t,text);
  77. }
  78.  
  79. :int active_button_id = 0;
  80. :int DrawStandartCaptButton(dword x, y, id, text)
  81. {
  82.         #define padding_v 5
  83.         #define padding_h 15
  84.         #define right_margin 12
  85.         #define h padding_v + padding_v + 16 //16 font height
  86.         int tx = x + padding_h;
  87.         int ty = y + padding_v+1;
  88.         int tw = strlen(text)*8;
  89.         int w = tw + padding_h + padding_h;
  90.         unsigned darker_color = MixColors(sc.button,0,230);
  91.  
  92.  
  93.         if (id>0) DefineButton(x,y,w,h,id,sc.button);
  94.  
  95.         WriteText(tx+1,ty+1,0x90,darker_color,text);
  96.         WriteText(tx,ty,0x90,sc.button_text,text);
  97.  
  98.         if (active_button_id==id) {
  99.                 DrawBar(tx,ty+15,tw,1, darker_color);
  100.                 DrawBar(tx,ty+14,tw,1, sc.button_text);
  101.         }
  102.  
  103.         return w + right_margin;
  104. }
  105.  
  106. /* UNSTABLE
  107. :unsigned LightenDarkenColor(dword color, amt) {
  108.         dword r = color >> 16 + amt << 16;
  109.         dword b = color >> 8 & 0x00FF + amt << 8;
  110.         dword g = color & 0x0000FF + amt;
  111.         return g | b | r ;
  112. }
  113. */
  114.  
  115. :void ActiveButtonSwitch(int min, max)
  116. {
  117.         active_button_id++;
  118.         if (active_button_id>max) || (active_button_id<max) active_button_id=min;
  119. }
  120.  
  121. :void WriteTextCenter(dword x,y,w,color_t,text)
  122. {
  123.         WriteText(-strlen(text)*6+w/2+x+1,y,0x80,color_t,text);
  124. }
  125.  
  126. :void DrawCircle(int x, y, r, color)
  127. {
  128.         int i;
  129.         float px=0, py=r, ii = r * 3.1415926 * 2;
  130.         FOR (i = 0; i < ii; i++)
  131.         {
  132.         PutPixel(px + x, y - py, color);
  133.         px = py / r + px;
  134.         py = -px / r + py;
  135.         }
  136. }
  137.  
  138. :void DrawEditBox(dword edit_box_pointer)
  139. {
  140.         dword x,y,w,h,bg,t;
  141.         ESI = edit_box_pointer;
  142.         x = ESI.edit_box.left;
  143.         y = ESI.edit_box.top;
  144.         w = ESI.edit_box.width+1;
  145.         h = 22;
  146.         if (ESI.edit_box.flags & 100000000000b) bg = 0xCACACA; else bg = 0xFFFfff;
  147.         edit_box_draw  stdcall (edit_box_pointer);
  148.         DrawRectangle3D(x-1, y-1, w+1, h+1, 0xE7E7E7, bg);
  149.         DrawRectangle(x-2, y-2, w+3, h+3, sc.work_graph);
  150.         DrawRectangle3D(x-3, y-3, w+5, h+5, sc.work_dark, sc.work_light);
  151. }
  152.  
  153. #define DOT_W 37
  154. :void DrawFileBox(dword edit_box_pointer, title, btn)
  155. {
  156.         dword x,y,w,h,bg,t;
  157.         ESI = edit_box_pointer;
  158.         x = ESI.edit_box.left;
  159.         y = ESI.edit_box.top;
  160.         w = ESI.edit_box.width+1;
  161.         h = 22;
  162.  
  163.         if (ESI.edit_box.flags & 100000000000b) bg = 0xCACACA; else bg = 0xFFFfff;
  164.         edit_box_draw  stdcall (edit_box_pointer);
  165.         DrawRectangle3D(x-1, y-1, w+1, h+1, 0xE7E7E7, bg);
  166.         DrawRectangle(x-2, y-2, w+3, h+3, sc.work_graph);
  167.         DrawRectangle3D(x-3, y-3, w+DOT_W+5, h+5, sc.work_dark, sc.work_light);
  168.  
  169.         WriteText(x-2, y-19, 0x90, sc.work_text, title);
  170.         DrawCaptButton(x+w+1, y-2, DOT_W, h+3, btn, sc.button, sc.button_text, "...");
  171. }
  172.  
  173. :void DrawEditBoxPos(dword x,y, edit_box_pointer)
  174. {
  175.         ESI = edit_box_pointer;
  176.         ESI.edit_box.left = x;
  177.         ESI.edit_box.top = y;
  178.         DrawEditBox(dword edit_box_pointer);
  179. }
  180.  
  181. :void DrawProgressBar(dword st_x, st_y, st_w, st_h, col_fon, col_border, col_fill, col_text, progress_percent)
  182. {
  183.         int progress_w;
  184.         static int fill_old;
  185.            
  186.         //if (progress_percent<=0) {DrawBar(st_x,st_y, st_x + st_w + fill_old + 15,st_h+1, col_fon); fill_old=0; return;}
  187.         if (progress_percent<=0) || (progress_percent>=100) return;
  188.        
  189.         DrawRectangle(st_x, st_y, st_w,st_h, col_border);
  190.         DrawRectangle3D(st_x+1, st_y+1, st_w-2,st_h-2, 0xFFFfff, 0xFFFfff);
  191.  
  192.         if (progress_percent>0) && (progress_percent<=100)
  193.         {
  194.                 progress_w = st_w - 3 * progress_percent / 100;
  195.                 DrawBar(st_x+2, st_y+2, progress_w, st_h-3, col_fill);
  196.                 DrawBar(st_x+2+progress_w, st_y+2, st_w-progress_w-3, st_h-3, 0xFFFfff);
  197.         }
  198. }
  199.  
  200. :void DrawLink(dword x,y,font_type,btn_id, inscription)
  201. {
  202.         int w;
  203.         WriteText(x,y,font_type,0x4E00E7,inscription);
  204.         if (font_type==0x80) w = strlen(inscription)*6; else w = strlen(inscription)*8;
  205.         DefineButton(x-1,y-1,w,10,btn_id+BT_HIDE,0);
  206.         DrawBar(x,y+8,w,1,0x4E00E7);
  207. }
  208.  
  209. :void PutShadow(dword x,y,w,h,skinned, signed strength)
  210. {
  211.         proc_info wForm;
  212.         dword shadow_buf = mem_Alloc(w*h*3);
  213.         GetProcessInfo(#wForm, SelfInfo);
  214.         CopyScreen(shadow_buf, 5*skinned+x+wForm.left, GetSkinHeight()*skinned+y+wForm.top, w, h);
  215.         ShadowImage(shadow_buf, w, h, strength);
  216.         _PutImage(x,y,w,h,shadow_buf);
  217.         mem_Free(shadow_buf);
  218. }
  219.  
  220. :void DrawPopup(dword x,y,w,h,skinned, col_work,col_border)
  221. {
  222.         DrawRectangle(x,y,w,h,col_border);
  223.         DrawBar(x+1,y+1,w-1,1,0xFFFfff);
  224.         DrawBar(x+1,y+2,1,h-2,0xFFFfff);
  225.         if (col_work!=-1) DrawBar(x+2,y+2,w-2,h-2,col_work);
  226.         DrawPopupShadow(x,y,w,h-1,skinned);
  227. }
  228.  
  229. :void Draw3DPopup(dword x,y,w,h)
  230. {
  231.         DrawRectangle3D(x,y,w,h, sc.work_dark, sc.work_graph);
  232.         DrawBar(x+1,y+1,w-1,1,sc.work_light);
  233.         DrawBar(x+1,y+2,1,h-2,sc.work_light);
  234.         DrawPopupShadow(x,y,w,h-1,0);
  235. }
  236.  
  237. :void DrawPopupShadow(dword x,y,w,h,skinned)
  238. {
  239.         PutShadow(w+x+1,y,1,h+2,skinned,2);
  240.         PutShadow(w+x+2,y+1,1,h+2,skinned,1);
  241.         PutShadow(x,y+h+2,w+2,1,skinned,2);
  242.         PutShadow(x+1,y+h+3,w+1,1,skinned,1);
  243. }
  244.  
  245. :dword GrayScaleImage(dword color_image, w, h)
  246. {
  247.         dword i,gray,to,rr,gg,bb;
  248.         to = w*h*3 + color_image;
  249.         for (i = color_image; i < to; i+=3)
  250.         {
  251.                 rr = DSBYTE[i];
  252.                 gg = DSBYTE[i+1];
  253.                 bb = DSBYTE[i+2];
  254.                 gray = rr*rr;
  255.                 gray += gg*gg;
  256.                 gray += bb*bb;
  257.                 gray = sqrt(gray) / 3;
  258.                 DSBYTE[i] = DSBYTE[i+1] = DSBYTE[i+2] = gray;
  259.         }
  260.         return gray;
  261. }
  262.  
  263. :void ShadowImage(dword color_image, w, h, signed strength)
  264. {
  265.         byte col;
  266.         dword to;
  267.         strength = 10 - strength;
  268.         to = w*h*3 + color_image;
  269.         for ( ; color_image < to; color_image++)
  270.         {
  271.                 col = math.min(strength * DSBYTE[color_image] / 10, 255);
  272.                 DSBYTE[color_image] = col;
  273.         }
  274. }
  275.  
  276. :void WriteTextLines(dword x,y,byte fontType, dword color, text_pointer, line_h)
  277. {
  278.         dword next_word_pointer = strchr(text_pointer, '\n');
  279.         if (next_word_pointer) WriteTextLines(dword x, y+line_h, byte fontType, dword color, next_word_pointer+2, line_h);
  280.         ESBYTE[next_word_pointer] = NULL;
  281.         WriteText(dword x, y, byte fontType, dword color, text_pointer);
  282.         ESBYTE[next_word_pointer] = '\n';
  283. }
  284.  
  285. :void DrawOvalBorder(dword x,y,w,h, light,dark,right,dots)
  286. {
  287.         DrawBar(x+1,    y,     w, 1,   light);
  288.         DrawBar(x+1,    y+h+1, w, 1,   dark);
  289.         DrawBar(x,      y+1,   1, h-1, light);
  290.         DrawBar(x+w+1,  y+2,   1, h-2, right);
  291.  
  292.         PutPixel(x,     y,     dots);
  293.         PutPixel(x+w+1, y+h+1, dots);
  294.         PutPixel(x,     y+h+1, dots);
  295.         PutPixel(x+w+1, y,     dots);
  296.        
  297.         PutPixel(x,     y+h, dark);
  298.         PutPixel(x+w+1, y+1, light);
  299.         PutPixel(x+w+1, y+h, dark);    
  300. }
  301.  
  302. :bool skin_is_dark()
  303. {
  304.         dword gray;
  305.         dword color_image = #sc.work;
  306.  
  307.         gray = DSBYTE[color_image]*DSBYTE[color_image];
  308.         gray += DSBYTE[color_image+1]*DSBYTE[color_image+1];
  309.         gray += DSBYTE[color_image+2]*DSBYTE[color_image+2];
  310.         gray = sqrt(gray) / 3;
  311.  
  312.         if (gray < 65) {
  313.                 return true;
  314.         } else {
  315.                 return false;
  316.         }
  317. }
  318.  
  319. //this function increase falue and return it
  320. //useful for list of controls which goes one after one
  321. :struct incn
  322. {
  323.         dword n;
  324.         dword inc(dword _addition);
  325.         dword set(dword _new_val);
  326. };
  327.  
  328. :dword incn::inc(dword _addition)
  329. {
  330.         n += _addition;
  331.         return n;
  332. }
  333.  
  334. :dword incn::set(dword _new_val)
  335. {
  336.         n =_new_val;
  337.         return n;
  338. }
  339.  
  340. //block with hover
  341. struct block {
  342.         int x,y,w,h;
  343.         bool hovered();
  344.         void set_size();
  345. };
  346.  
  347. :bool block::hovered() {
  348.         if ((mouse.x>=x) && (mouse.y>=y)
  349.         && (mouse.y<=y+h) && (mouse.x<=x+w))
  350.                 return true;
  351.         return false;
  352. }
  353.  
  354. :void block::set_size(dword _x, _y, _w, _h)
  355. {
  356.         x=_x;
  357.         y=_y;
  358.         w=_w;
  359.         h=_h;
  360. }
  361.  
  362.  
  363.  
  364.  
  365.  
  366. #endif