xref: /haiku/src/servers/app/CursorManager.h (revision 99d1318ec02694fc520a0dc38ae38565db7e8c3c)
1 /*
2  * Copyright 2001-2010, Haiku.
3  * Distributed under the terms of the MIT License.
4  *
5  * Authors:
6  *		DarkWyrm <bpmagic@columbus.rr.com>
7  */
8 #ifndef CURSOR_MANAGER_H
9 #define CURSOR_MANAGER_H
10 
11 
12 #include <List.h>
13 #include <Locker.h>
14 
15 #include <TokenSpace.h>
16 
17 #include "CursorSet.h"
18 
19 using BPrivate::BTokenSpace;
20 class ServerCursor;
21 
22 
23 /*!
24 	\class CursorManager CursorManager.h
25 	\brief Handles almost all cursor management functions for the system
26 
27 	The Cursor manager provides system cursor support, previous unseen on
28 	any BeOS platform. It also provides tokens for BCursors and frees all
29 	of an application's cursors whenever an application closes.
30 */
31 class CursorManager : public BLocker {
32 public:
33 								CursorManager();
34 								~CursorManager();
35 
36 			ServerCursor*		CreateCursor(team_id clientTeam,
37 									 const uint8* cursorData);
38 			ServerCursor*		CreateCursor(team_id clientTeam,
39 									BRect r, color_space format, int32 flags,
40 									BPoint hotspot, int32 bytesPerRow = -1);
41 
42 			int32				AddCursor(ServerCursor* cursor,
43 									int32 token = -1);
44 			void				DeleteCursors(team_id team);
45 
46 			bool				RemoveCursor(ServerCursor* cursor);
47 
48 			void				SetCursorSet(const char* path);
49 			ServerCursor*		GetCursor(BCursorID which);
50 
51 			ServerCursor*		FindCursor(int32 token);
52 
53 private:
54 			void				_InitCursor(ServerCursor*& cursorMember,
55 									const uint8* cursorBits, BCursorID id,
56 									const BPoint& hotSpot = B_ORIGIN);
57 			void				_LoadCursor(ServerCursor*& cursorMember,
58 									const CursorSet& set, BCursorID id);
59 			ServerCursor*		_FindCursor(team_id cientTeam,
60 									const uint8* cursorData);
61 			void				_RemoveCursor(ServerCursor* cursor);
62 
63 private:
64 			BList				fCursorList;
65 			BTokenSpace			fTokenSpace;
66 
67 			// System cursor members
68 			ServerCursor*		fCursorSystemDefault;
69 
70 			ServerCursor*		fCursorContextMenu;
71 			ServerCursor*		fCursorCopy;
72 			ServerCursor*		fCursorCreateLink;
73 			ServerCursor*		fCursorCrossHair;
74 			ServerCursor*		fCursorFollowLink;
75 			ServerCursor*		fCursorGrab;
76 			ServerCursor*		fCursorGrabbing;
77 			ServerCursor*		fCursorHelp;
78 			ServerCursor*		fCursorIBeam;
79 			ServerCursor*		fCursorIBeamHorizontal;
80 			ServerCursor*		fCursorMove;
81 			ServerCursor*		fCursorNoCursor;
82 			ServerCursor*		fCursorNotAllowed;
83 			ServerCursor*		fCursorProgress;
84 			ServerCursor*		fCursorResizeEast;
85 			ServerCursor*		fCursorResizeEastWest;
86 			ServerCursor*		fCursorResizeNorth;
87 			ServerCursor*		fCursorResizeNorthEast;
88 			ServerCursor*		fCursorResizeNorthEastSouthWest;
89 			ServerCursor*		fCursorResizeNorthSouth;
90 			ServerCursor*		fCursorResizeNorthWest;
91 			ServerCursor*		fCursorResizeNorthWestSouthEast;
92 			ServerCursor*		fCursorResizeSouth;
93 			ServerCursor*		fCursorResizeSouthEast;
94 			ServerCursor*		fCursorResizeSouthWest;
95 			ServerCursor*		fCursorResizeWest;
96 			ServerCursor*		fCursorZoomIn;
97 			ServerCursor*		fCursorZoomOut;
98 };
99 
100 #endif	// CURSOR_MANAGER_H
101