2000-06-01 20:20:13 +08:00
|
|
|
/* LIBGIMP - The GIMP Library
|
|
|
|
* Copyright (C) 1995-2000 Peter Mattis and Spencer Kimball
|
|
|
|
*
|
|
|
|
* gimpselection.c
|
|
|
|
*
|
2009-01-18 06:28:01 +08:00
|
|
|
* This library is free software: you can redistribute it and/or
|
2000-06-01 20:20:13 +08:00
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
2009-01-18 06:28:01 +08:00
|
|
|
* version 3 of the License, or (at your option) any later version.
|
2000-06-01 20:20:13 +08:00
|
|
|
*
|
|
|
|
* This library 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
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2009-01-18 06:28:01 +08:00
|
|
|
* License along with this library. If not, see
|
2018-07-12 05:27:07 +08:00
|
|
|
* <https://www.gnu.org/licenses/>.
|
2000-06-01 20:20:13 +08:00
|
|
|
*/
|
|
|
|
|
2002-05-14 07:30:23 +08:00
|
|
|
#include "config.h"
|
|
|
|
|
2000-06-01 20:20:13 +08:00
|
|
|
#include "gimp.h"
|
|
|
|
|
2019-08-14 03:36:03 +08:00
|
|
|
|
2021-04-06 18:39:52 +08:00
|
|
|
struct _GimpSelection
|
2019-08-27 22:47:17 +08:00
|
|
|
{
|
2021-04-06 18:39:52 +08:00
|
|
|
GimpChannel parent_instance;
|
2019-08-27 22:47:17 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2021-04-06 18:39:52 +08:00
|
|
|
G_DEFINE_TYPE (GimpSelection, gimp_selection, GIMP_TYPE_CHANNEL)
|
2019-08-14 03:36:03 +08:00
|
|
|
|
|
|
|
#define parent_class gimp_selection_parent_class
|
|
|
|
|
2019-08-27 22:47:17 +08:00
|
|
|
|
2019-08-14 03:36:03 +08:00
|
|
|
static void
|
|
|
|
gimp_selection_class_init (GimpSelectionClass *klass)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
gimp_selection_init (GimpSelection *selection)
|
|
|
|
{
|
|
|
|
}
|
2019-08-15 18:12:25 +08:00
|
|
|
|
2019-09-03 16:24:24 +08:00
|
|
|
/**
|
|
|
|
* gimp_selection_get_by_id:
|
|
|
|
* @selection_id: The selection id.
|
|
|
|
*
|
|
|
|
* Returns a #GimpSelection representing @selection_id. This function
|
|
|
|
* calls gimp_item_get_by_id() and returns the item if it is selection
|
|
|
|
* or %NULL otherwise.
|
|
|
|
*
|
|
|
|
* Returns: (nullable) (transfer none): a #GimpSelection for
|
|
|
|
* @selection_id or %NULL if @selection_id does not represent
|
|
|
|
* a valid selection. The object belongs to libgimp and you
|
|
|
|
* must not modify or unref it.
|
|
|
|
*
|
|
|
|
* Since: 3.0
|
|
|
|
**/
|
|
|
|
GimpSelection *
|
|
|
|
gimp_selection_get_by_id (gint32 selection_id)
|
|
|
|
{
|
|
|
|
GimpItem *item = gimp_item_get_by_id (selection_id);
|
|
|
|
|
|
|
|
if (GIMP_IS_SELECTION (item))
|
|
|
|
return (GimpSelection *) item;
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2000-08-25 08:37:35 +08:00
|
|
|
/**
|
|
|
|
* gimp_selection_float:
|
2020-05-18 07:33:28 +08:00
|
|
|
* @image: ignored
|
|
|
|
* @n_drawables: Size of @drawables.
|
|
|
|
* @drawables: (array length=n_drawables): The drawables from which to
|
|
|
|
* float selection.
|
|
|
|
* @offx: x offset for translation.
|
|
|
|
* @offy: y offset for translation.
|
2019-08-13 22:16:08 +08:00
|
|
|
*
|
|
|
|
* Float the selection from the specified drawable with initial offsets
|
|
|
|
* as specified.
|
|
|
|
*
|
|
|
|
* This procedure determines the region of the specified drawable that
|
|
|
|
* lies beneath the current selection. The region is then cut from the
|
|
|
|
* drawable and the resulting data is made into a new layer which is
|
|
|
|
* instantiated as a floating selection. The offsets allow initial
|
|
|
|
* positioning of the new floating selection.
|
|
|
|
*
|
2019-08-27 22:47:17 +08:00
|
|
|
* Returns: (transfer none): The floated layer.
|
2019-08-13 22:16:08 +08:00
|
|
|
*/
|
|
|
|
GimpLayer *
|
2020-05-18 07:33:28 +08:00
|
|
|
gimp_selection_float (GimpImage *image,
|
|
|
|
gint n_drawables,
|
|
|
|
GimpDrawable **drawables,
|
|
|
|
gint offx,
|
|
|
|
gint offy)
|
2019-08-13 22:16:08 +08:00
|
|
|
{
|
2020-05-18 07:33:28 +08:00
|
|
|
return _gimp_selection_float (n_drawables,
|
|
|
|
(const GimpItem **) drawables,
|
2019-08-13 22:16:08 +08:00
|
|
|
offx,
|
|
|
|
offy);
|
|
|
|
}
|