forked from len0rd/rockbox
		
	* the bar orientation (horiz/vert) is now chosen based on the width and heigt values (or can be forced). * the fill direction can now be inverted (fill right to left, or top to bottom is considered inverted) * It can now draw a slider type bar instead of a fill type (or indeed a slider with a fill type) To configure the new bar, any (or all) of the following params can be used after the bmp filename (order makes no difference either): invert - cause the bar to fill in the inverted direction vertical - draw a vertical bar (not needed if the height > width) horizontal - draw a horizontal bar (this is obviously the default) nofill - dont draw the filling bar (this still draws the outline, obviously pointless without the slider param) slider - draw an image for the slider. The next param MUST be the label of the image to draw. No option to use a subimage here, so the whole image needs to be the image you want on the slider. example: %pb(0,0,-,-,-,nofill, slider, slider_image, invert) - draw a boring horizontal progressbar which doesnt fill and only draws the image "slider_image" which moves right to left. the slider type might need some tweaking. let us know how it goes git-svn-id: svn://svn.rockbox.org/rockbox/trunk@27821 a1c6a512-1295-4272-9138-f99709370657
		
			
				
	
	
		
			65 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***************************************************************************
 | |
|  *             __________               __   ___.
 | |
|  *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 | |
|  *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 | |
|  *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 | |
|  *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 | |
|  *                     \/            \/     \/    \/            \/
 | |
|  * $Id$
 | |
|  *
 | |
|  * Copyright (C) 2005 Kevin Ferrare
 | |
|  *
 | |
|  * This program 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; either version 2
 | |
|  * of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 | |
|  * KIND, either express or implied.
 | |
|  *
 | |
|  ****************************************************************************/
 | |
| 
 | |
| #ifndef _GUI_SCROLLBAR_H_
 | |
| #define _GUI_SCROLLBAR_H_
 | |
| #include "screen_access.h"
 | |
| 
 | |
| #ifdef HAVE_LCD_BITMAP
 | |
| 
 | |
| enum orientation {
 | |
|     VERTICAL          = 0x0000,   /* Vertical orientation     */
 | |
|     HORIZONTAL        = 0x0001,   /* Horizontal orientation   */
 | |
|     INVERTFILL        = 0x0002,   /* Invert the fill direction */
 | |
| #ifdef HAVE_LCD_COLOR
 | |
|     FOREGROUND        = 0x0020,   /* Do not clear background pixels */
 | |
|     INNER_FILL        = 0x0040,   /* Fill inner part even if FOREGROUND */
 | |
|     INNER_BGFILL      = 0x0080,   /* Fill inner part with background
 | |
|                                      color even if FOREGROUND */
 | |
|     INNER_FILL_MASK   = 0x00c0,
 | |
| #endif
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Draws a scrollbar on the given screen
 | |
|  *  - screen : the screen to put the scrollbar on
 | |
|  *  - x : x start position of the scrollbar
 | |
|  *  - y : y start position of the scrollbar
 | |
|  *  - width : you won't guess =(^o^)=
 | |
|  *  - height : I won't tell you either !
 | |
|  *  - items : total number of items on the screen
 | |
|  *  - min_shown : index of the starting item on the screen
 | |
|  *  - max_shown : index of the last item on the screen
 | |
|  *  - orientation : either VERTICAL or HORIZONTAL
 | |
|  */
 | |
| extern void gui_scrollbar_draw(struct screen * screen, int x, int y,
 | |
|                                int width, int height, int items,
 | |
|                                int min_shown, int max_shown,
 | |
|                                unsigned flags);
 | |
| extern void gui_bitmap_scrollbar_draw(struct screen * screen, struct bitmap *bm,
 | |
|                             int x, int y,
 | |
|                             int width, int height, int items,
 | |
|                             int min_shown, int max_shown,
 | |
|                             unsigned flags);
 | |
| extern void show_busy_slider(struct screen *s, int x, int y,
 | |
|                             int width, int height);
 | |
| #endif /* HAVE_LCD_BITMAP */
 | |
| #endif /* _GUI_SCROLLBAR_H_ */
 |