/* poppler-layer.cc: glib interface to poppler * * Copyright (C) 2008 Carlos Garcia Campos * * 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. */ #include "poppler-layer.h" #include "poppler-private.h" /** * 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); }