1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
/*
Copyright (C) 2010 Red Hat, Inc.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __SPICE_CLIENT_CURSOR_CHANNEL_H__
#define __SPICE_CLIENT_CURSOR_CHANNEL_H__
#if !defined(__SPICE_CLIENT_H_INSIDE__) && !defined(SPICE_COMPILATION)
#warning "Only <spice-client.h> can be included directly"
#endif
#include "spice-client.h"
G_BEGIN_DECLS
#define SPICE_TYPE_CURSOR_CHANNEL (spice_cursor_channel_get_type())
#define SPICE_CURSOR_CHANNEL(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), SPICE_TYPE_CURSOR_CHANNEL, SpiceCursorChannel))
#define SPICE_CURSOR_CHANNEL_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), SPICE_TYPE_CURSOR_CHANNEL, SpiceCursorChannelClass))
#define SPICE_IS_CURSOR_CHANNEL(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), SPICE_TYPE_CURSOR_CHANNEL))
#define SPICE_IS_CURSOR_CHANNEL_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), SPICE_TYPE_CURSOR_CHANNEL))
#define SPICE_CURSOR_CHANNEL_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), SPICE_TYPE_CURSOR_CHANNEL, SpiceCursorChannelClass))
typedef struct _SpiceCursorChannel SpiceCursorChannel;
typedef struct _SpiceCursorChannelClass SpiceCursorChannelClass;
typedef struct _SpiceCursorChannelPrivate SpiceCursorChannelPrivate;
#define SPICE_TYPE_CURSOR_SHAPE (spice_cursor_shape_get_type())
/**
* SpiceCursorShape:
* @type: a #SpiceCursorType of @data
* @width: a width of the remote cursor
* @height: a height of the remote cursor
* @hot_spot_x: a 'x' coordinate of the remote cursor
* @hot_spot_y: a 'y' coordinate of the remote cursor
* @data: image data of the remote cursor
*
* The #SpiceCursorShape structure defines the remote cursor's shape.
*
*/
typedef struct _SpiceCursorShape SpiceCursorShape;
struct _SpiceCursorShape {
SpiceCursorType type;
guint16 width;
guint16 height;
guint16 hot_spot_x;
guint16 hot_spot_y;
gpointer data;
};
/**
* SpiceCursorChannel:
*
* The #SpiceCursorChannel struct is opaque and should not be accessed directly.
*/
struct _SpiceCursorChannel {
SpiceChannel parent;
/*< private >*/
SpiceCursorChannelPrivate *priv;
/* Do not add fields to this struct */
};
/**
* SpiceCursorChannelClass:
* @parent_class: Parent class.
* @cursor_set: Signal class handler for the #SpiceCursorChannel::cursor-set signal.
* @cursor_move: Signal class handler for the #SpiceCursorChannel::cursor-move signal.
* @cursor_hide: Signal class handler for the #SpiceCursorChannel::cursor-hide signal.
* @cursor_reset: Signal class handler for the #SpiceCursorChannel::cursor-reset signal.
*
* Class structure for #SpiceCursorChannel.
*/
struct _SpiceCursorChannelClass {
SpiceChannelClass parent_class;
/* signals */
void (*cursor_set)(SpiceCursorChannel *channel, gint width, gint height,
gint hot_x, gint hot_y, gpointer rgba);
void (*cursor_move)(SpiceCursorChannel *channel, gint x, gint y);
void (*cursor_hide)(SpiceCursorChannel *channel);
void (*cursor_reset)(SpiceCursorChannel *channel);
/*< private >*/
/* Do not add fields to this struct */
};
GType spice_cursor_channel_get_type(void);
GType spice_cursor_shape_get_type(void) G_GNUC_CONST;
G_END_DECLS
#endif /* __SPICE_CLIENT_CURSOR_CHANNEL_H__ */
|