Frameworks/libpurple.framework/Versions/0.6.2/Headers/whiteboard.h
author Zachary West <zacw@adium.im>
Fri Aug 21 13:25:11 2009 -0700 (2009-08-21)
changeset 2592 e8d15275025e
parent 1739 Frameworks/libpurple.framework/Versions/0.6.0/Headers/whiteboard.h@8b0daad9656c
permissions -rw-r--r--
im.pidgin.adium.1-4 at 267c6165e02e34318a1823960bd04c0639952f73
Evan@653
     1
/**
Evan@653
     2
 * @file whiteboard.h The PurpleWhiteboard core object
Evan@653
     3
 */
Evan@653
     4
Evan@653
     5
/* purple
Evan@653
     6
 *
Evan@653
     7
 * Purple is the legal property of its developers, whose names are too numerous
Evan@653
     8
 * to list here.  Please refer to the COPYRIGHT file distributed with this
Evan@653
     9
 * source distribution.
Evan@653
    10
 *
Evan@653
    11
 * This program is free software; you can redistribute it and/or modify
Evan@653
    12
 * it under the terms of the GNU General Public License as published by
Evan@653
    13
 * the Free Software Foundation; either version 2 of the License, or
Evan@653
    14
 * (at your option) any later version.
Evan@653
    15
 *
Evan@653
    16
 * This program is distributed in the hope that it will be useful,
Evan@653
    17
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Evan@653
    18
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Evan@653
    19
 * GNU General Public License for more details.
Evan@653
    20
 *
Evan@653
    21
 * You should have received a copy of the GNU General Public License
Evan@653
    22
 * along with this program; if not, write to the Free Software
Evan@653
    23
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
Evan@653
    24
 */
Evan@653
    25
Evan@653
    26
#ifndef _PURPLE_WHITEBOARD_H_
Evan@653
    27
#define _PURPLE_WHITEBOARD_H_
Evan@653
    28
Evan@653
    29
/**
Evan@653
    30
 * Whiteboard PRPL Operations
Evan@653
    31
 */
Evan@653
    32
typedef struct _PurpleWhiteboardPrplOps PurpleWhiteboardPrplOps;
Evan@653
    33
Evan@653
    34
#include "account.h"
Evan@653
    35
Evan@653
    36
/**
Evan@653
    37
 * A PurpleWhiteboard
Evan@653
    38
 */
Evan@653
    39
typedef struct _PurpleWhiteboard
Evan@653
    40
{
Evan@653
    41
	int state;                       /**< State of whiteboard session */
Evan@653
    42
Evan@653
    43
	PurpleAccount *account;            /**< Account associated with this session */
Evan@653
    44
	char *who;                       /**< Name of the remote user */
Evan@653
    45
Evan@653
    46
	void *ui_data;                   /**< Graphical user-interface data */
Evan@653
    47
	void *proto_data;                /**< Protocol specific data */
Evan@653
    48
	PurpleWhiteboardPrplOps *prpl_ops; /**< Protocol-plugin operations */
Evan@653
    49
Evan@653
    50
	GList *draw_list;                /**< List of drawing elements/deltas to send */
Evan@653
    51
} PurpleWhiteboard;
Evan@653
    52
Evan@653
    53
/**
Evan@653
    54
 * The PurpleWhiteboard UI Operations
Evan@653
    55
 */
Evan@653
    56
typedef struct _PurpleWhiteboardUiOps
Evan@653
    57
{
Evan@653
    58
	void (*create)(PurpleWhiteboard *wb);                                 /**< create function */
Evan@653
    59
	void (*destroy)(PurpleWhiteboard *wb);                               /**< destory function */
Evan@653
    60
	void (*set_dimensions)(PurpleWhiteboard *wb, int width, int height); /**< set_dimensions function */
Evan@653
    61
	void (*set_brush) (PurpleWhiteboard *wb, int size, int color);		/**< set the size and color of the brush */
Evan@653
    62
	void (*draw_point)(PurpleWhiteboard *wb, int x, int y,
Evan@653
    63
					   int color, int size);                           /**< draw_point function */
Evan@653
    64
	void (*draw_line)(PurpleWhiteboard *wb, int x1, int y1,
Evan@653
    65
					  int x2, int y2,
Evan@653
    66
					  int color, int size);                            /**< draw_line function */
Evan@653
    67
	void (*clear)(PurpleWhiteboard *wb);                                 /**< clear function */
Evan@653
    68
Evan@653
    69
	void (*_purple_reserved1)(void);
Evan@653
    70
	void (*_purple_reserved2)(void);
Evan@653
    71
	void (*_purple_reserved3)(void);
Evan@653
    72
	void (*_purple_reserved4)(void);
Evan@653
    73
} PurpleWhiteboardUiOps;
Evan@653
    74
Evan@653
    75
/**
Evan@653
    76
 * PurpleWhiteboard PRPL Operations
Evan@653
    77
 */
Evan@653
    78
struct _PurpleWhiteboardPrplOps
Evan@653
    79
{
Evan@653
    80
	void (*start)(PurpleWhiteboard *wb);                                   /**< start function */
Evan@653
    81
	void (*end)(PurpleWhiteboard *wb);                                     /**< end function */
Evan@653
    82
	void (*get_dimensions)(const PurpleWhiteboard *wb, int *width, int *height); /**< get_dimensions function */
Evan@653
    83
	void (*set_dimensions)(PurpleWhiteboard *wb, int width, int height);   /**< set_dimensions function */
Evan@653
    84
	void (*get_brush) (const PurpleWhiteboard *wb, int *size, int *color); /**< get the brush size and color */
Evan@653
    85
	void (*set_brush) (PurpleWhiteboard *wb, int size, int color);         /**< set the brush size and color */
Evan@653
    86
	void (*send_draw_list)(PurpleWhiteboard *wb, GList *draw_list);        /**< send_draw_list function */
Evan@653
    87
	void (*clear)(PurpleWhiteboard *wb);                                   /**< clear function */
Evan@653
    88
Evan@653
    89
	void (*_purple_reserved1)(void);
Evan@653
    90
	void (*_purple_reserved2)(void);
Evan@653
    91
	void (*_purple_reserved3)(void);
Evan@653
    92
	void (*_purple_reserved4)(void);
Evan@653
    93
};
Evan@653
    94
Evan@653
    95
#ifdef __cplusplus
Evan@653
    96
extern "C" {
Evan@653
    97
#endif /* __cplusplus */
Evan@653
    98
Evan@653
    99
/******************************************************************************/
Evan@653
   100
/** @name PurpleWhiteboard API                                                  */
Evan@653
   101
/******************************************************************************/
Evan@653
   102
/*@{*/
Evan@653
   103
Evan@653
   104
/**
Evan@653
   105
 * Sets the UI operations
Evan@653
   106
 *
Evan@653
   107
 * @param ops The UI operations to set
Evan@653
   108
 */
Evan@653
   109
void purple_whiteboard_set_ui_ops(PurpleWhiteboardUiOps *ops);
Evan@653
   110
Evan@653
   111
/**
Evan@653
   112
 * Sets the prpl operations for a whiteboard
Evan@653
   113
 *
Evan@653
   114
 * @param wb  The whiteboard for which to set the prpl operations
Evan@653
   115
 * @param ops The prpl operations to set
Evan@653
   116
 */
Evan@653
   117
void purple_whiteboard_set_prpl_ops(PurpleWhiteboard *wb, PurpleWhiteboardPrplOps *ops);
Evan@653
   118
Evan@653
   119
/**
Evan@653
   120
 * Creates a whiteboard
Evan@653
   121
 *
Evan@653
   122
 * @param account The account.
Evan@653
   123
 * @param who     Who you're drawing with.
Evan@653
   124
 * @param state   The state.
Evan@653
   125
 *
Evan@653
   126
 * @return The new whiteboard
Evan@653
   127
 */
Evan@653
   128
PurpleWhiteboard *purple_whiteboard_create(PurpleAccount *account, const char *who, int state);
Evan@653
   129
Evan@653
   130
/**
Evan@653
   131
 * Destroys a whiteboard
Evan@653
   132
 *
Evan@653
   133
 * @param wb The whiteboard.
Evan@653
   134
 */
Evan@653
   135
void purple_whiteboard_destroy(PurpleWhiteboard *wb);
Evan@653
   136
Evan@653
   137
/**
Evan@653
   138
 * Starts a whiteboard
Evan@653
   139
 *
Evan@653
   140
 * @param wb The whiteboard.
Evan@653
   141
 */
Evan@653
   142
void purple_whiteboard_start(PurpleWhiteboard *wb);
Evan@653
   143
Evan@653
   144
/**
Evan@653
   145
 * Finds a whiteboard from an account and user.
Evan@653
   146
 *
Evan@653
   147
 * @param account The account.
Evan@653
   148
 * @param who     The user.
Evan@653
   149
 *
Evan@653
   150
 * @return The whiteboard if found, otherwise @c NULL.
Evan@653
   151
 */
Evan@653
   152
PurpleWhiteboard *purple_whiteboard_get_session(const PurpleAccount *account, const char *who);
Evan@653
   153
Evan@653
   154
/**
Evan@653
   155
 * Destorys a drawing list for a whiteboard
Evan@653
   156
 *
Evan@653
   157
 * @param draw_list The drawing list.
Evan@653
   158
 */
Evan@653
   159
void purple_whiteboard_draw_list_destroy(GList *draw_list);
Evan@653
   160
Evan@653
   161
/**
Evan@653
   162
 * Gets the dimension of a whiteboard.
Evan@653
   163
 *
Evan@653
   164
 * @param wb		The whiteboard.
Evan@653
   165
 * @param width		The width to be set.
Evan@653
   166
 * @param height	The height to be set.
Evan@653
   167
 *
Evan@653
   168
 * @return TRUE if the values of width and height were set.
Evan@653
   169
 */
Evan@653
   170
gboolean purple_whiteboard_get_dimensions(const PurpleWhiteboard *wb, int *width, int *height);
Evan@653
   171
Evan@653
   172
/**
Evan@653
   173
 * Sets the dimensions for a whiteboard.
Evan@653
   174
 *
Evan@653
   175
 * @param wb     The whiteboard.
Evan@653
   176
 * @param width  The width.
Evan@653
   177
 * @param height The height.
Evan@653
   178
 */
Evan@653
   179
void purple_whiteboard_set_dimensions(PurpleWhiteboard *wb, int width, int height);
Evan@653
   180
Evan@653
   181
/**
Evan@653
   182
 * Draws a point on a whiteboard.
Evan@653
   183
 *
Evan@653
   184
 * @param wb    The whiteboard.
Evan@653
   185
 * @param x     The x coordinate.
Evan@653
   186
 * @param y     The y coordinate.
Evan@653
   187
 * @param color The color to use.
Evan@653
   188
 * @param size  The brush size.
Evan@653
   189
 */
Evan@653
   190
void purple_whiteboard_draw_point(PurpleWhiteboard *wb, int x, int y, int color, int size);
Evan@653
   191
Evan@653
   192
/**
Evan@653
   193
 * Send a list of points to draw to the buddy.
Evan@653
   194
 *
Evan@653
   195
 * @param wb	The whiteboard
Evan@653
   196
 * @param list	A GList of points
Evan@653
   197
 */
Evan@653
   198
void purple_whiteboard_send_draw_list(PurpleWhiteboard *wb, GList *list);
Evan@653
   199
Evan@653
   200
/**
Evan@653
   201
 * Draws a line on a whiteboard
Evan@653
   202
 *
Evan@653
   203
 * @param wb    The whiteboard.
Evan@653
   204
 * @param x1    The top-left x coordinate.
Evan@653
   205
 * @param y1    The top-left y coordinate.
Evan@653
   206
 * @param x2    The bottom-right x coordinate.
Evan@653
   207
 * @param y2    The bottom-right y coordinate.
Evan@653
   208
 * @param color The color to use.
Evan@653
   209
 * @param size  The brush size.
Evan@653
   210
 */
Evan@653
   211
void purple_whiteboard_draw_line(PurpleWhiteboard *wb, int x1, int y1, int x2, int y2, int color, int size);
Evan@653
   212
Evan@653
   213
/**
Evan@653
   214
 * Clears a whiteboard
Evan@653
   215
 *
Evan@653
   216
 * @param wb The whiteboard.
Evan@653
   217
 */
Evan@653
   218
void purple_whiteboard_clear(PurpleWhiteboard *wb);
Evan@653
   219
Evan@653
   220
/**
Evan@653
   221
 * Sends a request to the buddy to clear the whiteboard.
Evan@653
   222
 *
Evan@653
   223
 * @param wb The whiteboard
Evan@653
   224
 */
Evan@653
   225
void purple_whiteboard_send_clear(PurpleWhiteboard *wb);
Evan@653
   226
Evan@653
   227
/**
Evan@653
   228
 * Sends a request to change the size and color of the brush.
Evan@653
   229
 *
Evan@653
   230
 * @param wb	The whiteboard
Evan@653
   231
 * @param size	The size of the brush
Evan@653
   232
 * @param color	The color of the brush
Evan@653
   233
 */
Evan@653
   234
void purple_whiteboard_send_brush(PurpleWhiteboard *wb, int size, int color);
Evan@653
   235
Evan@653
   236
/**
Evan@653
   237
 * Gets the size and color of the brush.
Evan@653
   238
 *
Evan@653
   239
 * @param wb	The whiteboard
Evan@653
   240
 * @param size	The size of the brush
Evan@653
   241
 * @param color	The color of the brush
Evan@653
   242
 *
Evan@653
   243
 * @return	TRUE if the size and color were set.
Evan@653
   244
 */
Evan@653
   245
gboolean purple_whiteboard_get_brush(const PurpleWhiteboard *wb, int *size, int *color);
Evan@653
   246
Evan@653
   247
/**
Evan@653
   248
 * Sets the size and color of the brush.
Evan@653
   249
 *
Evan@653
   250
 * @param wb	The whiteboard
Evan@653
   251
 * @param size	The size of the brush
Evan@653
   252
 * @param color	The color of the brush
Evan@653
   253
 */
Evan@653
   254
void purple_whiteboard_set_brush(PurpleWhiteboard *wb, int size, int color);
Evan@653
   255
Evan@653
   256
/*@}*/
Evan@653
   257
Evan@653
   258
#ifdef __cplusplus
Evan@653
   259
}
Evan@653
   260
#endif /* __cplusplus */
Evan@653
   261
Evan@653
   262
#endif /* _PURPLE_WHITEBOARD_H_ */