Spaces:
Running
Running
/* poppler-layer.cc: glib interface to poppler | |
* | |
* Copyright (C) 2008 Carlos Garcia Campos <[email protected]> | |
* | |
* 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 2, 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., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. | |
*/ | |
/** | |
* SECTION:poppler-layer | |
* @short_description: Layers | |
* @title: PopplerLayer | |
*/ | |
typedef struct _PopplerLayerClass PopplerLayerClass; | |
struct _PopplerLayerClass | |
{ | |
GObjectClass parent_class; | |
}; | |
G_DEFINE_TYPE(PopplerLayer, poppler_layer, G_TYPE_OBJECT) | |
static void poppler_layer_finalize(GObject *object) | |
{ | |
PopplerLayer *poppler_layer = POPPLER_LAYER(object); | |
if (poppler_layer->document) { | |
g_object_unref(poppler_layer->document); | |
poppler_layer->document = nullptr; | |
} | |
if (poppler_layer->title) { | |
g_free(poppler_layer->title); | |
poppler_layer->title = nullptr; | |
} | |
poppler_layer->layer = nullptr; | |
poppler_layer->rbgroup = nullptr; | |
G_OBJECT_CLASS(poppler_layer_parent_class)->finalize(object); | |
} | |
static void poppler_layer_init(PopplerLayer *layer) { } | |
static void poppler_layer_class_init(PopplerLayerClass *klass) | |
{ | |
GObjectClass *gobject_class = G_OBJECT_CLASS(klass); | |
gobject_class->finalize = poppler_layer_finalize; | |
} | |
PopplerLayer *_poppler_layer_new(PopplerDocument *document, Layer *layer, GList *rbgroup) | |
{ | |
PopplerLayer *poppler_layer; | |
const GooString *layer_name; | |
g_return_val_if_fail(POPPLER_IS_DOCUMENT(document), NULL); | |
g_return_val_if_fail(layer != nullptr, NULL); | |
poppler_layer = POPPLER_LAYER(g_object_new(POPPLER_TYPE_LAYER, nullptr)); | |
poppler_layer->document = (PopplerDocument *)g_object_ref(document); | |
poppler_layer->layer = layer; | |
poppler_layer->rbgroup = rbgroup; | |
layer_name = layer->oc->getName(); | |
poppler_layer->title = layer_name ? _poppler_goo_string_to_utf8(layer_name) : nullptr; | |
return poppler_layer; | |
} | |
/** | |
* poppler_layer_get_title: | |
* @layer: a #PopplerLayer | |
* | |
* Returns the name of the layer suitable for | |
* presentation as a title in a viewer's GUI | |
* | |
* Return value: a string containing the title of the layer | |
* | |
* Since: 0.12 | |
**/ | |
const gchar *poppler_layer_get_title(PopplerLayer *poppler_layer) | |
{ | |
g_return_val_if_fail(POPPLER_IS_LAYER(poppler_layer), NULL); | |
return poppler_layer->title; | |
} | |
/** | |
* poppler_layer_is_visible: | |
* @layer: a #PopplerLayer | |
* | |
* Returns whether @layer is visible | |
* | |
* Return value: %TRUE if @layer is visible | |
* | |
* Since: 0.12 | |
**/ | |
gboolean poppler_layer_is_visible(PopplerLayer *poppler_layer) | |
{ | |
g_return_val_if_fail(POPPLER_IS_LAYER(poppler_layer), FALSE); | |
return poppler_layer->layer->oc->getState() == OptionalContentGroup::On; | |
} | |
/** | |
* poppler_layer_show: | |
* @layer: a #PopplerLayer | |
* | |
* Shows @layer | |
* | |
* Since: 0.12 | |
**/ | |
void poppler_layer_show(PopplerLayer *poppler_layer) | |
{ | |
GList *l; | |
Layer *layer; | |
g_return_if_fail(POPPLER_IS_LAYER(poppler_layer)); | |
layer = poppler_layer->layer; | |
if (layer->oc->getState() == OptionalContentGroup::On) { | |
return; | |
} | |
layer->oc->setState(OptionalContentGroup::On); | |
for (l = poppler_layer->rbgroup; l && l->data; l = g_list_next(l)) { | |
OptionalContentGroup *oc = (OptionalContentGroup *)l->data; | |
if (oc != layer->oc) { | |
oc->setState(OptionalContentGroup::Off); | |
} | |
} | |
} | |
/** | |
* poppler_layer_hide: | |
* @layer: a #PopplerLayer | |
* | |
* Hides @layer. If @layer is the parent of other nested layers, | |
* such layers will be also hidden and will be blocked until @layer | |
* is shown again | |
* | |
* Since: 0.12 | |
**/ | |
void poppler_layer_hide(PopplerLayer *poppler_layer) | |
{ | |
Layer *layer; | |
g_return_if_fail(POPPLER_IS_LAYER(poppler_layer)); | |
layer = poppler_layer->layer; | |
if (layer->oc->getState() == OptionalContentGroup::Off) { | |
return; | |
} | |
layer->oc->setState(OptionalContentGroup::Off); | |
} | |
/** | |
* poppler_layer_is_parent: | |
* @layer: a #PopplerLayer | |
* | |
* Returns whether @layer is parent of other nested layers. | |
* | |
* Return value: %TRUE if @layer is a parent layer | |
* | |
* Since: 0.12 | |
**/ | |
gboolean poppler_layer_is_parent(PopplerLayer *poppler_layer) | |
{ | |
g_return_val_if_fail(POPPLER_IS_LAYER(poppler_layer), FALSE); | |
return poppler_layer->layer->kids != nullptr; | |
} | |
/** | |
* poppler_layer_get_radio_button_group_id: | |
* @layer: a #PopplerLayer | |
* | |
* Returns the numeric ID the radio button group associated with @layer. | |
* | |
* Return value: the ID of the radio button group associated with @layer, | |
* or 0 if the layer is not associated to any radio button group | |
* | |
* Since: 0.12 | |
**/ | |
gint poppler_layer_get_radio_button_group_id(PopplerLayer *poppler_layer) | |
{ | |
g_return_val_if_fail(POPPLER_IS_LAYER(poppler_layer), FALSE); | |
return GPOINTER_TO_INT(poppler_layer->rbgroup); | |
} | |