Milena (Olena)
User documentation 2.0a Id
Main Page
Related Pages
Modules
Namespaces
Classes
All
Classes
Namespaces
Functions
Variables
Typedefs
Enumerator
Groups
Pages
draw/line.hh
1
// Copyright (C) 2007, 2008, 2009 EPITA Research and Development
2
// Laboratory (LRDE)
3
//
4
// This file is part of Olena.
5
//
6
// Olena is free software: you can redistribute it and/or modify it under
7
// the terms of the GNU General Public License as published by the Free
8
// Software Foundation, version 2 of the License.
9
//
10
// Olena is distributed in the hope that it will be useful,
11
// but WITHOUT ANY WARRANTY; without even the implied warranty of
12
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13
// General Public License for more details.
14
//
15
// You should have received a copy of the GNU General Public License
16
// along with Olena. If not, see <http://www.gnu.org/licenses/>.
17
//
18
// As a special exception, you may use this file as part of a free
19
// software project without restriction. Specifically, if other files
20
// instantiate templates or use macros or inline functions from this
21
// file, or you compile this file and link it with other files to produce
22
// an executable, this file does not by itself cause the resulting
23
// executable to be covered by the GNU General Public License. This
24
// exception does not however invalidate any other reasons why the
25
// executable file might be covered by the GNU General Public License.
26
27
#ifndef MLN_DRAW_LINE_HH
28
# define MLN_DRAW_LINE_HH
29
34
35
# include <mln/core/concept/image.hh>
36
# include <mln/core/site_set/p_line2d.hh>
37
# include <mln/core/image/imorph/safe.hh>
38
# include <mln/data/paste.hh>
39
# include <mln/pw/image.hh>
40
# include <mln/pw/cst.hh>
41
42
43
namespace
mln
44
{
45
46
namespace
draw
47
{
48
62
template
<
typename
I>
63
void
line
(Image<I>& ima,
64
const
mln_psite(I)& beg,
const
mln_psite(I)& end,
65
const
mln_value(I)& v);
66
67
68
# ifndef MLN_INCLUDE_ONLY
69
70
template
<
typename
I>
71
inline
72
void
line
(
Image<I>
& ima_,
73
const
mln_psite(I)& beg,
const
mln_psite(I)& end,
74
const
mln_value(I)& v)
75
{
76
I& ima = exact(ima_);
77
mln_precondition(ima.is_valid());
78
if
(! ima.has(beg))
79
trace::warning(
"Begin site is not part of the given image."
);
80
if
(! ima.has(end))
81
trace::warning(
"End site is not part of the given image."
);
82
data::paste
(pw::cst(v) |
p_line2d
(beg, end),
83
safe(ima).rw());
84
}
85
86
# endif // ! MLN_INCLUDE_ONLY
87
88
}
// end of namespace mln::draw
89
90
}
// end of namespace mln
91
92
93
#endif // ! MLN_DRAW_LINE_HH
mln
draw
line.hh
Generated on Thu Nov 8 2012 10:58:10 for Milena (Olena) by
1.8.2-20120930