File: low-level.cc

package info (click to toggle)
exactimage 0.9.1-16
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 4,264 kB
  • ctags: 6,386
  • sloc: cpp: 33,621; ansic: 1,730; xml: 1,590; makefile: 333; perl: 138; sh: 109; python: 45; php: 37
file content (41 lines) | stat: -rw-r--r-- 1,374 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/*
 * Misc. low-level helpers, usually to aid debugging.
 * Copyright (C) 2007 - 2010 Ren\xc3\xa9 Rebe, ExactCOD GmbH Germany
 *
 * 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; version 2. A copy of the GNU General
 * Public License can be found in the file LICENSE.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANT-
 * ABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
 * Public License for more details.
 *
 * Alternatively, commercial licensing options are available from the
 * copyright holder ExactCODE GmbH Germany.
 */

#include <stdlib.h> // malloc
#include <string.h> // memcpy

#include "low-level.hh"

void deinterlace (Image& image)
{
  const int stride = image.stride();
  const int height = image.height();
  uint8_t* deinterlaced = (uint8_t*) malloc(image.stride() * height);
  
  for (int i = 0; i < height; ++i)
    {
      const int dst_i = i / 2 + (i % 2) * (height / 2);
      std::cerr << i << " - " << dst_i << std::endl;
      uint8_t* dst = deinterlaced + stride * dst_i;
      uint8_t* src = image.getRawData() + stride * i;
      
      memcpy(dst, src, stride);
    }
  
  image.setRawData(deinterlaced);
}