mirror of
https://github.com/opencv/opencv.git
synced 2025-01-18 22:44:02 +08:00
These changes introduce Gtk3 support into the highgui module.
A new option WITH_GTK3 has been added to the cmake configure system to enable compilation under Gtk version 3.The flag HAVE_GTK3 is also introduced to select the new Gtk3 code in the source files. (Gtk2 is disbled when Gtk3 is selected). window_gtk.cpp has been modified to remove obsolete (and deleted from libgtk 3) and introduce new Gtk3 code in its place when compiled for Gtk3. To compile for Gtk2, disable WITH_GTK3 in cmake. To build for Gtk3 both WITH_GTK and WITH_GTK3 must be selected.
This commit is contained in:
parent
97fc1e10a7
commit
81d6842b8e
@ -120,6 +120,7 @@ OCV_OPTION(WITH_FFMPEG "Include FFMPEG support" ON
|
|||||||
OCV_OPTION(WITH_GSTREAMER "Include Gstreamer support" ON IF (UNIX AND NOT APPLE AND NOT ANDROID) )
|
OCV_OPTION(WITH_GSTREAMER "Include Gstreamer support" ON IF (UNIX AND NOT APPLE AND NOT ANDROID) )
|
||||||
OCV_OPTION(WITH_GSTREAMER_1_X "Include Gstreamer 1.x support" OFF)
|
OCV_OPTION(WITH_GSTREAMER_1_X "Include Gstreamer 1.x support" OFF)
|
||||||
OCV_OPTION(WITH_GTK "Include GTK support" ON IF (UNIX AND NOT APPLE AND NOT ANDROID) )
|
OCV_OPTION(WITH_GTK "Include GTK support" ON IF (UNIX AND NOT APPLE AND NOT ANDROID) )
|
||||||
|
OCV_OPTION(WITH_GTK3 "Include GTK3 support" ON IF (UNIX AND WITH_GTK AND NOT APPLE AND NOT ANDROID) )
|
||||||
OCV_OPTION(WITH_IPP "Include Intel IPP support" OFF IF (MSVC OR X86 OR X86_64) )
|
OCV_OPTION(WITH_IPP "Include Intel IPP support" OFF IF (MSVC OR X86 OR X86_64) )
|
||||||
OCV_OPTION(WITH_JASPER "Include JPEG2K support" ON IF (NOT IOS) )
|
OCV_OPTION(WITH_JASPER "Include JPEG2K support" ON IF (NOT IOS) )
|
||||||
OCV_OPTION(WITH_JPEG "Include JPEG support" ON)
|
OCV_OPTION(WITH_JPEG "Include JPEG support" ON)
|
||||||
@ -603,6 +604,7 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
status(" GTK+ 2.x:" HAVE_GTK THEN "YES (ver ${ALIASOF_gtk+-2.0_VERSION})" ELSE NO)
|
status(" GTK+ 2.x:" HAVE_GTK THEN "YES (ver ${ALIASOF_gtk+-2.0_VERSION})" ELSE NO)
|
||||||
|
status(" GTK+ 3.x:" HAVE_GTK3 THEN "YES (ver ${ALIASOF_gtk+-3.0_VERSION})" ELSE NO)
|
||||||
status(" GThread :" HAVE_GTHREAD THEN "YES (ver ${ALIASOF_gthread-2.0_VERSION})" ELSE NO)
|
status(" GThread :" HAVE_GTHREAD THEN "YES (ver ${ALIASOF_gthread-2.0_VERSION})" ELSE NO)
|
||||||
status(" GtkGlExt:" HAVE_GTKGLEXT THEN "YES (ver ${ALIASOF_gtkglext-1.0_VERSION})" ELSE NO)
|
status(" GtkGlExt:" HAVE_GTKGLEXT THEN "YES (ver ${ALIASOF_gtkglext-1.0_VERSION})" ELSE NO)
|
||||||
endif()
|
endif()
|
||||||
|
@ -39,9 +39,13 @@ if(WITH_QT)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# --- GTK ---
|
# --- GTK ---
|
||||||
ocv_clear_vars(HAVE_GTK HAVE_GTHREAD HAVE_GTKGLEXT)
|
ocv_clear_vars(HAVE_GTK HAVE_GTK3 HAVE_GTHREAD HAVE_GTKGLEXT)
|
||||||
if(WITH_GTK AND NOT HAVE_QT)
|
if(WITH_GTK AND NOT HAVE_QT)
|
||||||
CHECK_MODULE(gtk+-2.0 HAVE_GTK)
|
if(WITH_GTK3)
|
||||||
|
CHECK_MODULE(gtk+-3.0 HAVE_GTK3)
|
||||||
|
else()
|
||||||
|
CHECK_MODULE(gtk+-2.0 HAVE_GTK)
|
||||||
|
endif()
|
||||||
CHECK_MODULE(gthread-2.0 HAVE_GTHREAD)
|
CHECK_MODULE(gthread-2.0 HAVE_GTHREAD)
|
||||||
if(WITH_OPENGL)
|
if(WITH_OPENGL)
|
||||||
CHECK_MODULE(gtkglext-1.0 HAVE_GTKGLEXT)
|
CHECK_MODULE(gtkglext-1.0 HAVE_GTKGLEXT)
|
||||||
|
@ -82,6 +82,9 @@
|
|||||||
/* GTK+ 2.x toolkit */
|
/* GTK+ 2.x toolkit */
|
||||||
#cmakedefine HAVE_GTK
|
#cmakedefine HAVE_GTK
|
||||||
|
|
||||||
|
/* GTK+ 3.x toolkit */
|
||||||
|
#cmakedefine HAVE_GTK3
|
||||||
|
|
||||||
/* Define to 1 if you have the <inttypes.h> header file. */
|
/* Define to 1 if you have the <inttypes.h> header file. */
|
||||||
#cmakedefine HAVE_INTTYPES_H 1
|
#cmakedefine HAVE_INTTYPES_H 1
|
||||||
|
|
||||||
|
@ -106,7 +106,7 @@ elseif(HAVE_QT)
|
|||||||
endif()
|
endif()
|
||||||
elseif(HAVE_WIN32UI)
|
elseif(HAVE_WIN32UI)
|
||||||
list(APPEND highgui_srcs src/window_w32.cpp)
|
list(APPEND highgui_srcs src/window_w32.cpp)
|
||||||
elseif(HAVE_GTK)
|
elseif(HAVE_GTK OR HAVE_GTK3)
|
||||||
list(APPEND highgui_srcs src/window_gtk.cpp)
|
list(APPEND highgui_srcs src/window_gtk.cpp)
|
||||||
elseif(HAVE_CARBON)
|
elseif(HAVE_CARBON)
|
||||||
list(APPEND highgui_srcs src/window_carbon.cpp)
|
list(APPEND highgui_srcs src/window_carbon.cpp)
|
||||||
|
@ -61,6 +61,8 @@ CV_IMPL void cvSetWindowProperty(const char* name, int prop_id, double prop_valu
|
|||||||
cvSetModeWindow_W32(name,prop_value);
|
cvSetModeWindow_W32(name,prop_value);
|
||||||
#elif defined (HAVE_GTK)
|
#elif defined (HAVE_GTK)
|
||||||
cvSetModeWindow_GTK(name,prop_value);
|
cvSetModeWindow_GTK(name,prop_value);
|
||||||
|
#elif defined (HAVE_GTK3)
|
||||||
|
cvSetModeWindow_GTK(name,prop_value);
|
||||||
#elif defined (HAVE_CARBON)
|
#elif defined (HAVE_CARBON)
|
||||||
cvSetModeWindow_CARBON(name,prop_value);
|
cvSetModeWindow_CARBON(name,prop_value);
|
||||||
#elif defined (HAVE_COCOA)
|
#elif defined (HAVE_COCOA)
|
||||||
@ -100,6 +102,8 @@ CV_IMPL double cvGetWindowProperty(const char* name, int prop_id)
|
|||||||
return cvGetModeWindow_W32(name);
|
return cvGetModeWindow_W32(name);
|
||||||
#elif defined (HAVE_GTK)
|
#elif defined (HAVE_GTK)
|
||||||
return cvGetModeWindow_GTK(name);
|
return cvGetModeWindow_GTK(name);
|
||||||
|
#elif defined (HAVE_GTK3)
|
||||||
|
return cvGetModeWindow_GTK(name);
|
||||||
#elif defined (HAVE_CARBON)
|
#elif defined (HAVE_CARBON)
|
||||||
return cvGetModeWindow_CARBON(name);
|
return cvGetModeWindow_CARBON(name);
|
||||||
#elif defined (HAVE_COCOA)
|
#elif defined (HAVE_COCOA)
|
||||||
@ -117,6 +121,8 @@ CV_IMPL double cvGetWindowProperty(const char* name, int prop_id)
|
|||||||
return cvGetPropWindowAutoSize_W32(name);
|
return cvGetPropWindowAutoSize_W32(name);
|
||||||
#elif defined (HAVE_GTK)
|
#elif defined (HAVE_GTK)
|
||||||
return cvGetPropWindowAutoSize_GTK(name);
|
return cvGetPropWindowAutoSize_GTK(name);
|
||||||
|
#elif defined (HAVE_GTK3)
|
||||||
|
return cvGetPropWindowAutoSize_GTK(name);
|
||||||
#else
|
#else
|
||||||
return -1;
|
return -1;
|
||||||
#endif
|
#endif
|
||||||
@ -130,6 +136,8 @@ CV_IMPL double cvGetWindowProperty(const char* name, int prop_id)
|
|||||||
return cvGetRatioWindow_W32(name);
|
return cvGetRatioWindow_W32(name);
|
||||||
#elif defined (HAVE_GTK)
|
#elif defined (HAVE_GTK)
|
||||||
return cvGetRatioWindow_GTK(name);
|
return cvGetRatioWindow_GTK(name);
|
||||||
|
#elif defined (HAVE_GTK3)
|
||||||
|
return cvGetRatioWindow_GTK(name);
|
||||||
#else
|
#else
|
||||||
return -1;
|
return -1;
|
||||||
#endif
|
#endif
|
||||||
@ -143,6 +151,8 @@ CV_IMPL double cvGetWindowProperty(const char* name, int prop_id)
|
|||||||
return cvGetOpenGlProp_W32(name);
|
return cvGetOpenGlProp_W32(name);
|
||||||
#elif defined (HAVE_GTK)
|
#elif defined (HAVE_GTK)
|
||||||
return cvGetOpenGlProp_GTK(name);
|
return cvGetOpenGlProp_GTK(name);
|
||||||
|
#elif defined (HAVE_GTK3)
|
||||||
|
return cvGetOpenGlProp_GTK(name);
|
||||||
#else
|
#else
|
||||||
return -1;
|
return -1;
|
||||||
#endif
|
#endif
|
||||||
@ -472,6 +482,7 @@ int cv::createButton(const String&, ButtonCallback, void*, int , bool )
|
|||||||
|
|
||||||
#if defined(HAVE_WIN32UI) // see window_w32.cpp
|
#if defined(HAVE_WIN32UI) // see window_w32.cpp
|
||||||
#elif defined (HAVE_GTK) // see window_gtk.cpp
|
#elif defined (HAVE_GTK) // see window_gtk.cpp
|
||||||
|
#elif defined (HAVE_GTK3) // see window_gtk.cpp
|
||||||
#elif defined (HAVE_COCOA) // see window_carbon.cpp
|
#elif defined (HAVE_COCOA) // see window_carbon.cpp
|
||||||
#elif defined (HAVE_CARBON)
|
#elif defined (HAVE_CARBON)
|
||||||
#elif defined (HAVE_QT) //YV see window_QT.cpp
|
#elif defined (HAVE_QT) //YV see window_QT.cpp
|
||||||
|
@ -43,7 +43,7 @@
|
|||||||
|
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
|
|
||||||
#ifdef HAVE_GTK
|
#if defined (HAVE_GTK) || defined (HAVE_GTK3)
|
||||||
|
|
||||||
#include "gtk/gtk.h"
|
#include "gtk/gtk.h"
|
||||||
#include "gdk/gdkkeysyms.h"
|
#include "gdk/gdkkeysyms.h"
|
||||||
@ -150,32 +150,77 @@ cvImageWidget_realize (GtkWidget *widget)
|
|||||||
GdkWindowAttr attributes;
|
GdkWindowAttr attributes;
|
||||||
gint attributes_mask;
|
gint attributes_mask;
|
||||||
|
|
||||||
|
#if defined(HAVE_GTK3)
|
||||||
|
GtkAllocation allocation;
|
||||||
|
gtk_widget_get_allocation(widget, &allocation);
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
//printf("cvImageWidget_realize\n");
|
//printf("cvImageWidget_realize\n");
|
||||||
g_return_if_fail (widget != NULL);
|
g_return_if_fail (widget != NULL);
|
||||||
g_return_if_fail (CV_IS_IMAGE_WIDGET (widget));
|
g_return_if_fail (CV_IS_IMAGE_WIDGET (widget));
|
||||||
|
|
||||||
gtk_widget_set_realized(widget, true);
|
gtk_widget_set_realized(widget, TRUE);
|
||||||
|
|
||||||
|
#if defined(HAVE_GTK3)
|
||||||
|
attributes.x = allocation.x;
|
||||||
|
attributes.y = allocation.y;
|
||||||
|
attributes.width = allocation.width;
|
||||||
|
attributes.height = allocation.height;
|
||||||
|
#else
|
||||||
attributes.x = widget->allocation.x;
|
attributes.x = widget->allocation.x;
|
||||||
attributes.y = widget->allocation.y;
|
attributes.y = widget->allocation.y;
|
||||||
attributes.width = widget->allocation.width;
|
attributes.width = widget->allocation.width;
|
||||||
attributes.height = widget->allocation.height;
|
attributes.height = widget->allocation.height;
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
attributes.wclass = GDK_INPUT_OUTPUT;
|
attributes.wclass = GDK_INPUT_OUTPUT;
|
||||||
attributes.window_type = GDK_WINDOW_CHILD;
|
attributes.window_type = GDK_WINDOW_CHILD;
|
||||||
attributes.event_mask = gtk_widget_get_events (widget) |
|
attributes.event_mask = gtk_widget_get_events (widget) |
|
||||||
GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK |
|
GDK_EXPOSURE_MASK | GDK_BUTTON_PRESS_MASK |
|
||||||
GDK_BUTTON_RELEASE_MASK | GDK_POINTER_MOTION_MASK;
|
GDK_BUTTON_RELEASE_MASK | GDK_POINTER_MOTION_MASK;
|
||||||
attributes.visual = gtk_widget_get_visual (widget);
|
attributes.visual = gtk_widget_get_visual (widget);
|
||||||
attributes.colormap = gtk_widget_get_colormap (widget);
|
|
||||||
|
|
||||||
|
#if defined(HAVE_GTK3)
|
||||||
|
attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL;
|
||||||
|
gtk_widget_set_window(
|
||||||
|
widget,
|
||||||
|
gdk_window_new(
|
||||||
|
gtk_widget_get_parent_window(widget),
|
||||||
|
&attributes,
|
||||||
|
attributes_mask
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
gtk_widget_set_style(
|
||||||
|
widget,
|
||||||
|
gtk_style_attach(
|
||||||
|
gtk_widget_get_style(widget),
|
||||||
|
gtk_widget_get_window(widget)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
gdk_window_set_user_data (
|
||||||
|
gtk_widget_get_window(widget),
|
||||||
|
widget
|
||||||
|
);
|
||||||
|
|
||||||
|
gtk_style_set_background (
|
||||||
|
gtk_widget_get_style(widget),
|
||||||
|
gtk_widget_get_window(widget),
|
||||||
|
GTK_STATE_ACTIVE
|
||||||
|
);
|
||||||
|
#else
|
||||||
|
// The following lines are included to prevent breaking
|
||||||
|
// compatibility with older Gtk2 (<gtk+-2.18) libraries.
|
||||||
|
attributes.colormap = gtk_widget_get_colormap (widget);
|
||||||
attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP;
|
attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP;
|
||||||
widget->window = gdk_window_new (widget->parent->window, &attributes, attributes_mask);
|
widget->window = gdk_window_new (widget->parent->window, &attributes, attributes_mask);
|
||||||
|
|
||||||
widget->style = gtk_style_attach (widget->style, widget->window);
|
widget->style = gtk_style_attach (widget->style, widget->window);
|
||||||
|
|
||||||
gdk_window_set_user_data (widget->window, widget);
|
gdk_window_set_user_data (widget->window, widget);
|
||||||
|
|
||||||
gtk_style_set_background (widget->style, widget->window, GTK_STATE_ACTIVE);
|
gtk_style_set_background (widget->style, widget->window, GTK_STATE_ACTIVE);
|
||||||
|
#endif // HAVE_GTK3
|
||||||
}
|
}
|
||||||
|
|
||||||
static CvSize cvImageWidget_calc_size( int im_width, int im_height, int max_width, int max_height ){
|
static CvSize cvImageWidget_calc_size( int im_width, int im_height, int max_width, int max_height ){
|
||||||
@ -218,6 +263,26 @@ cvImageWidget_size_request (GtkWidget *widget,
|
|||||||
//printf("%d %d\n",requisition->width, requisition->height);
|
//printf("%d %d\n",requisition->width, requisition->height);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
static void
|
||||||
|
cvImageWidget_get_preferred_width (GtkWidget *widget, gint *minimal_width, gint *natural_width)
|
||||||
|
{
|
||||||
|
GtkRequisition requisition;
|
||||||
|
|
||||||
|
cvImageWidget_size_request (widget, &requisition);
|
||||||
|
*minimal_width = *natural_width = requisition.width;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
cvImageWidget_get_preferred_height (GtkWidget *widget, gint *minimal_height, gint *natural_height)
|
||||||
|
{
|
||||||
|
GtkRequisition requisition;
|
||||||
|
|
||||||
|
cvImageWidget_size_request (widget, &requisition);
|
||||||
|
*minimal_height = *natural_height = requisition.height;
|
||||||
|
}
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
static void cvImageWidget_set_size(GtkWidget * widget, int max_width, int max_height){
|
static void cvImageWidget_set_size(GtkWidget * widget, int max_width, int max_height){
|
||||||
CvImageWidget * image_widget = CV_IMAGE_WIDGET( widget );
|
CvImageWidget * image_widget = CV_IMAGE_WIDGET( widget );
|
||||||
|
|
||||||
@ -237,7 +302,7 @@ static void cvImageWidget_set_size(GtkWidget * widget, int max_width, int max_he
|
|||||||
cvReleaseMat( &image_widget->scaled_image );
|
cvReleaseMat( &image_widget->scaled_image );
|
||||||
}
|
}
|
||||||
if( !image_widget->scaled_image ){
|
if( !image_widget->scaled_image ){
|
||||||
image_widget->scaled_image = cvCreateMat( scaled_image_size.height, scaled_image_size.width, CV_8UC3 );
|
image_widget->scaled_image = cvCreateMat( scaled_image_size.height, scaled_image_size.width, CV_8UC3 );
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -255,7 +320,11 @@ cvImageWidget_size_allocate (GtkWidget *widget,
|
|||||||
g_return_if_fail (CV_IS_IMAGE_WIDGET (widget));
|
g_return_if_fail (CV_IS_IMAGE_WIDGET (widget));
|
||||||
g_return_if_fail (allocation != NULL);
|
g_return_if_fail (allocation != NULL);
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
gtk_widget_set_allocation(widget, allocation);
|
||||||
|
#else
|
||||||
widget->allocation = *allocation;
|
widget->allocation = *allocation;
|
||||||
|
#endif //HAVE_GTK3
|
||||||
image_widget = CV_IMAGE_WIDGET (widget);
|
image_widget = CV_IMAGE_WIDGET (widget);
|
||||||
|
|
||||||
|
|
||||||
@ -279,26 +348,37 @@ cvImageWidget_size_allocate (GtkWidget *widget,
|
|||||||
((image_widget->flags & CV_WINDOW_AUTOSIZE) ||
|
((image_widget->flags & CV_WINDOW_AUTOSIZE) ||
|
||||||
(image_widget->flags & CV_WINDOW_NO_IMAGE)) )
|
(image_widget->flags & CV_WINDOW_NO_IMAGE)) )
|
||||||
{
|
{
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
allocation->width = image_widget->original_image->cols;
|
||||||
|
allocation->height = image_widget->original_image->rows;
|
||||||
|
gtk_widget_set_allocation(widget, allocation);
|
||||||
|
#else
|
||||||
widget->allocation.width = image_widget->original_image->cols;
|
widget->allocation.width = image_widget->original_image->cols;
|
||||||
widget->allocation.height = image_widget->original_image->rows;
|
widget->allocation.height = image_widget->original_image->rows;
|
||||||
gdk_window_move_resize( widget->window, allocation->x, allocation->y,
|
#endif //HAVE_GTK3
|
||||||
image_widget->original_image->cols, image_widget->original_image->rows );
|
gdk_window_move_resize( gtk_widget_get_window(widget),
|
||||||
|
allocation->x, allocation->y,
|
||||||
|
image_widget->original_image->cols, image_widget->original_image->rows );
|
||||||
if(image_widget->flags & CV_WINDOW_NO_IMAGE){
|
if(image_widget->flags & CV_WINDOW_NO_IMAGE){
|
||||||
image_widget->flags &= ~CV_WINDOW_NO_IMAGE;
|
image_widget->flags &= ~CV_WINDOW_NO_IMAGE;
|
||||||
gtk_widget_queue_resize( GTK_WIDGET(widget) );
|
gtk_widget_queue_resize( GTK_WIDGET(widget) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
gdk_window_move_resize (widget->window,
|
gdk_window_move_resize (gtk_widget_get_window(widget),
|
||||||
allocation->x, allocation->y,
|
allocation->x, allocation->y,
|
||||||
allocation->width, allocation->height );
|
allocation->width, allocation->height );
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
static void
|
||||||
|
cvImageWidget_destroy (GtkWidget *object)
|
||||||
|
#else
|
||||||
static void
|
static void
|
||||||
cvImageWidget_destroy (GtkObject *object)
|
cvImageWidget_destroy (GtkObject *object)
|
||||||
|
#endif //HAVE_GTK3
|
||||||
{
|
{
|
||||||
CvImageWidget *image_widget;
|
CvImageWidget *image_widget;
|
||||||
|
|
||||||
@ -310,24 +390,39 @@ cvImageWidget_destroy (GtkObject *object)
|
|||||||
cvReleaseMat( &image_widget->scaled_image );
|
cvReleaseMat( &image_widget->scaled_image );
|
||||||
cvReleaseMat( &image_widget->original_image );
|
cvReleaseMat( &image_widget->original_image );
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
if (GTK_WIDGET_CLASS (parent_class)->destroy)
|
||||||
|
(* GTK_WIDGET_CLASS (parent_class)->destroy) (object);
|
||||||
|
#else
|
||||||
if (GTK_OBJECT_CLASS (parent_class)->destroy)
|
if (GTK_OBJECT_CLASS (parent_class)->destroy)
|
||||||
(* GTK_OBJECT_CLASS (parent_class)->destroy) (object);
|
(* GTK_OBJECT_CLASS (parent_class)->destroy) (object);
|
||||||
|
#endif //HAVE_GTK3
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cvImageWidget_class_init (CvImageWidgetClass * klass)
|
static void cvImageWidget_class_init (CvImageWidgetClass * klass)
|
||||||
{
|
{
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
|
||||||
|
#else
|
||||||
GtkObjectClass *object_class;
|
GtkObjectClass *object_class;
|
||||||
GtkWidgetClass *widget_class;
|
GtkWidgetClass *widget_class;
|
||||||
|
|
||||||
object_class = (GtkObjectClass*) klass;
|
object_class = (GtkObjectClass*) klass;
|
||||||
widget_class = (GtkWidgetClass*) klass;
|
widget_class = (GtkWidgetClass*) klass;
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
parent_class = GTK_WIDGET_CLASS( g_type_class_peek (gtk_widget_get_type ()) );
|
parent_class = GTK_WIDGET_CLASS( g_type_class_peek (gtk_widget_get_type ()) );
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
widget_class->destroy = cvImageWidget_destroy;
|
||||||
|
widget_class->get_preferred_width = cvImageWidget_get_preferred_width;
|
||||||
|
widget_class->get_preferred_height = cvImageWidget_get_preferred_height;
|
||||||
|
#else
|
||||||
object_class->destroy = cvImageWidget_destroy;
|
object_class->destroy = cvImageWidget_destroy;
|
||||||
|
widget_class->size_request = cvImageWidget_size_request;
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
widget_class->realize = cvImageWidget_realize;
|
widget_class->realize = cvImageWidget_realize;
|
||||||
widget_class->size_request = cvImageWidget_size_request;
|
|
||||||
widget_class->size_allocate = cvImageWidget_size_allocate;
|
widget_class->size_allocate = cvImageWidget_size_allocate;
|
||||||
widget_class->button_press_event = NULL;
|
widget_class->button_press_event = NULL;
|
||||||
widget_class->button_release_event = NULL;
|
widget_class->button_release_event = NULL;
|
||||||
@ -347,13 +442,15 @@ GType cvImageWidget_get_type (void){
|
|||||||
|
|
||||||
if (!image_type)
|
if (!image_type)
|
||||||
{
|
{
|
||||||
image_type = g_type_register_static_simple( GTK_TYPE_WIDGET,
|
image_type = g_type_register_static_simple(
|
||||||
(gchar*) "CvImageWidget",
|
GTK_TYPE_WIDGET,
|
||||||
sizeof(CvImageWidgetClass),
|
(gchar*) "CvImageWidget",
|
||||||
(GClassInitFunc) cvImageWidget_class_init,
|
sizeof(CvImageWidgetClass),
|
||||||
sizeof(CvImageWidget),
|
(GClassInitFunc) cvImageWidget_class_init,
|
||||||
(GInstanceInitFunc) cvImageWidget_init,
|
sizeof(CvImageWidget),
|
||||||
(GTypeFlags)NULL);
|
(GInstanceInitFunc) cvImageWidget_init,
|
||||||
|
(GTypeFlags)NULL
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return image_type;
|
return image_type;
|
||||||
@ -642,8 +739,12 @@ double cvGetRatioWindow_GTK(const char* name)
|
|||||||
if (!window)
|
if (!window)
|
||||||
EXIT; // keep silence here
|
EXIT; // keep silence here
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
result = static_cast<double>(
|
||||||
|
gtk_widget_get_allocated_width(window->widget)) / gtk_widget_get_allocated_height(window->widget);
|
||||||
|
#else
|
||||||
result = static_cast<double>(window->widget->allocation.width) / window->widget->allocation.height;
|
result = static_cast<double>(window->widget->allocation.width) / window->widget->allocation.height;
|
||||||
|
#endif // HAVE_GTK3
|
||||||
__END__;
|
__END__;
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
@ -738,7 +839,56 @@ namespace
|
|||||||
|
|
||||||
#endif // HAVE_OPENGL
|
#endif // HAVE_OPENGL
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
static gboolean cvImageWidget_draw(GtkWidget* widget, cairo_t *cr, gpointer data)
|
||||||
|
{
|
||||||
|
#ifdef HAVE_OPENGL
|
||||||
|
CvWindow* window = (CvWindow*)data;
|
||||||
|
|
||||||
|
if (window->useGl)
|
||||||
|
{
|
||||||
|
drawGl(window);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
(void)data;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
CvImageWidget *image_widget = NULL;
|
||||||
|
GdkPixbuf *pixbuf = NULL;
|
||||||
|
|
||||||
|
g_return_val_if_fail (widget != NULL, FALSE);
|
||||||
|
g_return_val_if_fail (CV_IS_IMAGE_WIDGET (widget), FALSE);
|
||||||
|
|
||||||
|
cr = gdk_cairo_create(gtk_widget_get_window(widget));
|
||||||
|
image_widget = CV_IMAGE_WIDGET (widget);
|
||||||
|
|
||||||
|
if( image_widget->scaled_image ){
|
||||||
|
// center image in available region
|
||||||
|
int x0 = (gtk_widget_get_allocated_width(widget) - image_widget->scaled_image->cols)/2;
|
||||||
|
int y0 = (gtk_widget_get_allocated_height(widget) - image_widget->scaled_image->rows)/2;
|
||||||
|
|
||||||
|
pixbuf = gdk_pixbuf_new_from_data(image_widget->scaled_image->data.ptr, GDK_COLORSPACE_RGB, false,
|
||||||
|
8, MIN(image_widget->scaled_image->cols, gtk_widget_get_allocated_width(widget)),
|
||||||
|
MIN(image_widget->scaled_image->rows, gtk_widget_get_allocated_height(widget)),
|
||||||
|
image_widget->scaled_image->step, NULL, NULL);
|
||||||
|
|
||||||
|
gdk_cairo_set_source_pixbuf(cr, pixbuf, x0, y0);
|
||||||
|
}
|
||||||
|
else if( image_widget->original_image ){
|
||||||
|
pixbuf = gdk_pixbuf_new_from_data(image_widget->original_image->data.ptr, GDK_COLORSPACE_RGB, false,
|
||||||
|
8, MIN(image_widget->original_image->cols, gtk_widget_get_allocated_width(widget)),
|
||||||
|
MIN(image_widget->original_image->rows, gtk_widget_get_allocated_height(widget)),
|
||||||
|
image_widget->original_image->step, NULL, NULL);
|
||||||
|
gdk_cairo_set_source_pixbuf(cr, pixbuf, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
cairo_paint(cr);
|
||||||
|
cairo_destroy(cr);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
static gboolean cvImageWidget_expose(GtkWidget* widget, GdkEventExpose* event, gpointer data)
|
static gboolean cvImageWidget_expose(GtkWidget* widget, GdkEventExpose* event, gpointer data)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_OPENGL
|
#ifdef HAVE_OPENGL
|
||||||
@ -776,6 +926,7 @@ static gboolean cvImageWidget_expose(GtkWidget* widget, GdkEventExpose* event, g
|
|||||||
8, MIN(image_widget->scaled_image->cols, widget->allocation.width),
|
8, MIN(image_widget->scaled_image->cols, widget->allocation.width),
|
||||||
MIN(image_widget->scaled_image->rows, widget->allocation.height),
|
MIN(image_widget->scaled_image->rows, widget->allocation.height),
|
||||||
image_widget->scaled_image->step, NULL, NULL);
|
image_widget->scaled_image->step, NULL, NULL);
|
||||||
|
|
||||||
gdk_cairo_set_source_pixbuf(cr, pixbuf, x0, y0);
|
gdk_cairo_set_source_pixbuf(cr, pixbuf, x0, y0);
|
||||||
}
|
}
|
||||||
else if( image_widget->original_image ){
|
else if( image_widget->original_image ){
|
||||||
@ -790,6 +941,7 @@ static gboolean cvImageWidget_expose(GtkWidget* widget, GdkEventExpose* event, g
|
|||||||
cairo_destroy(cr);
|
cairo_destroy(cr);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
CV_IMPL int cvNamedWindow( const char* name, int flags )
|
CV_IMPL int cvNamedWindow( const char* name, int flags )
|
||||||
{
|
{
|
||||||
@ -862,8 +1014,13 @@ CV_IMPL int cvNamedWindow( const char* name, int flags )
|
|||||||
G_CALLBACK(icvOnMouse), window );
|
G_CALLBACK(icvOnMouse), window );
|
||||||
g_signal_connect( window->frame, "delete-event",
|
g_signal_connect( window->frame, "delete-event",
|
||||||
G_CALLBACK(icvOnClose), window );
|
G_CALLBACK(icvOnClose), window );
|
||||||
|
#if defined(HAVE_GTK3)
|
||||||
|
g_signal_connect( window->widget, "draw",
|
||||||
|
G_CALLBACK(cvImageWidget_draw), window );
|
||||||
|
#else
|
||||||
g_signal_connect( window->widget, "expose-event",
|
g_signal_connect( window->widget, "expose-event",
|
||||||
G_CALLBACK(cvImageWidget_expose), window );
|
G_CALLBACK(cvImageWidget_expose), window );
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
gtk_widget_add_events (window->widget, GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_PRESS_MASK | GDK_POINTER_MOTION_MASK) ;
|
gtk_widget_add_events (window->widget, GDK_BUTTON_RELEASE_MASK | GDK_BUTTON_PRESS_MASK | GDK_POINTER_MOTION_MASK) ;
|
||||||
|
|
||||||
@ -1420,6 +1577,13 @@ CV_IMPL const char* cvGetWindowName( void* window_handle )
|
|||||||
return window_name;
|
return window_name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
#define GDK_Escape GDK_KEY_Escape
|
||||||
|
#define GDK_Return GDK_KEY_Return
|
||||||
|
#define GDK_Linefeed GDK_KEY_Linefeed
|
||||||
|
#define GDK_Tab GDK_KEY_Tab
|
||||||
|
#endif //HAVE_GTK3
|
||||||
|
|
||||||
static gboolean icvOnKeyPress( GtkWidget * /*widget*/,
|
static gboolean icvOnKeyPress( GtkWidget * /*widget*/,
|
||||||
GdkEventKey* event, gpointer /*user_data*/ )
|
GdkEventKey* event, gpointer /*user_data*/ )
|
||||||
{
|
{
|
||||||
@ -1550,8 +1714,13 @@ static gboolean icvOnMouse( GtkWidget *widget, GdkEvent *event, gpointer user_da
|
|||||||
image_widget->original_image &&
|
image_widget->original_image &&
|
||||||
image_widget->scaled_image ){
|
image_widget->scaled_image ){
|
||||||
// image origin is not necessarily at (0,0)
|
// image origin is not necessarily at (0,0)
|
||||||
|
#if defined (HAVE_GTK3)
|
||||||
|
int x0 = (gtk_widget_get_allocated_width(widget) - image_widget->scaled_image->cols)/2;
|
||||||
|
int y0 = (gtk_widget_get_allocated_height(widget) - image_widget->scaled_image->rows)/2;
|
||||||
|
#else
|
||||||
int x0 = (widget->allocation.width - image_widget->scaled_image->cols)/2;
|
int x0 = (widget->allocation.width - image_widget->scaled_image->cols)/2;
|
||||||
int y0 = (widget->allocation.height - image_widget->scaled_image->rows)/2;
|
int y0 = (widget->allocation.height - image_widget->scaled_image->rows)/2;
|
||||||
|
#endif //HAVE_GTK3
|
||||||
pt.x = cvRound( ((pt32f.x-x0)*image_widget->original_image->cols)/
|
pt.x = cvRound( ((pt32f.x-x0)*image_widget->original_image->cols)/
|
||||||
image_widget->scaled_image->cols );
|
image_widget->scaled_image->cols );
|
||||||
pt.y = cvRound( ((pt32f.y-y0)*image_widget->original_image->rows)/
|
pt.y = cvRound( ((pt32f.y-y0)*image_widget->original_image->rows)/
|
||||||
@ -1629,7 +1798,7 @@ CV_IMPL int cvWaitKey( int delay )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // HAVE_GTK
|
#endif // HAVE_GTK || HAVE_GTK3
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
|
|
||||||
/* End of file. */
|
/* End of file. */
|
||||||
|
Loading…
Reference in New Issue
Block a user