/*************************************************************************** gscrollview.cpp (c) 2004-2006 - Daniel Campos Fernández Gtkmae "GTK+ made easy" classes Realizado para la Junta de Extremadura. Consejería de Educación Ciencia y Tecnología. Proyecto gnuLinEx This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version. This program 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ***************************************************************************/ #include "widgets.h" #include "widgets_private.h" #include "gscrollview.h" void gSV_scroll(GtkAdjustment *Adj,gScrollView *data) { if (data->onScroll) data->onScroll(data); } gScrollView::gScrollView(gContainer *parent) : gContainer(parent) { GtkAdjustment* Adj; g_typ=Type_gScrollView; _mw = _mh = 0; _scroll = gtk_scrolled_window_new(NULL,NULL); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(_scroll), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); //gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(border), GTK_SHADOW_ETCHED_IN); //gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(border), widget); //gtk_container_add(GTK_CONTAINER(border), widget); viewport = gtk_viewport_new(gtk_scrolled_window_get_hadjustment(GTK_SCROLLED_WINDOW(_scroll)), gtk_scrolled_window_get_vadjustment (GTK_SCROLLED_WINDOW(_scroll))); gtk_viewport_set_shadow_type(GTK_VIEWPORT(viewport), GTK_SHADOW_NONE); gtk_container_add(GTK_CONTAINER(_scroll), viewport); border = _scroll; widget = gtk_layout_new(0,0); realize(false); setBorder(true); Adj=gtk_scrolled_window_get_hadjustment(GTK_SCROLLED_WINDOW(_scroll)); g_signal_connect(G_OBJECT(Adj),"value-changed",G_CALLBACK(gSV_scroll),this); Adj=gtk_scrolled_window_get_vadjustment(GTK_SCROLLED_WINDOW(_scroll)); g_signal_connect(G_OBJECT(Adj),"value-changed",G_CALLBACK(gSV_scroll),this); } bool gScrollView::hasBorder() { if (gtk_scrolled_window_get_shadow_type(GTK_SCROLLED_WINDOW(border))==GTK_SHADOW_NONE) return false; return true; } void gScrollView::setBorder(bool vl) { if (vl) gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(border),GTK_SHADOW_IN); else gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(border),GTK_SHADOW_NONE); } void gScrollView::updateSize() { int bucle; int minX=0,maxX=0,minY=0,maxY=0; gControl *ch; for (bucle=0;bucleisVisible()) continue; if (ch->left()<0) if (ch->left()left(); if ( (ch->width()+ch->left())>maxX ) maxX=ch->width()+ch->left(); if (ch->top()<0) if (ch->top()top(); if ( (ch->height()+ch->top())>maxY ) maxY=ch->height()+ch->top(); } _mw = maxX-minX; if (_mw < viewport->allocation.width) _mw = viewport->allocation.width; _mh = maxY-minY; if (_mh < viewport->allocation.height) _mh = viewport->allocation.height; gtk_widget_set_size_request(widget, _mw, _mh); } void gScrollView::performArrange() { gContainer::performArrange(); updateSize(); } void gScrollView::resize(int w, int h) { if (w == bufW && h == bufH) return; gContainer::resize(w, h); if (bufW == 0 || bufH == 0) return; //updateSize(); //performArrange(); //parent()->performArrange(); } void gScrollView::ensureVisible(int x, int y, int w, int h) { if (!GTK_IS_SCROLLED_WINDOW(border)) return; GtEnsureVisible arg; arg.clientWidth = clientWidth(); arg.clientHeight = clientHeight(); arg.scrollX = scrollX(); arg.scrollY = scrollY(); arg.scrollWidth = scrollWidth(); arg.scrollHeight = scrollHeight(); gt_ensure_visible(&arg, x, y, w, h); scroll(arg.scrollX, arg.scrollY); }