Subversion Repositories Kolibri OS

Rev

Rev 6794 | Go to most recent revision | Blame | Last modification | View Log | Download | RSS feed

  1. struct s_image
  2. {
  3.         dword *image;
  4.         char path[4096];
  5. };
  6.  
  7. s_image pics[100]; //pics = mem_Alloc( 100*sizeof(s_image) );
  8.  
  9. struct ImageCache {
  10.         int pics_count;
  11.         void Free();
  12.         int GetImage();
  13.         void Images();
  14. };
  15.  
  16. void ImageCache::Free()
  17. {
  18.         for ( ; pics_count>0; pics_count--)
  19.         {
  20.                 if (pics[pics_count].image) img_destroy stdcall (pics[pics_count].image);
  21.                 pics[pics_count].path = NULL;
  22.         }
  23. }
  24.  
  25. int ImageCache::GetImage(dword i_path)
  26. {
  27.         int i;
  28.         for (i=0; i<=pics_count; i++) if (!strcmp(#pics[i].path, i_path)) return i; //image exists
  29.         // Load image and add it to Cache
  30.         pics_count++;
  31.         pics[pics_count].image = load_image(i_path);
  32.         strcpy(#pics[pics_count].path, i_path);
  33.         return pics_count;
  34. }
  35.  
  36.  
  37. void ImageCache::Images(dword left1, top1, width1)
  38. {
  39.         dword image;
  40.     char img_path[4096], alt[4096]=0;
  41.     dword imgw=0, imgh=0, img_lines_first=0, cur_pic=0;
  42.        
  43.         do{
  44.                 if (isattr("src="))
  45.                 {
  46.                         strcpy(#img_path, #val);
  47.                         GetAbsoluteURL(#img_path);
  48.                         cur_pic = GetImage(#img_path);
  49.                 }
  50.                 if (isattr("alt="))
  51.                 {
  52.                         strcpy(#alt, "[");
  53.                         strcat(#alt, #val);
  54.                         strcat(#alt, "]");
  55.                 }
  56.  
  57.         } while(GetNextParam());
  58.        
  59.         if (!pics[cur_pic].image)
  60.         {
  61.                 if (alt) strcat(#line, #alt);
  62.                 //cur_pic = GetImage("/sys/network/noimg.png");
  63.                 return;
  64.         }
  65.        
  66.         imgw = DSWORD[pics[cur_pic].image+4];
  67.         imgh = DSWORD[pics[cur_pic].image+8];
  68.         if (imgw > width1) imgw = width1;
  69.        
  70.         draw_y += imgh + 5;
  71.         if (top1+imgh<WB1.list.y) || (top1>WB1.list.y+WB1.list.h-10) return; //if all image is out of visible area
  72.         if (top1<WB1.list.y) //if image partly visible (at the top)
  73.         {
  74.                 img_lines_first=WB1.list.y-top1;
  75.                 imgh=imgh-img_lines_first;
  76.                 top1=WB1.list.y;
  77.         }
  78.         if (top1>WB1.list.y+WB1.list.h-imgh-5) //if image partly visible (at the bottom)
  79.         {
  80.                 imgh=WB1.list.y+WB1.list.h-top1-5;
  81.         }      
  82.         if (imgh<=0) return;
  83.        
  84.         img_draw stdcall (pics[cur_pic].image, left1-5, top1, imgw, imgh,0,img_lines_first);
  85.         DrawBar(left1+imgw - 5, top1, WB1.list.w-imgw, imgh, bg_color);
  86.         DrawBar(WB1.list.x, top1+imgh, WB1.list.w, -imgh % WB1.list.item_h + WB1.list.item_h, bg_color);
  87.         if (link)
  88.         {
  89.                 //UnsafeDefineButton(left1 - 5, top1, imgw, imgh-1, PageLinks.count + 400 + BT_HIDE, 0xB5BFC9);
  90.                 //PageLinks.AddText(0, imgw, imgh-1, NOLINE, 1);
  91.                 //WB1.DrawPage();
  92.         }
  93. }
  94.  
  95. ImageCache ImgCache;