boinc/doc/graphics.php

202 lines
5.9 KiB
PHP
Raw Normal View History

<?php
require_once("docutil.php");
page_head("The BOINC graphics API");
echo"
<p>
BOINC applications can optionally provide graphics.
Graphics are displayed either in an application window
or in a full-screen window (when acting as a screensaver).
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
<pre>
int boinc_init_graphics(void (*worker)());
// for simple applications
int boinc_init_options_graphics(BOINC_OPTIONS&, void (*worker)());
// for compound applications
</pre>
where <code>worker()</code> is the main function of your application.
Do NOT call boinc_init() or boinc_init_options().
<p>
Unix/Linux applications that use graphics should compile
all files with -D_REENTRANT,
since graphics uses multiple threads.
<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>
<p>
<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.
The two threads communicate through application-defined
shared memory structures.
Typically these structures contain information about the computation,
which is used to generate graphics.
You must initialize the shared data structure
before calling <code>boinc_init_graphics()</code>.
<p>
Graphical applications must supply the following functions:
<pre>
bool app_graphics_render(int xs, ys, double time_of_day);
</pre>
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,
and <code>time_of_day</code> is the relative time in seconds.
The function should return true if it actually drew anything.
It can refer to the user name, CPU time etc. obtained from
<code>boinc_get_init_data()</code>.
Applications that don't do graphics must also supply a
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>
<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>
<h3>Limiting frame rate</h3>
<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).
<h3>Support classes</h3>
<p>
Several graphics-related classes were developed for SETI@home.
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.
Includes member functions for drawing the reduced data as a 3D graph
in several ways (lines, rectangles, connected surface).
<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>
";
page_tail();
?>