Blame gegl/buffer/gegl-sampler-nearest.c

Packit Service 2781ba
/* This file is part of GEGL
Packit Service 2781ba
 *
Packit Service 2781ba
 * GEGL is free software; you can redistribute it and/or
Packit Service 2781ba
 * modify it under the terms of the GNU Lesser General Public
Packit Service 2781ba
 * License as published by the Free Software Foundation; either
Packit Service 2781ba
 * version 3 of the License, or (at your option) any later version.
Packit Service 2781ba
 *
Packit Service 2781ba
 * GEGL is distributed in the hope that it will be useful,
Packit Service 2781ba
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 2781ba
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 2781ba
 * Lesser General Public License for more details.
Packit Service 2781ba
 *
Packit Service 2781ba
 * You should have received a copy of the GNU Lesser General Public
Packit Service 2781ba
 * License along with GEGL; if not, see <http://www.gnu.org/licenses/>.
Packit Service 2781ba
 *
Packit Service 2781ba
 */
Packit Service 2781ba
Packit Service 2781ba
#include "config.h"
Packit Service 2781ba
#include <string.h>
Packit Service 2781ba
Packit Service 2781ba
#include <glib-object.h>
Packit Service 2781ba
Packit Service 2781ba
#include "gegl.h"
Packit Service 2781ba
#include "gegl-types-internal.h"
Packit Service 2781ba
#include "gegl-buffer-private.h"
Packit Service 2781ba
#include "gegl-sampler-nearest.h"
Packit Service 2781ba
Packit Service 2781ba
Packit Service 2781ba
enum
Packit Service 2781ba
{
Packit Service 2781ba
  PROP_0,
Packit Service 2781ba
  PROP_LAST
Packit Service 2781ba
};
Packit Service 2781ba
Packit Service 2781ba
static void    gegl_sampler_nearest_get (GeglSampler  *self,
Packit Service 2781ba
                                         gdouble       x,
Packit Service 2781ba
                                         gdouble       y,
Packit Service 2781ba
                                         GeglMatrix2  *scale,
Packit Service 2781ba
                                         void         *output);
Packit Service 2781ba
static void    set_property             (GObject      *gobject,
Packit Service 2781ba
                                         guint         prop_id,
Packit Service 2781ba
                                         const GValue *value,
Packit Service 2781ba
                                         GParamSpec   *pspec);
Packit Service 2781ba
static void    get_property             (GObject      *gobject,
Packit Service 2781ba
                                         guint         prop_id,
Packit Service 2781ba
                                         GValue       *value,
Packit Service 2781ba
                                         GParamSpec   *pspec);
Packit Service 2781ba
Packit Service 2781ba
G_DEFINE_TYPE (GeglSamplerNearest, gegl_sampler_nearest, GEGL_TYPE_SAMPLER)
Packit Service 2781ba
Packit Service 2781ba
static void
Packit Service 2781ba
gegl_sampler_nearest_class_init (GeglSamplerNearestClass *klass)
Packit Service 2781ba
{
Packit Service 2781ba
  GeglSamplerClass *sampler_class = GEGL_SAMPLER_CLASS (klass);
Packit Service 2781ba
  GObjectClass *object_class = G_OBJECT_CLASS (klass);
Packit Service 2781ba
Packit Service 2781ba
  object_class->set_property = set_property;
Packit Service 2781ba
  object_class->get_property = get_property;
Packit Service 2781ba
Packit Service 2781ba
  sampler_class->get     = gegl_sampler_nearest_get;
Packit Service 2781ba
Packit Service 2781ba
}
Packit Service 2781ba
Packit Service 2781ba
static void
Packit Service 2781ba
gegl_sampler_nearest_init (GeglSamplerNearest *self)
Packit Service 2781ba
{
Packit Service 2781ba
   GEGL_SAMPLER (self)->context_rect[0].x = 0;
Packit Service 2781ba
   GEGL_SAMPLER (self)->context_rect[0].y = 0;
Packit Service 2781ba
   GEGL_SAMPLER (self)->context_rect[0].width = 1;
Packit Service 2781ba
   GEGL_SAMPLER (self)->context_rect[0].height = 1;
Packit Service 2781ba
   GEGL_SAMPLER (self)->interpolate_format = babl_format ("RGBA float");
Packit Service 2781ba
}
Packit Service 2781ba
Packit Service 2781ba
void
Packit Service 2781ba
gegl_sampler_nearest_get (GeglSampler *self,
Packit Service 2781ba
                          gdouble      x,
Packit Service 2781ba
                          gdouble      y,
Packit Service 2781ba
                          GeglMatrix2 *scale,
Packit Service 2781ba
                          void        *output)
Packit Service 2781ba
{
Packit Service 2781ba
  gfloat             *sampler_bptr;
Packit Service 2781ba
  sampler_bptr = gegl_sampler_get_from_buffer (self, (gint)x, (gint)y);
Packit Service 2781ba
  babl_process (babl_fish (self->interpolate_format, self->format), sampler_bptr, output, 1);
Packit Service 2781ba
}
Packit Service 2781ba
Packit Service 2781ba
static void
Packit Service 2781ba
set_property (GObject      *gobject,
Packit Service 2781ba
              guint         property_id,
Packit Service 2781ba
              const GValue *value,
Packit Service 2781ba
              GParamSpec   *pspec)
Packit Service 2781ba
{
Packit Service 2781ba
  switch (property_id)
Packit Service 2781ba
    {
Packit Service 2781ba
      default:
Packit Service 2781ba
        G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, property_id, pspec);
Packit Service 2781ba
        break;
Packit Service 2781ba
    }
Packit Service 2781ba
}
Packit Service 2781ba
Packit Service 2781ba
static void
Packit Service 2781ba
get_property (GObject    *gobject,
Packit Service 2781ba
              guint       property_id,
Packit Service 2781ba
              GValue     *value,
Packit Service 2781ba
              GParamSpec *pspec)
Packit Service 2781ba
{
Packit Service 2781ba
  switch (property_id)
Packit Service 2781ba
    {
Packit Service 2781ba
      default:
Packit Service 2781ba
        G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, property_id, pspec);
Packit Service 2781ba
        break;
Packit Service 2781ba
    }
Packit Service 2781ba
}