diff options
| -rw-r--r-- | include/xine.h.tmpl.in | 62 | ||||
| -rw-r--r-- | src/libspudec/spudec.h | 5 | ||||
| -rw-r--r-- | src/video_out/video_out_xv.c | 40 | ||||
| -rw-r--r-- | src/xine-engine/video_out.c | 5 | ||||
| -rw-r--r-- | src/xine-engine/xine.c | 44 | 
5 files changed, 143 insertions, 13 deletions
| diff --git a/include/xine.h.tmpl.in b/include/xine.h.tmpl.in index 2096ce8f7..c2998ccc2 100644 --- a/include/xine.h.tmpl.in +++ b/include/xine.h.tmpl.in @@ -29,7 +29,7 @@     \endverbatim   */  /* - * $Id: xine.h.tmpl.in,v 1.12 2001/05/03 18:22:37 f1rmb Exp $ + * $Id: xine.h.tmpl.in,v 1.13 2001/05/03 22:20:44 f1rmb Exp $   *   */ @@ -339,6 +339,66 @@ void xine_get_window_property_min_max(xine_t *this, int property, int *min, int   */  void xine_window_handle_event(xine_t *this, void *event); +/** + * \fn void xine_set_window_fullscreen(xine_t *this, int fullscreen); + * \brief + * \param + * \return + * + * + */ +void xine_set_window_fullscreen(xine_t *this, int fullscreen); + +/** + * \fn int xine_get_window_fullscreen(xine_t *this); + * \brief + * \param + * \return + * + * + */ +int xine_get_window_fullscreen(xine_t *this); + +/** + * \fn void xine_set_window_visible(xine_t *this, int visible); + * \brief + * \param + * \return + * + * + */ +void xine_set_window_visible(xine_t *this, int visible); + +/** + * \fn int xine_get_window_visible(xine_t *this); + * \brief + * \param + * \return + * + * + */ +int xine_get_window_visible(xine_t *this); + +/** + * \fn void xine_set_display_cursor(xine_t *this, int show); + * \brief + * \param + * \return + * + * + */ +void xine_set_display_cursor(xine_t *this, int show); + +/** + * \fn int xine_get_display_cursor(xine_t *this); + * \brief + * \param + * \return + * + * + */ +int xine_get_display_cursor(xine_t *this); +  /** @} end of xine_management_api */  /** diff --git a/src/libspudec/spudec.h b/src/libspudec/spudec.h index c20c934a0..e4ce15741 100644 --- a/src/libspudec/spudec.h +++ b/src/libspudec/spudec.h @@ -60,8 +60,3 @@ struct spudec_s {  spudec_t *spudec_init (metronom_t *metronom, fifo_buffer_t *spu_fifo);  #endif /* HAVE_SPUDEC_H */ - - - - - diff --git a/src/video_out/video_out_xv.c b/src/video_out/video_out_xv.c index 6b3675e6d..5441a4536 100644 --- a/src/video_out/video_out_xv.c +++ b/src/video_out/video_out_xv.c @@ -17,7 +17,7 @@   * along with this program; if not, write to the Free Software   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA   * - * $Id: video_out_xv.c,v 1.9 2001/05/01 02:29:00 guenter Exp $ + * $Id: video_out_xv.c,v 1.10 2001/05/03 22:20:45 f1rmb Exp $   *    * video_out_xv.c, X11 video extension interface for xine   * @@ -117,8 +117,30 @@ typedef struct xv_driver_s {    int              fullscreen_width; /* this is basically how big the screen is */    int              fullscreen_height;    int              in_fullscreen;    /* is the window in fullscreen mode? */ + +  Cursor           cursor[2];        /* Cursor pointers */ +  } xv_driver_t; +/* + * Cursors creation + */ +static unsigned char bm_no_data[] = { 0,0,0,0, 0,0,0,0 }; +static void xv_create_cursors (xv_driver_t *this) { +  Pixmap bm_no; + +  bm_no = XCreateBitmapFromData(this->display, this->window, bm_no_data, 8, 8); +  this->cursor[0] = XCreatePixmapCursor(this->display, bm_no, bm_no, +					&this->black, &this->black, 0, 0); +  this->cursor[1] = XCreateFontCursor(this->display,XC_left_ptr); +} + +/* Hide/Show cursor */ +static void xv_display_cursor(vo_driver_t *this_gen, int value) { +  xv_driver_t *this = (xv_driver_t *) this_gen; +   +  XDefineCursor(this->display, this->window, this->cursor[value]); +}  static uint32_t xv_get_capabilities (vo_driver_t *this_gen) { @@ -581,20 +603,25 @@ static int xv_set_property (vo_driver_t *this_gen,      return this->props[property].value;    } else { -    /* FIXME: implement these props +    /* FIXME: implement these props */      switch (property) {        case VO_PROP_WINDOW_VISIBLE: +	printf("VO_PROP_WINDOW_VISIBLE(%d)\n", value);        break;        case VO_PROP_CURSOR_VISIBLE: +	xv_display_cursor(this_gen, value);        break;        case VO_PROP_FULLSCREEN: +	printf("VO_PROP_FULLSCREEN(%d)\n", value);        break;        case VO_PROP_INTERLACED: +	printf("VO_PROP_INTERLACED(%d)\n", value);        break;        case VO_PROP_ASPECT_RATIO: +	printf("VO_PROP_ASPECT_RATIO(%d)\n", value);        break;      } -    */ +    this->props[property].value = value;    }    return value; @@ -922,6 +949,13 @@ vo_driver_t *init_video_out_plugin (config_values_t *config, void *visual) {    xv_calc_format (this, 720, 576, 2);    xv_setup_window (this); +  /*  +   * Create cursors, then display the current one. +   */ +  xv_create_cursors(this); +  xv_display_cursor(&this->vo_driver,  +		    this->props[VO_PROP_CURSOR_VISIBLE].value); +    return &this->vo_driver;  } diff --git a/src/xine-engine/video_out.c b/src/xine-engine/video_out.c index 78c37d839..c13fbf16d 100644 --- a/src/xine-engine/video_out.c +++ b/src/xine-engine/video_out.c @@ -17,7 +17,7 @@   * along with this program; if not, write to the Free Software   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA   * - * $Id: video_out.c,v 1.2 2001/05/03 18:22:37 f1rmb Exp $ + * $Id: video_out.c,v 1.3 2001/05/03 22:20:45 f1rmb Exp $   *   */ @@ -327,8 +327,7 @@ static uint32_t vo_get_capabilities (vo_instance_t *this) {    return this->driver->get_capabilities (this->driver);  } -static int vo_get_property (vo_instance_t *this, -			    int property) { +static int vo_get_property (vo_instance_t *this, int property) {    return this->driver->get_property (this->driver, property);  } diff --git a/src/xine-engine/xine.c b/src/xine-engine/xine.c index 5d39330cc..41191123f 100644 --- a/src/xine-engine/xine.c +++ b/src/xine-engine/xine.c @@ -17,7 +17,7 @@   * along with this program; if not, write to the Free Software   * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA   * - * $Id: xine.c,v 1.12 2001/05/03 18:22:37 f1rmb Exp $ + * $Id: xine.c,v 1.13 2001/05/03 22:20:45 f1rmb Exp $   *   * top-level xine functions   * @@ -566,3 +566,45 @@ void xine_window_handle_event(xine_t *this, void *event) {    this->video_out->handle_event(this->video_out, event);  } + +/* + * + */ +void xine_set_window_fullscreen(xine_t *this, int fullscreen) { + +  xine_set_window_property(this, VO_PROP_FULLSCREEN, fullscreen); +} + +/* + * + */ +int xine_get_window_fullscreen(xine_t *this) { + +  return (xine_get_window_property(this, VO_PROP_FULLSCREEN)); +} + +/* + * + */ +void xine_set_window_visible(xine_t *this, int visible) { + +  xine_set_window_property(this, VO_PROP_WINDOW_VISIBLE, visible); +} + +/* + * + */ +int xine_get_window_visible(xine_t *this) { + +  return (xine_get_window_property(this, VO_PROP_WINDOW_VISIBLE)); +} + +void xine_set_display_cursor(xine_t *this, int show) { +   +  xine_set_window_property(this, VO_PROP_CURSOR_VISIBLE, show); +} + +int xine_get_display_cursor(xine_t *this) { +   +  return (xine_get_window_property(this, VO_PROP_CURSOR_VISIBLE)); +} | 
