2004-06-09 19:09:16 +00:00
|
|
|
<?php
|
2003-08-19 06:44:58 +00:00
|
|
|
require_once("docutil.php");
|
|
|
|
page_head("The BOINC graphics API");
|
|
|
|
echo"
|
2002-04-30 22:22:54 +00:00
|
|
|
<p>
|
2004-05-31 18:13:01 +00:00
|
|
|
BOINC applications can optionally provide graphics.
|
2003-11-02 23:08:06 +00:00
|
|
|
Graphics are displayed either in an application window
|
|
|
|
or in a full-screen window (when acting as a screensaver).
|
2004-11-24 07:02:01 +00:00
|
|
|
There are a couple of ways to do graphics:
|
|
|
|
|
|
|
|
<h2>Separate graphics application</h2>
|
|
|
|
<p>
|
|
|
|
In this approach, graphics are generated by a program
|
|
|
|
that is separate from your main application.
|
|
|
|
The main application executes the graphics application,
|
|
|
|
and must kill it when done.
|
|
|
|
<p>
|
|
|
|
The graphics application can be implemented
|
|
|
|
using the BOINC framework (see below)
|
|
|
|
in which it supplies a render function
|
|
|
|
and leaves the rest to BOINC.
|
|
|
|
In this case it should call
|
|
|
|
boinc_init_graphics() (see below) with a NULL worker function.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Or the graphics application can be implemented from scratch.
|
|
|
|
It will need to monitor the graphics_request message channel
|
|
|
|
(see lib/app_ipc.h) to find out when to open and close windows.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
The main and graphics applications typically communicate
|
|
|
|
using shared memory
|
|
|
|
(you can use the functions in boinc/lib/shmem.C for this).
|
|
|
|
<p>
|
|
|
|
This approach has the advantage that the main application
|
|
|
|
doesn't use graphics libraries,
|
|
|
|
and can execute on systems that don't have these libraries.
|
|
|
|
You can use the same application package for
|
|
|
|
both graphical and non-graphical platforms:
|
|
|
|
on a non-graphical host, the graphics application will
|
|
|
|
exit immediately because the libraries are missing.
|
|
|
|
|
|
|
|
<h2>Graphics integrated in main application</h2>
|
|
|
|
<p>
|
|
|
|
In this approach, graphics are generated a thread
|
|
|
|
within your main application.
|
|
|
|
The application must call either
|
2002-07-31 05:59:43 +00:00
|
|
|
<pre>
|
2004-10-28 20:42:44 +00:00
|
|
|
int boinc_init_graphics(void (*worker)());
|
|
|
|
// for simple applications
|
|
|
|
int boinc_init_options_graphics(BOINC_OPTIONS&, void (*worker)());
|
|
|
|
// for compound applications
|
2002-07-31 05:59:43 +00:00
|
|
|
</pre>
|
2004-10-12 20:56:44 +00:00
|
|
|
where <code>worker()</code> is the main function of your application.
|
2004-10-28 20:42:44 +00:00
|
|
|
Do NOT call boinc_init() or boinc_init_options().
|
2004-10-29 18:18:53 +00:00
|
|
|
<p>
|
|
|
|
Unix/Linux applications that use graphics should compile
|
|
|
|
all files with -D_REENTRANT,
|
|
|
|
since graphics uses multiple threads.
|
2004-10-12 20:56:44 +00:00
|
|
|
|
2004-05-31 18:13:01 +00:00
|
|
|
<h3>Static graphics</h3>
|
|
|
|
<p>
|
|
|
|
An application can display a pre-existing image file
|
|
|
|
(JPEG, GIFF, BMP or Targa) as its graphic.
|
|
|
|
This is the simplest approach since you
|
|
|
|
don't need to develop any code.
|
|
|
|
You must include the image file with each workunit.
|
|
|
|
To do this, link the application with api/static_graphics.C
|
|
|
|
(edit this file to use your filename).
|
|
|
|
You can change the image over time,
|
|
|
|
but you must change the (physical, not logical)
|
|
|
|
name of the file each time.
|
|
|
|
|
|
|
|
<h3>Dynamic graphics</h3>
|
2003-11-02 23:08:06 +00:00
|
|
|
<p>
|
2004-10-12 20:56:44 +00:00
|
|
|
<code>boinc_init_graphics()</code> creates a <b>worker thread</b>
|
|
|
|
that runs the main application function.
|
|
|
|
The original thread becomes the <b>graphics thread</b>,
|
|
|
|
which handles GUI events and does rendering.
|
2003-11-02 23:08:06 +00:00
|
|
|
The two threads communicate through application-defined
|
|
|
|
shared memory structures.
|
|
|
|
Typically these structures contain information about the computation,
|
|
|
|
which is used to generate graphics.
|
2004-10-12 20:56:44 +00:00
|
|
|
You must initialize the shared data structure
|
2003-11-02 23:08:06 +00:00
|
|
|
before calling <code>boinc_init_graphics()</code>.
|
|
|
|
<p>
|
|
|
|
Graphical applications must supply the following functions:
|
2002-07-30 18:06:39 +00:00
|
|
|
<pre>
|
2003-11-02 23:08:06 +00:00
|
|
|
bool app_graphics_render(int xs, ys, double time_of_day);
|
2002-07-30 18:06:39 +00:00
|
|
|
</pre>
|
2003-11-02 23:08:06 +00:00
|
|
|
This will be called periodically in the graphics thread.
|
|
|
|
It should generate the current graphic.
|
|
|
|
<code>xs</code> and <code>ys</code> are the X and Y sizes of the window,
|
2004-10-12 20:56:44 +00:00
|
|
|
and <code>time_of_day</code> is the relative time in seconds.
|
2002-07-31 05:59:43 +00:00
|
|
|
The function should return true if it actually drew anything.
|
|
|
|
It can refer to the user name, CPU time etc. obtained from
|
2003-11-02 23:08:06 +00:00
|
|
|
<code>boinc_get_init_data()</code>.
|
2002-07-31 05:59:43 +00:00
|
|
|
Applications that don't do graphics must also supply a
|
2003-11-02 23:08:06 +00:00
|
|
|
dummy <code>app_graphics_render()</code> to link with the API.
|
|
|
|
<pre>
|
|
|
|
void app_graphics_init();
|
|
|
|
</pre>
|
|
|
|
This is called in the graphics thread when a window is created.
|
|
|
|
It must make any calls needed to initialize graphics in the window.
|
|
|
|
<pre>
|
|
|
|
void app_graphics_resize(int x, int y);
|
|
|
|
</pre>
|
|
|
|
Called when the window size changes.
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
void app_graphics_reread_prefs();
|
|
|
|
</pre>
|
|
|
|
This is called, in the graphics thread, whenever
|
|
|
|
the user's project preferences change.
|
|
|
|
It can call
|
|
|
|
<pre>
|
|
|
|
boinc_parse_init_data_file();
|
|
|
|
boinc_get_init_data(APP_INIT_DATA&);
|
|
|
|
</pre>
|
|
|
|
to get the new preferences.
|
|
|
|
|
|
|
|
<p>
|
|
|
|
|
2004-05-11 05:46:56 +00:00
|
|
|
<h3>Handling input</h3>
|
|
|
|
<p>
|
|
|
|
The application must supply the following input-handling functions:
|
|
|
|
<pre>
|
|
|
|
void boinc_app_mouse_move(
|
|
|
|
int x, int y, // new coords of cursor
|
|
|
|
bool left, // whether left mouse button is down
|
|
|
|
bool middle,
|
|
|
|
bool right
|
|
|
|
);
|
|
|
|
|
|
|
|
void boinc_app_mouse_button(
|
|
|
|
int x, int y, // coords of cursor
|
|
|
|
int which, // which button (0/1/2)
|
|
|
|
bool is_down // true iff button is now down
|
|
|
|
);
|
|
|
|
|
|
|
|
void boinc_app_key_press(
|
|
|
|
int, int // system-specific key encodings
|
|
|
|
)
|
|
|
|
|
|
|
|
void boinc_app_key_release(
|
|
|
|
int, int // system-specific key encodings
|
|
|
|
)
|
|
|
|
</pre>
|
2003-11-02 23:08:06 +00:00
|
|
|
<h3>Limiting frame rate</h3>
|
2003-10-15 17:14:58 +00:00
|
|
|
<p>
|
|
|
|
The following global variables control frame rate:
|
|
|
|
<p>
|
|
|
|
<b>boinc_max_fps</b> is an upper bound on the number of frames per second
|
|
|
|
(default 30).
|
|
|
|
<p>
|
|
|
|
<b>boinc_max_gfx_cpu_frac</b> is an upper bound on the fraction
|
|
|
|
of CPU time used for graphics (default 0.5).
|
2003-11-02 23:08:06 +00:00
|
|
|
|
2003-11-07 23:26:17 +00:00
|
|
|
<h3>Support classes</h3>
|
|
|
|
<p>
|
2004-05-31 18:13:01 +00:00
|
|
|
Several graphics-related classes were developed for SETI@home.
|
2003-11-07 23:26:17 +00:00
|
|
|
They may be of general utility.
|
|
|
|
|
|
|
|
<dl>
|
|
|
|
<dt>
|
|
|
|
REDUCED_ARRAY
|
|
|
|
<dd>
|
|
|
|
Represents a two-dimensional array of data,
|
|
|
|
which is reduced to a smaller dimension by averaging or taking extrema.
|
2004-05-31 18:13:01 +00:00
|
|
|
Includes member functions for drawing the reduced data as a 3D graph
|
|
|
|
in several ways (lines, rectangles, connected surface).
|
2003-11-07 23:26:17 +00:00
|
|
|
<dt>
|
|
|
|
PROGRESS and PROGRESS_2D
|
|
|
|
<dd>
|
|
|
|
Represent progress bars, depicted in 3 or 2 dimensions.
|
|
|
|
|
|
|
|
<dt>
|
|
|
|
RIBBON_GRAPH
|
|
|
|
<dd>
|
|
|
|
Represents of 3D graph of a function of 1 variable.
|
|
|
|
|
|
|
|
<dt>
|
|
|
|
MOVING_TEXT_PANEL
|
|
|
|
<dd>
|
|
|
|
Represents a flanged 3D panel, moving cyclically in 3 dimentions,
|
|
|
|
on which text is displayed.
|
|
|
|
<dt>
|
|
|
|
STARFIELD
|
|
|
|
<dd>
|
|
|
|
Represents a set of randomly-generated stars
|
|
|
|
that move forwards or backwards in 3 dimensions.
|
|
|
|
|
|
|
|
<dt>
|
|
|
|
TEXTURE_DESC
|
|
|
|
<dd>
|
|
|
|
Represents an image (JPEG, Targa, BMP or PNG)
|
|
|
|
displayed in 3 dimensions.
|
|
|
|
</dl>
|
2003-08-19 06:44:58 +00:00
|
|
|
";
|
|
|
|
page_tail();
|
|
|
|
?>
|