diff --git a/Makefile.sources b/Makefile.sources index ac2a7c403..ec7edc7a5 100644 --- a/Makefile.sources +++ b/Makefile.sources @@ -95,6 +95,7 @@ S_AMIGA := compat.c gui.c tree.c history.c hotlist.c schedule.c \ cookies.c context_menu.c clipboard.c save_complete.c \ fetch_file.c fetch_mailto.c search.c history_local.c \ download.c iff_dr2d.c sslcert.c gui_options.c print.c \ + theme.c \ stringview/stringview.c stringview/urlhistory.c S_AMIGA := $(addprefix amiga/,$(S_AMIGA)) diff --git a/amiga/download.c b/amiga/download.c index 20647afab..2172fb8cc 100644 --- a/amiga/download.c +++ b/amiga/download.c @@ -16,6 +16,8 @@ * along with this program. If not, see . */ +#include + #include #include #include @@ -33,6 +35,7 @@ #include "amiga/options.h" #include "amiga/bitmap.h" #include "amiga/iff_dr2d.h" +#include "amiga/theme.h" #include "content/fetch.h" @@ -42,8 +45,6 @@ #include "utils/messages.h" #include "utils/utils.h" -#include - #include #include diff --git a/amiga/gui.c b/amiga/gui.c index d47a7a4b5..22d7064d7 100755 --- a/amiga/gui.c +++ b/amiga/gui.c @@ -55,6 +55,7 @@ #include "amiga/print.h" #include "amiga/schedule.h" #include "amiga/search.h" +#include "amiga/theme.h" #include "amiga/tree.h" #include "amiga/utf8.h" @@ -69,7 +70,6 @@ #include #include #include -#include #include #include #include @@ -81,12 +81,11 @@ /* Other OS includes */ #include #include +#include #include #include #include #include -#include -#include #include #include #include @@ -141,8 +140,6 @@ struct ApplicationIFace *IApplication=NULL; Class *urlStringClass; -struct BitMap *throbber = NULL; -ULONG throbber_width,throbber_height,throbber_frames,throbber_update_interval; BOOL rmbtrapped; BOOL locked_screen = FALSE; BOOL screen_closed = FALSE; @@ -153,62 +150,12 @@ extern colour scroll_widget_fg_colour; extern colour scroll_widget_bg_colour; extern colour scroll_widget_arrow_colour; -static Object *mouseptrobj[AMI_LASTPOINTER+1]; -static struct BitMap *mouseptrbm[AMI_LASTPOINTER+1]; -static int mouseptrcurrent=0; static struct DrawInfo *dri; -char *ptrs[AMI_LASTPOINTER+1] = { - "ptr_default", - "ptr_point", - "ptr_caret", - "ptr_menu", - "ptr_up", - "ptr_down", - "ptr_left", - "ptr_right", - "ptr_rightup", - "ptr_leftdown", - "ptr_leftup", - "ptr_rightdown", - "ptr_cross", - "ptr_move", - "ptr_wait", - "ptr_help", - "ptr_nodrop", - "ptr_notallowed", - "ptr_progress", - "ptr_blank", - "ptr_drag"}; -char *ptrs32[AMI_LASTPOINTER+1] = { - "ptr32_default", - "ptr32_point", - "ptr32_caret", - "ptr32_menu", - "ptr32_up", - "ptr32_down", - "ptr32_left", - "ptr32_right", - "ptr32_rightup", - "ptr32_leftdown", - "ptr32_leftup", - "ptr32_rightdown", - "ptr32_cross", - "ptr32_move", - "ptr32_wait", - "ptr32_help", - "ptr32_nodrop", - "ptr32_notallowed", - "ptr32_progress", - "ptr32_blank", - "ptr32_drag"}; - -void ami_update_throbber(struct gui_window_2 *g,bool redraw); void ami_update_buttons(struct gui_window_2 *); void ami_scroller_hook(struct Hook *,Object *,struct IntuiMessage *); uint32 ami_popup_hook(struct Hook *hook,Object *item,APTR reserved); -void ami_init_mouse_pointers(void); void ami_switch_tab(struct gui_window_2 *gwin,bool redraw); void ami_change_tab(struct gui_window_2 *gwin, int direction); static void *myrealloc(void *ptr, size_t len, void *pw); @@ -265,12 +212,11 @@ int main(int argc, char** argv) void gui_init(int argc, char** argv) { struct Locale *locale; - char lang[100],throbberfile[100]; + char lang[100]; STRPTR tempacceptlangs; bool found=FALSE; int i; - BPTR lock=0,amiupdatefh; - Object *dto; + BPTR lock = 0, amiupdatefh = 0; msgport = AllocSysObjectTags(ASOT_PORT, ASO_NoTrack,FALSE, @@ -496,71 +442,9 @@ void gui_init(int argc, char** argv) ami_global_history_initialise(); ami_cookies_initialise(); save_complete_init(); - - strcpy(throbberfile,option_theme); - AddPart(throbberfile,"Theme",100); - - lock = Lock(throbberfile,ACCESS_READ); - - if(!lock) - { - warn_user("ThemeApplyErr",option_theme); - strcpy(throbberfile,"PROGDIR:Resources/Themes/Default/Theme"); - free(option_theme); - option_theme = (char *)strdup("PROGDIR:Resources/Themes/Default"); - } - else - { - UnLock(lock); - } - - messages_load(throbberfile); - + ami_theme_init(); ami_init_mouse_pointers(); - - ami_get_theme_filename(throbberfile,"theme_throbber"); - throbber_frames=atoi(messages_get("theme_throbber_frames")); - throbber_update_interval = atoi(messages_get("theme_throbber_delay")); - if(throbber_update_interval == 0) throbber_update_interval = 100; - - if(dto = NewDTObject(throbberfile, - DTA_GroupID,GID_PICTURE, - PDTA_DestMode,PMODE_V43, - TAG_DONE)) - { - struct BitMapHeader *throbber_bmh; - struct RastPort throbber_rp; - - if(GetDTAttrs(dto,PDTA_BitMapHeader,&throbber_bmh,TAG_DONE)) - { - throbber_width = throbber_bmh->bmh_Width / throbber_frames; - throbber_height = throbber_bmh->bmh_Height; - throbber_bmh->bmh_Masking = mskHasAlpha; - - InitRastPort(&throbber_rp); - - if(throbber = p96AllocBitMap(throbber_bmh->bmh_Width, - throbber_height,32, - BMF_CLEAR | BMF_DISPLAYABLE | BMF_INTERLEAVED, - NULL,RGBFB_A8R8G8B8)) - { - struct RenderInfo ri; - UBYTE *throbber_tempmem = AllocVec(throbber_bmh->bmh_Width*throbber_height*4,MEMF_PRIVATE | MEMF_CLEAR); - throbber_rp.BitMap = throbber; - ri.Memory = throbber_tempmem; - ri.BytesPerRow = 4*throbber_bmh->bmh_Width; - ri.RGBFormat = RGBFB_A8R8G8B8; - - IDoMethod(dto,PDTM_READPIXELARRAY,ri.Memory,PBPAFMT_ARGB,ri.BytesPerRow,0,0,throbber_bmh->bmh_Width,throbber_height); - - p96WritePixelArray((struct RenderInfo *)&ri,0,0,&throbber_rp,0,0,throbber_bmh->bmh_Width,throbber_height); - - FreeVec(throbber_tempmem); - } - } - DisposeDTObject(dto); - } - + ami_theme_throbber_setup(); } void ami_openscreen(void) @@ -1973,7 +1857,7 @@ void gui_quit(void) { int i; - p96FreeBitMap(throbber); + ami_theme_throbber_free(); urldb_save(option_url_file); urldb_save_cookies(option_cookie_file); @@ -2010,16 +1894,7 @@ void gui_quit(void) if(option_context_menu) ami_context_menu_free(); ami_free_menulabs(); - for(i=0;i<=AMI_LASTPOINTER;i++) - { - if(mouseptrbm[i]) - { - FreeRaster(mouseptrbm[i]->Planes[0],16,16); - FreeRaster(mouseptrbm[i]->Planes[1],16,16); - FreeVec(mouseptrbm[i]); - } - } - + ami_mouse_pointers_free(); ami_clipboard_free(); ami_print_free(); @@ -2111,16 +1986,6 @@ void ami_update_buttons(struct gui_window_2 *gwin) } } -void ami_get_theme_filename(char *filename,char *themestring) -{ - if(messages_get(themestring)[0] == '*') strncpy(filename,messages_get(themestring)+1,100); - else - { - strcpy(filename,option_theme); - AddPart(filename,messages_get(themestring),100); - } -} - void ami_toggletabbar(struct gui_window_2 *gwin, bool show) { if(ClickTabBase->lib_Version < 53) return; @@ -3463,191 +3328,6 @@ void gui_window_set_status(struct gui_window *g, const char *text) } } -void gui_window_set_pointer(struct gui_window *g, gui_pointer_shape shape) -{ - ami_update_pointer(g->shared->win,shape); -} - -void ami_update_pointer(struct Window *win, gui_pointer_shape shape) -{ - if(mouseptrcurrent == shape) return; - if(drag_save) return; - - if(option_use_os_pointers) - { - switch(shape) - { - case GUI_POINTER_DEFAULT: - SetWindowPointer(win,TAG_DONE); - break; - - case GUI_POINTER_WAIT: - SetWindowPointer(win, - WA_BusyPointer,TRUE, - WA_PointerDelay,TRUE, - TAG_DONE); - break; - - default: - if(mouseptrobj[shape]) - { - SetWindowPointer(win,WA_Pointer,mouseptrobj[shape],TAG_DONE); - } - else - { - SetWindowPointer(win,TAG_DONE); - } - break; - } - } - else - { - if(mouseptrobj[shape]) - { - SetWindowPointer(win,WA_Pointer,mouseptrobj[shape],TAG_DONE); - } - else - { - if(shape == GUI_POINTER_WAIT) - { - SetWindowPointer(win, - WA_BusyPointer,TRUE, - WA_PointerDelay,TRUE, - TAG_DONE); - } - else - { - SetWindowPointer(win,TAG_DONE); - } - } - } - - mouseptrcurrent = shape; -} - -void gui_window_hide_pointer(struct gui_window *g) -{ - if(mouseptrcurrent != AMI_GUI_POINTER_BLANK) - { - SetWindowPointer(g->shared->win,WA_Pointer,mouseptrobj[AMI_GUI_POINTER_BLANK],TAG_DONE); - mouseptrcurrent = AMI_GUI_POINTER_BLANK; - } -} - -void ami_init_mouse_pointers(void) -{ - int i; - struct RastPort mouseptr; - struct DiskObject *dobj; - uint32 format = IDFMT_BITMAPPED; - int32 mousexpt=0,mouseypt=0; - - InitRastPort(&mouseptr); - - for(i=0;i<=AMI_LASTPOINTER;i++) - { - BPTR ptrfile = 0; - mouseptrbm[i] = NULL; - mouseptrobj[i] = NULL; - char ptrfname[1024]; - - if(option_truecolour_mouse_pointers) - { - ami_get_theme_filename(&ptrfname,ptrs32[i]); - if(dobj = GetIconTags(ptrfname,ICONGETA_UseFriendBitMap,TRUE,TAG_DONE)) - { - if(IconControl(dobj, ICONCTRLA_GetImageDataFormat, &format, TAG_DONE)) - { - if(IDFMT_DIRECTMAPPED == format) - { - int32 width = 0, height = 0; - uint8* data = 0; - IconControl(dobj, - ICONCTRLA_GetWidth, &width, - ICONCTRLA_GetHeight, &height, - ICONCTRLA_GetImageData1, &data, - TAG_DONE); - - if (width > 0 && width <= 64 && height > 0 && height <= 64 && data) - { - STRPTR tooltype; - - if(tooltype = FindToolType(dobj->do_ToolTypes, "XOFFSET")) - mousexpt = atoi(tooltype); - - if(tooltype = FindToolType(dobj->do_ToolTypes, "YOFFSET")) - mouseypt = atoi(tooltype); - - if (mousexpt < 0 || mousexpt >= width) - mousexpt = 0; - if (mouseypt < 0 || mouseypt >= height) - mouseypt = 0; - - static uint8 dummyPlane[64 * 64 / 8]; - static struct BitMap dummyBitMap = { 64 / 8, 64, 0, 2, 0, { dummyPlane, dummyPlane, 0, 0, 0, 0, 0, 0 }, }; - - mouseptrobj[i] = NewObject(NULL, "pointerclass", - POINTERA_BitMap, &dummyBitMap, - POINTERA_XOffset, -mousexpt, - POINTERA_YOffset, -mouseypt, - POINTERA_WordWidth, (width + 15) / 16, - POINTERA_XResolution, POINTERXRESN_SCREENRES, - POINTERA_YResolution, POINTERYRESN_SCREENRESASPECT, - POINTERA_ImageData, data, - POINTERA_Width, width, - POINTERA_Height, height, - TAG_DONE); - } - } - } - } - } - - if(!mouseptrobj[i]) - { - ami_get_theme_filename(ptrfname,ptrs[i]); - if(ptrfile = Open(ptrfname,MODE_OLDFILE)) - { - int mx,my; - UBYTE *pprefsbuf = AllocVec(1061,MEMF_PRIVATE | MEMF_CLEAR); - Read(ptrfile,pprefsbuf,1061); - - mouseptrbm[i]=AllocVec(sizeof(struct BitMap),MEMF_PRIVATE | MEMF_CLEAR); - InitBitMap(mouseptrbm[i],2,32,32); - mouseptrbm[i]->Planes[0] = AllocRaster(32,32); - mouseptrbm[i]->Planes[1] = AllocRaster(32,32); - mouseptr.BitMap = mouseptrbm[i]; - - for(my=0;my<32;my++) - { - for(mx=0;mx<32;mx++) - { - SetAPen(&mouseptr,pprefsbuf[(my*(33))+mx]-'0'); - WritePixel(&mouseptr,mx,my); - } - } - - mousexpt = ((pprefsbuf[1056]-'0')*10)+(pprefsbuf[1057]-'0'); - mouseypt = ((pprefsbuf[1059]-'0')*10)+(pprefsbuf[1060]-'0'); - - mouseptrobj[i] = NewObject(NULL,"pointerclass", - POINTERA_BitMap,mouseptrbm[i], - POINTERA_WordWidth,2, - POINTERA_XOffset,-mousexpt, - POINTERA_YOffset,-mouseypt, - POINTERA_XResolution,POINTERXRESN_SCREENRES, - POINTERA_YResolution,POINTERYRESN_SCREENRESASPECT, - TAG_DONE); - - FreeVec(pprefsbuf); - Close(ptrfile); - } - - } - - } // for -} - void gui_window_set_url(struct gui_window *g, const char *url) { ULONG cur_tab = 0; @@ -3665,64 +3345,6 @@ void gui_window_set_url(struct gui_window *g, const char *url) } } -void gui_window_start_throbber(struct gui_window *g) -{ - struct IBox *bbox; - ULONG cur_tab = 0; - - if(!g) return; - - if(g->tab_node && (g->shared->tabs > 1)) - { - GetAttr(CLICKTAB_Current, g->shared->objects[GID_TABS], - (ULONG *)&cur_tab); - SetClickTabNodeAttrs(g->tab_node, TNA_Flagged, TRUE, TAG_DONE); - RefreshGadgets((APTR)g->shared->objects[GID_TABS], - g->shared->win, NULL); - } - - g->throbbing = true; - - if((cur_tab == g->tab) || (g->shared->tabs <= 1)) - { - GetAttr(SPACE_AreaBox, g->shared->objects[GID_THROBBER], - (ULONG *)&bbox); - - if(g->shared->throbber_frame == 0) g->shared->throbber_frame=1; - - BltBitMapRastPort(throbber,throbber_width,0,g->shared->win->RPort,bbox->Left,bbox->Top,throbber_width,throbber_height,0x0C0); - } -} - -void gui_window_stop_throbber(struct gui_window *g) -{ - struct IBox *bbox; - ULONG cur_tab = 0; - - if(!g) return; - - if(g->tab_node && (g->shared->tabs > 1)) - { - GetAttr(CLICKTAB_Current, g->shared->objects[GID_TABS], - (ULONG *)&cur_tab); - SetClickTabNodeAttrs(g->tab_node, TNA_Flagged, FALSE, TAG_DONE); - RefreshGadgets((APTR)g->shared->objects[GID_TABS], - g->shared->win, NULL); - } - - g->throbbing = false; - - if((cur_tab == g->tab) || (g->shared->tabs <= 1)) - { - GetAttr(SPACE_AreaBox, g->shared->objects[GID_THROBBER], - (ULONG *)&bbox); - - BltBitMapRastPort(throbber, 0, 0, g->shared->win->RPort, bbox->Left, - bbox->Top, throbber_width, throbber_height, 0x0C0); - } -// g->shared->throbber_frame = 0; -} - /** * function to add retrieved favicon to gui */ @@ -3848,59 +3470,6 @@ void gui_window_set_search_ico(struct content *ico) } while(node = nnode); } -void ami_update_throbber(struct gui_window_2 *g,bool redraw) -{ - struct IBox *bbox; - int frame = g->throbber_frame; - - if(!g) return; - if(!g->objects[GID_THROBBER]) return; - - if(g->bw->window->throbbing == false) - { - frame = 0; - g->throbber_frame=1; - } - else - { - if(!redraw) - { - if(g->throbber_update_count < throbber_update_interval) - { - g->throbber_update_count++; - return; - } - - g->throbber_update_count = 0; - - g->throbber_frame++; - if(g->throbber_frame > (throbber_frames-1)) - g->throbber_frame=1; - - } - } - - GetAttr(SPACE_AreaBox,(Object *)g->objects[GID_THROBBER],(ULONG *)&bbox); - -/* - EraseRect(g->win->RPort,bbox->Left,bbox->Top, - bbox->Left+throbber_width,bbox->Top+throbber_height); -*/ - - BltBitMapTags(BLITA_SrcX, throbber_width * frame, - BLITA_SrcY,0, - BLITA_DestX,bbox->Left, - BLITA_DestY,bbox->Top, - BLITA_Width,throbber_width, - BLITA_Height,throbber_height, - BLITA_Source,throbber, - BLITA_Dest,g->win->RPort, - BLITA_SrcType,BLITT_BITMAP, - BLITA_DestType,BLITT_RASTPORT, -// BLITA_UseSrcAlpha,TRUE, - TAG_DONE); -} - void gui_window_place_caret(struct gui_window *g, int x, int y, int height) { struct IBox *bbox; diff --git a/amiga/gui.h b/amiga/gui.h index 14bf794ce..5509c0314 100755 --- a/amiga/gui.h +++ b/amiga/gui.h @@ -74,10 +74,6 @@ enum GID_LAST }; -#define AMI_GUI_POINTER_BLANK GUI_POINTER_PROGRESS+1 -#define AMI_GUI_POINTER_DRAG GUI_POINTER_PROGRESS+2 -#define AMI_LASTPOINTER AMI_GUI_POINTER_DRAG - struct find_window; struct history_window; @@ -127,10 +123,8 @@ struct gui_window }; void ami_get_msg(void); -void ami_update_pointer(struct Window *win, gui_pointer_shape shape); void ami_close_all_tabs(struct gui_window_2 *gwin); void ami_quit_netsurf(void); -void ami_get_theme_filename(char *filename,char *themestring); void ami_do_redraw(struct gui_window_2 *g); STRPTR ami_locale_langs(void); diff --git a/amiga/theme.c b/amiga/theme.c new file mode 100644 index 000000000..f25ba12ba --- /dev/null +++ b/amiga/theme.c @@ -0,0 +1,495 @@ +/* + * Copyright 2010 Chris Young + * + * This file is part of NetSurf, http://www.netsurf-browser.org/ + * + * NetSurf is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * NetSurf is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#include + +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include + +#include "amiga/download.h" +#include "amiga/options.h" +#include "amiga/theme.h" +#include "utils/messages.h" +#include "utils/utils.h" + +struct BitMap *throbber = NULL; +ULONG throbber_frames,throbber_update_interval; +static Object *mouseptrobj[AMI_LASTPOINTER+1]; +static struct BitMap *mouseptrbm[AMI_LASTPOINTER+1]; +static int mouseptrcurrent=0; + +char *ptrs[AMI_LASTPOINTER+1] = { + "ptr_default", + "ptr_point", + "ptr_caret", + "ptr_menu", + "ptr_up", + "ptr_down", + "ptr_left", + "ptr_right", + "ptr_rightup", + "ptr_leftdown", + "ptr_leftup", + "ptr_rightdown", + "ptr_cross", + "ptr_move", + "ptr_wait", + "ptr_help", + "ptr_nodrop", + "ptr_notallowed", + "ptr_progress", + "ptr_blank", + "ptr_drag"}; + +char *ptrs32[AMI_LASTPOINTER+1] = { + "ptr32_default", + "ptr32_point", + "ptr32_caret", + "ptr32_menu", + "ptr32_up", + "ptr32_down", + "ptr32_left", + "ptr32_right", + "ptr32_rightup", + "ptr32_leftdown", + "ptr32_leftup", + "ptr32_rightdown", + "ptr32_cross", + "ptr32_move", + "ptr32_wait", + "ptr32_help", + "ptr32_nodrop", + "ptr32_notallowed", + "ptr32_progress", + "ptr32_blank", + "ptr32_drag"}; + +void ami_theme_init(void) +{ + char themefile[1024]; + BPTR lock = 0; + + strcpy(themefile,option_theme); + AddPart(themefile,"Theme",100); + + lock = Lock(themefile,ACCESS_READ); + + if(!lock) + { + warn_user("ThemeApplyErr",option_theme); + strcpy(themefile,"PROGDIR:Resources/Themes/Default/Theme"); + free(option_theme); + option_theme = (char *)strdup("PROGDIR:Resources/Themes/Default"); + } + else + { + UnLock(lock); + } + + messages_load(themefile); +} + +void ami_theme_throbber_setup(void) +{ + char throbberfile[1024]; + Object *dto; + + ami_get_theme_filename(throbberfile,"theme_throbber"); + throbber_frames=atoi(messages_get("theme_throbber_frames")); + throbber_update_interval = atoi(messages_get("theme_throbber_delay")); + if(throbber_update_interval == 0) throbber_update_interval = 100; + + if(dto = NewDTObject(throbberfile, + DTA_GroupID,GID_PICTURE, + PDTA_DestMode,PMODE_V43, + TAG_DONE)) + { + struct BitMapHeader *throbber_bmh; + struct RastPort throbber_rp; + + if(GetDTAttrs(dto,PDTA_BitMapHeader,&throbber_bmh,TAG_DONE)) + { + throbber_width = throbber_bmh->bmh_Width / throbber_frames; + throbber_height = throbber_bmh->bmh_Height; + throbber_bmh->bmh_Masking = mskHasAlpha; + + InitRastPort(&throbber_rp); + + if(throbber = p96AllocBitMap(throbber_bmh->bmh_Width, + throbber_height,32, + BMF_CLEAR | BMF_DISPLAYABLE | BMF_INTERLEAVED, + NULL,RGBFB_A8R8G8B8)) + { + struct RenderInfo ri; + UBYTE *throbber_tempmem = AllocVec(throbber_bmh->bmh_Width*throbber_height*4,MEMF_PRIVATE | MEMF_CLEAR); + throbber_rp.BitMap = throbber; + ri.Memory = throbber_tempmem; + ri.BytesPerRow = 4*throbber_bmh->bmh_Width; + ri.RGBFormat = RGBFB_A8R8G8B8; + + IDoMethod(dto,PDTM_READPIXELARRAY,ri.Memory,PBPAFMT_ARGB,ri.BytesPerRow,0,0,throbber_bmh->bmh_Width,throbber_height); + + p96WritePixelArray((struct RenderInfo *)&ri,0,0,&throbber_rp,0,0,throbber_bmh->bmh_Width,throbber_height); + + FreeVec(throbber_tempmem); + } + } + DisposeDTObject(dto); + } +} + +void ami_theme_throbber_free(void) +{ + p96FreeBitMap(throbber); +} + +void ami_get_theme_filename(char *filename, char *themestring) +{ + if(messages_get(themestring)[0] == '*') + { + strncpy(filename, messages_get(themestring) + 1, 100); + } + else + { + strcpy(filename, option_theme); + AddPart(filename, messages_get(themestring), 100); + } +} + +void gui_window_set_pointer(struct gui_window *g, gui_pointer_shape shape) +{ + ami_update_pointer(g->shared->win,shape); +} + +void ami_update_pointer(struct Window *win, gui_pointer_shape shape) +{ + if(mouseptrcurrent == shape) return; + if(drag_save) return; + + if(option_use_os_pointers) + { + switch(shape) + { + case GUI_POINTER_DEFAULT: + SetWindowPointer(win,TAG_DONE); + break; + + case GUI_POINTER_WAIT: + SetWindowPointer(win, + WA_BusyPointer,TRUE, + WA_PointerDelay,TRUE, + TAG_DONE); + break; + + default: + if(mouseptrobj[shape]) + { + SetWindowPointer(win,WA_Pointer,mouseptrobj[shape],TAG_DONE); + } + else + { + SetWindowPointer(win,TAG_DONE); + } + break; + } + } + else + { + if(mouseptrobj[shape]) + { + SetWindowPointer(win,WA_Pointer,mouseptrobj[shape],TAG_DONE); + } + else + { + if(shape == GUI_POINTER_WAIT) + { + SetWindowPointer(win, + WA_BusyPointer,TRUE, + WA_PointerDelay,TRUE, + TAG_DONE); + } + else + { + SetWindowPointer(win,TAG_DONE); + } + } + } + + mouseptrcurrent = shape; +} + +void gui_window_hide_pointer(struct gui_window *g) +{ + if(mouseptrcurrent != AMI_GUI_POINTER_BLANK) + { + SetWindowPointer(g->shared->win,WA_Pointer,mouseptrobj[AMI_GUI_POINTER_BLANK],TAG_DONE); + mouseptrcurrent = AMI_GUI_POINTER_BLANK; + } +} + +void ami_init_mouse_pointers(void) +{ + int i; + struct RastPort mouseptr; + struct DiskObject *dobj; + uint32 format = IDFMT_BITMAPPED; + int32 mousexpt=0,mouseypt=0; + + InitRastPort(&mouseptr); + + for(i=0;i<=AMI_LASTPOINTER;i++) + { + BPTR ptrfile = 0; + mouseptrbm[i] = NULL; + mouseptrobj[i] = NULL; + char ptrfname[1024]; + + if(option_truecolour_mouse_pointers) + { + ami_get_theme_filename(&ptrfname,ptrs32[i]); + if(dobj = GetIconTags(ptrfname,ICONGETA_UseFriendBitMap,TRUE,TAG_DONE)) + { + if(IconControl(dobj, ICONCTRLA_GetImageDataFormat, &format, TAG_DONE)) + { + if(IDFMT_DIRECTMAPPED == format) + { + int32 width = 0, height = 0; + uint8* data = 0; + IconControl(dobj, + ICONCTRLA_GetWidth, &width, + ICONCTRLA_GetHeight, &height, + ICONCTRLA_GetImageData1, &data, + TAG_DONE); + + if (width > 0 && width <= 64 && height > 0 && height <= 64 && data) + { + STRPTR tooltype; + + if(tooltype = FindToolType(dobj->do_ToolTypes, "XOFFSET")) + mousexpt = atoi(tooltype); + + if(tooltype = FindToolType(dobj->do_ToolTypes, "YOFFSET")) + mouseypt = atoi(tooltype); + + if (mousexpt < 0 || mousexpt >= width) + mousexpt = 0; + if (mouseypt < 0 || mouseypt >= height) + mouseypt = 0; + + static uint8 dummyPlane[64 * 64 / 8]; + static struct BitMap dummyBitMap = { 64 / 8, 64, 0, 2, 0, { dummyPlane, dummyPlane, 0, 0, 0, 0, 0, 0 }, }; + + mouseptrobj[i] = NewObject(NULL, "pointerclass", + POINTERA_BitMap, &dummyBitMap, + POINTERA_XOffset, -mousexpt, + POINTERA_YOffset, -mouseypt, + POINTERA_WordWidth, (width + 15) / 16, + POINTERA_XResolution, POINTERXRESN_SCREENRES, + POINTERA_YResolution, POINTERYRESN_SCREENRESASPECT, + POINTERA_ImageData, data, + POINTERA_Width, width, + POINTERA_Height, height, + TAG_DONE); + } + } + } + } + } + + if(!mouseptrobj[i]) + { + ami_get_theme_filename(ptrfname,ptrs[i]); + if(ptrfile = Open(ptrfname,MODE_OLDFILE)) + { + int mx,my; + UBYTE *pprefsbuf = AllocVec(1061,MEMF_PRIVATE | MEMF_CLEAR); + Read(ptrfile,pprefsbuf,1061); + + mouseptrbm[i]=AllocVec(sizeof(struct BitMap),MEMF_PRIVATE | MEMF_CLEAR); + InitBitMap(mouseptrbm[i],2,32,32); + mouseptrbm[i]->Planes[0] = AllocRaster(32,32); + mouseptrbm[i]->Planes[1] = AllocRaster(32,32); + mouseptr.BitMap = mouseptrbm[i]; + + for(my=0;my<32;my++) + { + for(mx=0;mx<32;mx++) + { + SetAPen(&mouseptr,pprefsbuf[(my*(33))+mx]-'0'); + WritePixel(&mouseptr,mx,my); + } + } + + mousexpt = ((pprefsbuf[1056]-'0')*10)+(pprefsbuf[1057]-'0'); + mouseypt = ((pprefsbuf[1059]-'0')*10)+(pprefsbuf[1060]-'0'); + + mouseptrobj[i] = NewObject(NULL,"pointerclass", + POINTERA_BitMap,mouseptrbm[i], + POINTERA_WordWidth,2, + POINTERA_XOffset,-mousexpt, + POINTERA_YOffset,-mouseypt, + POINTERA_XResolution,POINTERXRESN_SCREENRES, + POINTERA_YResolution,POINTERYRESN_SCREENRESASPECT, + TAG_DONE); + + FreeVec(pprefsbuf); + Close(ptrfile); + } + + } + + } // for +} + +void ami_mouse_pointers_free(void) +{ + int i; + + for(i=0;i<=AMI_LASTPOINTER;i++) + { + if(mouseptrbm[i]) + { + FreeRaster(mouseptrbm[i]->Planes[0],16,16); + FreeRaster(mouseptrbm[i]->Planes[1],16,16); + FreeVec(mouseptrbm[i]); + } + } +} + +void gui_window_start_throbber(struct gui_window *g) +{ + struct IBox *bbox; + ULONG cur_tab = 0; + + if(!g) return; + + if(g->tab_node && (g->shared->tabs > 1)) + { + GetAttr(CLICKTAB_Current, g->shared->objects[GID_TABS], + (ULONG *)&cur_tab); + SetClickTabNodeAttrs(g->tab_node, TNA_Flagged, TRUE, TAG_DONE); + RefreshGadgets((APTR)g->shared->objects[GID_TABS], + g->shared->win, NULL); + } + + g->throbbing = true; + + if((cur_tab == g->tab) || (g->shared->tabs <= 1)) + { + GetAttr(SPACE_AreaBox, g->shared->objects[GID_THROBBER], + (ULONG *)&bbox); + + if(g->shared->throbber_frame == 0) g->shared->throbber_frame=1; + + BltBitMapRastPort(throbber,throbber_width,0,g->shared->win->RPort,bbox->Left,bbox->Top,throbber_width,throbber_height,0x0C0); + } +} + +void gui_window_stop_throbber(struct gui_window *g) +{ + struct IBox *bbox; + ULONG cur_tab = 0; + + if(!g) return; + + if(g->tab_node && (g->shared->tabs > 1)) + { + GetAttr(CLICKTAB_Current, g->shared->objects[GID_TABS], + (ULONG *)&cur_tab); + SetClickTabNodeAttrs(g->tab_node, TNA_Flagged, FALSE, TAG_DONE); + RefreshGadgets((APTR)g->shared->objects[GID_TABS], + g->shared->win, NULL); + } + + g->throbbing = false; + + if((cur_tab == g->tab) || (g->shared->tabs <= 1)) + { + GetAttr(SPACE_AreaBox, g->shared->objects[GID_THROBBER], + (ULONG *)&bbox); + + BltBitMapRastPort(throbber, 0, 0, g->shared->win->RPort, bbox->Left, + bbox->Top, throbber_width, throbber_height, 0x0C0); + } +// g->shared->throbber_frame = 0; +} + +void ami_update_throbber(struct gui_window_2 *g,bool redraw) +{ + struct IBox *bbox; + int frame = g->throbber_frame; + + if(!g) return; + if(!g->objects[GID_THROBBER]) return; + + if(g->bw->window->throbbing == false) + { + frame = 0; + g->throbber_frame=1; + } + else + { + if(!redraw) + { + if(g->throbber_update_count < throbber_update_interval) + { + g->throbber_update_count++; + return; + } + + g->throbber_update_count = 0; + + g->throbber_frame++; + if(g->throbber_frame > (throbber_frames-1)) + g->throbber_frame=1; + + } + } + + GetAttr(SPACE_AreaBox,(Object *)g->objects[GID_THROBBER],(ULONG *)&bbox); + +/* + EraseRect(g->win->RPort,bbox->Left,bbox->Top, + bbox->Left+throbber_width,bbox->Top+throbber_height); +*/ + + BltBitMapTags(BLITA_SrcX, throbber_width * frame, + BLITA_SrcY,0, + BLITA_DestX,bbox->Left, + BLITA_DestY,bbox->Top, + BLITA_Width,throbber_width, + BLITA_Height,throbber_height, + BLITA_Source,throbber, + BLITA_Dest,g->win->RPort, + BLITA_SrcType,BLITT_BITMAP, + BLITA_DestType,BLITT_RASTPORT, +// BLITA_UseSrcAlpha,TRUE, + TAG_DONE); +} diff --git a/amiga/theme.h b/amiga/theme.h new file mode 100644 index 000000000..3a396fdb1 --- /dev/null +++ b/amiga/theme.h @@ -0,0 +1,39 @@ +/* + * Copyright 2010 Chris Young + * + * This file is part of NetSurf, http://www.netsurf-browser.org/ + * + * NetSurf is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * NetSurf is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#ifndef AMIGA_THEME_H +#define AMIGA_THEME_H +#include "amiga/gui.h" + +#define AMI_GUI_POINTER_BLANK GUI_POINTER_PROGRESS+1 +#define AMI_GUI_POINTER_DRAG GUI_POINTER_PROGRESS+2 +#define AMI_LASTPOINTER AMI_GUI_POINTER_DRAG + +ULONG throbber_width, throbber_height; + +void ami_theme_init(void); +void ami_get_theme_filename(char *filename, char *themestring); + +void ami_theme_throbber_setup(void); +void ami_theme_throbber_free(void); +void ami_update_throbber(struct gui_window_2 *g,bool redraw); + +void ami_init_mouse_pointers(void); +void ami_mouse_pointers_free(void); +void ami_update_pointer(struct Window *win, gui_pointer_shape shape); +#endif