xref: /haiku/docs/develop/kits/app/usecases/BCursorUseCases.html (revision 21258e2674226d6aa732321b6f8494841895af5f)
1<HTML>
2<HEAD>
3<TITLE>BCursor Use Cases and Implementation Details</TITLE>
4</HEAD>
5
6<BODY BGCOLOR="white" LINK="#000067" VLINK="#000067" ALINK="#0000FF">
7
8<FONT FACE="Verdana,Arial,Helvetica,sans-serif" SIZE="-1">
9
10<H1>BCursor Use Cases and Implementation Details:</H1>
11
12<P>This document describes the BCursor interface and some basics of how it is implemented.
13The document has the following sections:</P>
14
15<OL>
16<LI><A HREF="#interface">BCursor Interface</A></LI>
17<LI><A HREF="#usecases">BCursor Use Cases</A></LI>
18<LI><A HREF="#implement">BCursor Implementation</A></LI>
19</OL>
20
21<A NAME="interface"></A><H2>BCursor Interface:</H2>
22
23<P>The BCursor class is a simple class used to represent a mouse cursor as an object instead of an array of pixel data.  The best source of information for the BCursor interface can be found
24<A HREF="https://www.haiku-os.org/legacy-docs/bebook/BCursor_Overview.html#BCursor_Overview_CursorDataFormat">here in the Be Book</A>.
25</P>
26
27<A NAME="usecases"></A><H2>BCursor Use Cases:</H2>
28
29<P>The following use cases cover the BCursor functionality:</P>
30
31<OL>
32<LI><P><B>Construction 1:</B> The first BCursor constructor requires a pointer to the pixel data.  The format for the pixel data is described
33<A HREF="https://www.haiku-os.org/legacy-docs/bebook/BCursor_Overview.html">here in the Be Book</A>.
34This pixel data is used to initialize the BCursor, but BCursor does not take ownership of the data, therefore you are responsible for freeing the memory after construction.</P></LI>
35
36<LI><P><B>Construction 2:</B> The second BCursor constructor requires a BMessage as an archive, however BCursor does not currently support archiving.  Do not use this constructor.</P></LI>
37
38<LI><P><B>Destruction:</B> This releases all resources used by the BCursor.</P></LI>
39
40<LI><P><B>Instantiate:</B> This always returns NULL since it relies on the second constructor (which is not currently supported).  If it were implemented, this would return a new BArchivable consisting of a BCursor created from the archive passed in as an argument. </P></LI>
41
42</OL>
43
44<A NAME="implement"></A><H2>BCursor Implementation:</H2>
45
46<P>All meaningful work of the BCursor is implemented in the first constructor.  The constructor establishes a link with the app_server and sends it the pixel data.  The app_server provides the BCursor with a token which identifies the pixel data.  When BApplication::SetCursor(BCursor) is called, it must get the needed cursor data by obtaining the BCursor's token (BApplication is a friend of BCursor) and using the token to request the data from the app_server.  Note that BCursor does not internally store the pixel data.</P>
47
48</BODY>
49</HTML>
50
51