File: BitmapFilter.hxx

package info (click to toggle)
libreoffice 4%3A26.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,833,120 kB
  • sloc: cpp: 4,395,780; xml: 499,109; java: 254,438; python: 81,820; ansic: 33,823; perl: 30,297; javascript: 19,722; sh: 12,050; makefile: 10,854; cs: 8,865; yacc: 8,549; objc: 2,131; lex: 1,385; asm: 1,231; awk: 996; pascal: 914; csh: 20; sed: 5
file content (79 lines) | stat: -rw-r--r-- 2,755 bytes parent folder | download | duplicates (5)
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 */

#pragma once

#include <vcl/bitmap.hxx>
#include <functional>

class Animation;

namespace vcl::bitmap
{
// Generates strip ranges and run the input function with the start and
// end as parameters. The additional parameter bLast denotes if the
// iteration is the last one.
//
// Example:
// first = 0, last = 100, STRIP_SIZE = 32
// this will generate:
// [0, 31, false], [32, 63, false], [64, 95, false], [96, 100, true]
template <int STRIP_SIZE>
void generateStripRanges(
    tools::Long nFirst, tools::Long nLast,
    std::function<void(tools::Long const nStart, tools::Long const nEnd, bool const bLast)>
        aFunction)
{
    tools::Long nStart = nFirst;
    for (; nStart < nLast - STRIP_SIZE; nStart += STRIP_SIZE)
    {
        tools::Long nEnd = nStart + STRIP_SIZE - 1;
        aFunction(nStart, nEnd, false);
    }
    aFunction(nStart, nLast, true);
}

} // end vcl::bitmap

/** BitmapFilter transforms (or "filters") a given bitmap based on a provided filter.
    It is based on the command pattern, which allows for additional filters without
    needing to modify existing client code.

    The BitmapFilter class is the base class, to implement a new filter you derive
    your new filter from this and implement the filtering functionality in the execute()
    function.

    The execute function takes the Bitmap that you want to apply the filter to, and
    returns a brand new, filtered, Bitmap instance.

    The actual filters parameterisation is expected to be done in the constructor. So, to
    take a simple example, if you want to make every fourth pixel a different color you
    would accept a BitmapColor parameter that specifies the color, and stores this as a
    member variable that the Bitmap4thColorReplaceFilter would then use in its execute()
    statement.

    The BitmapFilter class has a static convenience Filter function that takes a Bitmap
    and the desired filter, which filters the Bitmap parameter, then overwrite this Bitmap
    instance. If the filter fails (Bitmap is empty) then it returns false.
*/

class VCL_DLLPUBLIC BitmapFilter
{
public:
    BitmapFilter();
    virtual ~BitmapFilter();

    virtual Bitmap execute(Bitmap const& rBitmap) const = 0;

    static bool Filter(Bitmap& rBmp, BitmapFilter const& rFilter);
    static bool Filter(Animation& rBmpEx, BitmapFilter const& rFilter);
};

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */