Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv_contrib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv_contrib
Commits
c26e0c08
Commit
c26e0c08
authored
Aug 07, 2014
by
Bellaktris
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
try to fix more errors
parent
4eaf9946
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
54 additions
and
67 deletions
+54
-67
structured_edge_detection.hpp
...oc/include/opencv2/ximpgroc/structured_edge_detection.hpp
+1
-1
whitebalance.rst
modules/xphoto/doc/colorbalance/whitebalance.rst
+2
-5
algo.hpp
modules/xphoto/src/algo.hpp
+0
-11
annf.hpp
modules/xphoto/src/annf.hpp
+0
-5
dct_image_denoising.cpp
modules/xphoto/src/dct_image_denoising.cpp
+3
-2
gcgraph.hpp
modules/xphoto/src/gcgraph.hpp
+0
-3
inpainting.cpp
modules/xphoto/src/inpainting.cpp
+5
-4
norm2.hpp
modules/xphoto/src/norm2.hpp
+11
-0
photomontage.hpp
modules/xphoto/src/photomontage.hpp
+32
-36
No files found.
modules/ximpgroc/include/opencv2/ximpgroc/structured_edge_detection.hpp
View file @
c26e0c08
...
@@ -90,7 +90,7 @@ public:
...
@@ -90,7 +90,7 @@ public:
/*!
/*!
* ...
* ...
*/
*/
CV_EXPORTS_W
Ptr
<
RFFeatureGetter
>
createRFFeatureGetter
(
void
);
CV_EXPORTS_W
Ptr
<
RFFeatureGetter
>
createRFFeatureGetter
();
...
...
modules/xphoto/doc/colorbalance/whitebalance.rst
View file @
c26e0c08
...
@@ -15,12 +15,9 @@ due to specific illumination or camera settings).
...
@@ -15,12 +15,9 @@ due to specific illumination or camera settings).
:param src : source image
:param src : source image
:param dst : destination image
:param dst : destination image
:param algorithmType : type of the algorithm to use.
:param algorithmType : type of the algorithm to use. Use WHITE_BALANCE_SIMPLE to perform
Use WHITE_BALANCE_SIMPLE to perform
smart histogram adjustments (ignoring 4% pixels with minimal
smart histogram adjustments
(ignoring 4% pixels with minimal
and maximal values) for each channel.
and maximal values) for each channel.
:param inputMin : minimum value in the input image
:param inputMin : minimum value in the input image
:param inputMax : maximum value in the input image
:param inputMax : maximum value in the input image
:param outputMin : minimum value in the output image
:param outputMin : minimum value in the output image
...
...
modules/xphoto/src/algo.hpp
View file @
c26e0c08
...
@@ -40,16 +40,6 @@
...
@@ -40,16 +40,6 @@
#ifndef __ALGO_HPP__
#ifndef __ALGO_HPP__
#define __ALGO_HPP__
#define __ALGO_HPP__
#include <vector>
#include <algorithm>
#include <cmath>
#include <cstdlib>
#include <limits>
namespace
xphotoInternal
{
template
<
typename
Tp
>
static
int
min_idx
(
std
::
vector
<
Tp
>
vec
)
template
<
typename
Tp
>
static
int
min_idx
(
std
::
vector
<
Tp
>
vec
)
{
{
...
@@ -68,5 +58,4 @@ static inline int hamming_length(int x)
...
@@ -68,5 +58,4 @@ static inline int hamming_length(int x)
}
}
}
#endif
/* __ALGO_HPP__ */
#endif
/* __ALGO_HPP__ */
modules/xphoto/src/annf.hpp
View file @
c26e0c08
...
@@ -42,10 +42,6 @@
...
@@ -42,10 +42,6 @@
#include "algo.hpp"
#include "algo.hpp"
namespace
xphotoInternal
{
static
void
plusToMinusUpdate
(
const
cv
::
Mat
&
current
,
cv
::
Mat
&
next
,
const
int
dx
,
const
int
dy
)
static
void
plusToMinusUpdate
(
const
cv
::
Mat
&
current
,
cv
::
Mat
&
next
,
const
int
dx
,
const
int
dy
)
{
{
for
(
int
i
=
0
;
i
<
next
.
rows
;
++
i
)
for
(
int
i
=
0
;
i
<
next
.
rows
;
++
i
)
...
@@ -127,5 +123,4 @@ static void getWHSeries(const cv::Mat &src, cv::Mat &dst, const int nProjections
...
@@ -127,5 +123,4 @@ static void getWHSeries(const cv::Mat &src, cv::Mat &dst, const int nProjections
}
}
}
#endif
/* __ANNF_HPP__ */
#endif
/* __ANNF_HPP__ */
modules/xphoto/src/dct_image_denoising.cpp
View file @
c26e0c08
...
@@ -63,7 +63,7 @@ namespace cv
...
@@ -63,7 +63,7 @@ namespace cv
{
{
public
:
public
:
grayDctDenoisingInvoker
(
const
Mat
&
src
,
std
::
vector
<
Mat
>
&
patches
,
const
double
sigma
,
const
int
psize
);
grayDctDenoisingInvoker
(
const
Mat
&
src
,
std
::
vector
<
Mat
>
&
patches
,
const
double
sigma
,
const
int
psize
);
~
grayDctDenoisingInvoker
();
~
grayDctDenoisingInvoker
()
{}
;
void
operator
()
(
const
Range
&
range
)
const
;
void
operator
()
(
const
Range
&
range
)
const
;
...
@@ -74,12 +74,13 @@ namespace cv
...
@@ -74,12 +74,13 @@ namespace cv
const
int
psize
;
// size of block to compute dct
const
int
psize
;
// size of block to compute dct
const
double
sigma
;
// expected noise standard deviation
const
double
sigma
;
// expected noise standard deviation
const
double
thresh
;
// thresholding estimate
const
double
thresh
;
// thresholding estimate
void
operator
=
(
const
grayDctDenoisingInvoker
&
)
const
{};
};
};
grayDctDenoisingInvoker
::
grayDctDenoisingInvoker
(
const
Mat
&
_src
,
std
::
vector
<
Mat
>
&
_patches
,
grayDctDenoisingInvoker
::
grayDctDenoisingInvoker
(
const
Mat
&
_src
,
std
::
vector
<
Mat
>
&
_patches
,
const
double
_sigma
,
const
int
_psize
)
const
double
_sigma
,
const
int
_psize
)
:
src
(
_src
),
patches
(
_patches
),
sigma
(
_sigma
),
thresh
(
3
*
_sigma
),
psize
(
_psize
)
{}
:
src
(
_src
),
patches
(
_patches
),
sigma
(
_sigma
),
thresh
(
3
*
_sigma
),
psize
(
_psize
)
{}
grayDctDenoisingInvoker
::~
grayDctDenoisingInvoker
(){}
void
grayDctDenoisingInvoker
::
operator
()
(
const
Range
&
range
)
const
void
grayDctDenoisingInvoker
::
operator
()
(
const
Range
&
range
)
const
{
{
...
...
modules/xphoto/src/gcgraph.hpp
View file @
c26e0c08
...
@@ -42,9 +42,6 @@
...
@@ -42,9 +42,6 @@
#ifndef _CV_GCGRAPH_H_
#ifndef _CV_GCGRAPH_H_
#define _CV_GCGRAPH_H_
#define _CV_GCGRAPH_H_
#include <vector>
#include <opencv2/core.hpp>
template
<
class
TWeight
>
class
GCGraph
template
<
class
TWeight
>
class
GCGraph
{
{
...
...
modules/xphoto/src/inpainting.cpp
View file @
c26e0c08
...
@@ -52,10 +52,11 @@
...
@@ -52,10 +52,11 @@
#include "opencv2/core/types.hpp"
#include "opencv2/core/types.hpp"
#include "opencv2/core/types_c.h"
#include "opencv2/core/types_c.h"
namespace
xphotoInternal
#include "photomontage.hpp"
{
#include "annf.hpp"
# include "photomontage.hpp"
# include "annf.hpp"
}
namespace
cv
namespace
cv
{
{
...
...
modules/xphoto/src/norm2.hpp
View file @
c26e0c08
...
@@ -40,6 +40,17 @@
...
@@ -40,6 +40,17 @@
#ifndef __NORM2_HPP__
#ifndef __NORM2_HPP__
#define __NORM2_HPP__
#define __NORM2_HPP__
static
inline
int
sqr
(
uchar
x
)
{
return
x
*
x
;
}
template
<
int
cn
>
static
inline
int
sqr
(
cv
::
Vec
<
uchar
,
cn
>
x
)
{
return
x
.
dot
(
x
);
}
static
inline
int
norm2
(
const
uchar
&
a
,
const
uchar
&
b
)
{
return
sqr
(
a
-
b
);
}
template
<
int
cn
>
static
inline
int
norm2
(
const
cv
::
Vec
<
uchar
,
cn
>
&
a
,
const
cv
::
Vec
<
uchar
,
cn
>
&
b
)
{
return
sqr
(
a
-
b
);
}
template
<
typename
Tp
>
static
inline
Tp
sqr
(
Tp
x
)
{
return
x
*
x
;
}
template
<
typename
Tp
>
static
inline
Tp
sqr
(
Tp
x
)
{
return
x
*
x
;
}
template
<
typename
Tp
,
int
cn
>
static
inline
Tp
sqr
(
cv
::
Vec
<
Tp
,
cn
>
x
)
{
return
x
.
dot
(
x
);
}
template
<
typename
Tp
,
int
cn
>
static
inline
Tp
sqr
(
cv
::
Vec
<
Tp
,
cn
>
x
)
{
return
x
.
dot
(
x
);
}
...
...
modules/xphoto/src/photomontage.hpp
View file @
c26e0c08
...
@@ -40,20 +40,14 @@
...
@@ -40,20 +40,14 @@
#ifndef __PHOTOMONTAGE_HPP__
#ifndef __PHOTOMONTAGE_HPP__
#define __PHOTOMONTAGE_HPP__
#define __PHOTOMONTAGE_HPP__
#include <opencv2/core.hpp>
#include "norm2.hpp"
#include "norm2.hpp"
#include "algo.hpp"
#include "algo.hpp"
#include "annf.hpp"
#include "gcgraph.hpp"
#include "gcgraph.hpp"
#define GCInfinity 10*1000*1000*1000.0
#define GCInfinity 10*1000*1000*1000.0
namespace
xphotoInternal
{
template
<
typename
Tp
>
class
Photomontage
template
<
typename
Tp
>
class
Photomontage
{
{
private
:
private
:
...
@@ -89,6 +83,8 @@ private:
...
@@ -89,6 +83,8 @@ private:
}
}
};
};
void
operator
=
(
const
Photomontage
<
Tp
>&
)
const
{};
protected
:
protected
:
virtual
double
dist
(
const
Tp
&
l1p1
,
const
Tp
&
l1p2
,
const
Tp
&
l2p1
,
const
Tp
&
l2p2
);
virtual
double
dist
(
const
Tp
&
l1p1
,
const
Tp
&
l1p2
,
const
Tp
&
l2p1
,
const
Tp
&
l2p2
);
virtual
void
setWeights
(
GCGraph
<
double
>
&
graph
,
const
cv
::
Point
&
pA
,
const
cv
::
Point
&
pB
,
const
int
lA
,
const
int
lB
,
const
int
lX
);
virtual
void
setWeights
(
GCGraph
<
double
>
&
graph
,
const
cv
::
Point
&
pA
,
const
cv
::
Point
&
pB
,
const
int
lA
,
const
int
lB
,
const
int
lX
);
...
@@ -101,7 +97,7 @@ public:
...
@@ -101,7 +97,7 @@ public:
void
assignResImage
(
cv
::
Mat
&
img
);
void
assignResImage
(
cv
::
Mat
&
img
);
};
};
template
<
typename
Tp
>
double
Photomontage
<
Tp
>::
template
<
typename
Tp
>
inline
double
Photomontage
<
Tp
>::
dist
(
const
Tp
&
l1p1
,
const
Tp
&
l1p2
,
const
Tp
&
l2p1
,
const
Tp
&
l2p2
)
dist
(
const
Tp
&
l1p1
,
const
Tp
&
l1p2
,
const
Tp
&
l2p1
,
const
Tp
&
l2p2
)
{
{
return
norm2
(
l1p1
,
l2p1
)
+
norm2
(
l1p2
,
l2p2
);
return
norm2
(
l1p1
,
l2p1
)
+
norm2
(
l1p2
,
l2p2
);
...
@@ -113,10 +109,10 @@ setWeights(GCGraph <double> &graph, const cv::Point &pA, const cv::Point &pB, co
...
@@ -113,10 +109,10 @@ setWeights(GCGraph <double> &graph, const cv::Point &pA, const cv::Point &pB, co
if
(
lA
==
lB
)
if
(
lA
==
lB
)
{
{
/** Link from A to B **/
/** Link from A to B **/
double
weightAB
=
dist
(
images
[
lA
].
at
<
typename
Tp
>
(
pA
),
double
weightAB
=
dist
(
images
[
lA
].
template
at
<
Tp
>
(
pA
),
images
[
lA
].
at
<
typename
Tp
>
(
pB
),
images
[
lA
].
template
at
<
Tp
>
(
pB
),
images
[
lX
].
at
<
typename
Tp
>
(
pA
),
images
[
lX
].
template
at
<
Tp
>
(
pA
),
images
[
lX
].
at
<
typename
Tp
>
(
pB
)
);
images
[
lX
].
template
at
<
Tp
>
(
pB
)
);
graph
.
addEdges
(
int
(
pA
.
y
*
width
+
pA
.
x
),
int
(
pB
.
y
*
width
+
pB
.
x
),
weightAB
,
weightAB
);
graph
.
addEdges
(
int
(
pA
.
y
*
width
+
pA
.
x
),
int
(
pB
.
y
*
width
+
pB
.
x
),
weightAB
,
weightAB
);
}
}
else
else
...
@@ -124,24 +120,24 @@ setWeights(GCGraph <double> &graph, const cv::Point &pA, const cv::Point &pB, co
...
@@ -124,24 +120,24 @@ setWeights(GCGraph <double> &graph, const cv::Point &pA, const cv::Point &pB, co
int
X
=
graph
.
addVtx
();
int
X
=
graph
.
addVtx
();
/** Link from X to sink **/
/** Link from X to sink **/
double
weightXS
=
dist
(
images
[
lA
].
at
<
typename
Tp
>
(
pA
),
double
weightXS
=
dist
(
images
[
lA
].
template
at
<
Tp
>
(
pA
),
images
[
lA
].
at
<
typename
Tp
>
(
pB
),
images
[
lA
].
template
at
<
Tp
>
(
pB
),
images
[
lB
].
at
<
typename
Tp
>
(
pA
),
images
[
lB
].
template
at
<
Tp
>
(
pA
),
images
[
lB
].
at
<
typename
Tp
>
(
pB
)
);
images
[
lB
].
template
at
<
Tp
>
(
pB
)
);
graph
.
addTermWeights
(
X
,
0
,
weightXS
);
graph
.
addTermWeights
(
X
,
0
,
weightXS
);
/** Link from A to X **/
/** Link from A to X **/
double
weightAX
=
dist
(
images
[
lA
].
at
<
typename
Tp
>
(
pA
),
double
weightAX
=
dist
(
images
[
lA
].
template
at
<
Tp
>
(
pA
),
images
[
lA
].
at
<
typename
Tp
>
(
pB
),
images
[
lA
].
template
at
<
Tp
>
(
pB
),
images
[
lX
].
at
<
typename
Tp
>
(
pA
),
images
[
lX
].
template
at
<
Tp
>
(
pA
),
images
[
lX
].
at
<
typename
Tp
>
(
pB
)
);
images
[
lX
].
template
at
<
Tp
>
(
pB
)
);
graph
.
addEdges
(
int
(
pA
.
y
*
width
+
pA
.
x
),
X
,
weightAX
,
weightAX
);
graph
.
addEdges
(
int
(
pA
.
y
*
width
+
pA
.
x
),
X
,
weightAX
,
weightAX
);
/** Link from X to B **/
/** Link from X to B **/
double
weightXB
=
dist
(
images
[
lX
].
at
<
typename
Tp
>
(
pA
),
double
weightXB
=
dist
(
images
[
lX
].
template
at
<
Tp
>
(
pA
),
images
[
lX
].
at
<
typename
Tp
>
(
pB
),
images
[
lX
].
template
at
<
Tp
>
(
pB
),
images
[
lB
].
at
<
typename
Tp
>
(
pA
),
images
[
lB
].
template
at
<
Tp
>
(
pA
),
images
[
lB
].
at
<
typename
Tp
>
(
pB
)
);
images
[
lB
].
template
at
<
Tp
>
(
pB
)
);
graph
.
addEdges
(
X
,
int
(
pB
.
y
*
width
+
pB
.
x
),
weightXB
,
weightXB
);
graph
.
addEdges
(
X
,
int
(
pB
.
y
*
width
+
pB
.
x
),
weightXB
,
weightXB
);
}
}
}
}
...
@@ -155,20 +151,20 @@ singleExpansion(const int alpha)
...
@@ -155,20 +151,20 @@ singleExpansion(const int alpha)
/** Terminal links **/
/** Terminal links **/
for
(
int
i
=
0
;
i
<
height
;
++
i
)
for
(
int
i
=
0
;
i
<
height
;
++
i
)
{
{
const
uchar
*
maskAlphaRow
=
masks
[
alpha
].
ptr
<
uchar
>
(
i
);
const
uchar
*
maskAlphaRow
=
masks
[
alpha
].
template
ptr
<
uchar
>
(
i
);
const
int
*
labelRow
=
(
const
int
*
)
x_i
.
ptr
<
int
>
(
i
);
const
int
*
labelRow
=
(
const
int
*
)
x_i
.
template
ptr
<
int
>
(
i
);
for
(
int
j
=
0
;
j
<
width
;
++
j
)
for
(
int
j
=
0
;
j
<
width
;
++
j
)
graph
.
addTermWeights
(
graph
.
addVtx
(),
graph
.
addTermWeights
(
graph
.
addVtx
(),
maskAlphaRow
[
j
]
?
0
:
GCInfinity
,
maskAlphaRow
[
j
]
?
0
:
GCInfinity
,
masks
[
labelRow
[
j
]
].
at
<
uchar
>
(
i
,
j
)
?
0
:
GCInfinity
);
masks
[
labelRow
[
j
]
].
template
at
<
uchar
>
(
i
,
j
)
?
0
:
GCInfinity
);
}
}
/** Neighbor links **/
/** Neighbor links **/
for
(
int
i
=
0
;
i
<
height
-
1
;
++
i
)
for
(
int
i
=
0
;
i
<
height
-
1
;
++
i
)
{
{
const
int
*
currentRow
=
(
const
int
*
)
x_i
.
ptr
<
int
>
(
i
);
const
int
*
currentRow
=
(
const
int
*
)
x_i
.
template
ptr
<
int
>
(
i
);
const
int
*
nextRow
=
(
const
int
*
)
x_i
.
ptr
<
int
>
(
i
+
1
);
const
int
*
nextRow
=
(
const
int
*
)
x_i
.
template
ptr
<
int
>
(
i
+
1
);
for
(
int
j
=
0
;
j
<
width
-
1
;
++
j
)
for
(
int
j
=
0
;
j
<
width
-
1
;
++
j
)
{
{
...
@@ -180,7 +176,7 @@ singleExpansion(const int alpha)
...
@@ -180,7 +176,7 @@ singleExpansion(const int alpha)
currentRow
[
width
-
1
],
nextRow
[
width
-
1
],
alpha
);
currentRow
[
width
-
1
],
nextRow
[
width
-
1
],
alpha
);
}
}
const
int
*
currentRow
=
(
const
int
*
)
x_i
.
ptr
<
int
>
(
height
-
1
);
const
int
*
currentRow
=
(
const
int
*
)
x_i
.
template
ptr
<
int
>
(
height
-
1
);
for
(
int
i
=
0
;
i
<
width
-
1
;
++
i
)
for
(
int
i
=
0
;
i
<
width
-
1
;
++
i
)
setWeights
(
graph
,
cv
::
Point
(
height
-
1
,
i
),
cv
::
Point
(
height
-
1
,
i
+
1
),
setWeights
(
graph
,
cv
::
Point
(
height
-
1
,
i
),
cv
::
Point
(
height
-
1
,
i
+
1
),
currentRow
[
i
],
currentRow
[
i
+
1
],
alpha
);
currentRow
[
i
],
currentRow
[
i
+
1
],
alpha
);
...
@@ -192,8 +188,8 @@ singleExpansion(const int alpha)
...
@@ -192,8 +188,8 @@ singleExpansion(const int alpha)
labelings
[
alpha
].
create
(
height
,
width
,
CV_32SC1
);
labelings
[
alpha
].
create
(
height
,
width
,
CV_32SC1
);
for
(
int
i
=
0
;
i
<
height
;
++
i
)
for
(
int
i
=
0
;
i
<
height
;
++
i
)
{
{
const
int
*
inRow
=
(
const
int
*
)
x_i
.
ptr
<
int
>
(
i
);
const
int
*
inRow
=
(
const
int
*
)
x_i
.
template
ptr
<
int
>
(
i
);
int
*
outRow
=
(
int
*
)
labelings
[
alpha
].
ptr
<
int
>
(
i
);
int
*
outRow
=
(
int
*
)
labelings
[
alpha
].
template
ptr
<
int
>
(
i
);
for
(
int
j
=
0
;
j
<
width
;
++
j
)
for
(
int
j
=
0
;
j
<
width
;
++
j
)
outRow
[
j
]
=
graph
.
inSourceSegment
(
i
*
width
+
j
)
?
inRow
[
j
]
:
alpha
;
outRow
[
j
]
=
graph
.
inSourceSegment
(
i
*
width
+
j
)
?
inRow
[
j
]
:
alpha
;
...
@@ -242,7 +238,10 @@ assignResImage(cv::Mat &img)
...
@@ -242,7 +238,10 @@ assignResImage(cv::Mat &img)
for
(
int
i
=
0
;
i
<
height
;
++
i
)
for
(
int
i
=
0
;
i
<
height
;
++
i
)
for
(
int
j
=
0
;
j
<
width
;
++
j
)
for
(
int
j
=
0
;
j
<
width
;
++
j
)
img
.
at
<
Tp
>
(
i
,
j
)
=
images
[
optimalLabeling
.
at
<
int
>
(
i
,
j
)
].
at
<
Tp
>
(
i
,
j
);
{
cv
::
Mat
M
=
images
[
optimalLabeling
.
template
at
<
int
>
(
i
,
j
)];
img
.
template
at
<
Tp
>
(
i
,
j
)
=
M
.
template
at
<
Tp
>
(
i
,
j
);
}
}
}
template
<
typename
Tp
>
Photomontage
<
Tp
>::
template
<
typename
Tp
>
Photomontage
<
Tp
>::
...
@@ -250,10 +249,7 @@ Photomontage(const std::vector <cv::Mat> &_images, const std::vector <cv::Mat> &
...
@@ -250,10 +249,7 @@ Photomontage(const std::vector <cv::Mat> &_images, const std::vector <cv::Mat> &
:
:
images
(
_images
),
masks
(
_masks
),
labelings
(
images
.
size
()),
distances
(
images
.
size
()),
images
(
_images
),
masks
(
_masks
),
labelings
(
images
.
size
()),
distances
(
images
.
size
()),
height
(
int
(
images
[
0
].
rows
)),
width
(
int
(
images
[
0
].
cols
)),
type
(
images
[
0
].
type
()),
height
(
int
(
images
[
0
].
rows
)),
width
(
int
(
images
[
0
].
cols
)),
type
(
images
[
0
].
type
()),
channels
(
images
[
0
].
channels
()),
lsize
(
int
(
images
.
size
())),
x_i
(
height
,
width
,
CV_32SC1
){
channels
(
images
[
0
].
channels
()),
lsize
(
int
(
images
.
size
())),
x_i
(
height
,
width
,
CV_32SC1
){}
CV_Assert
(
images
[
0
].
depth
()
!=
CV_8U
&&
masks
[
0
].
depth
()
==
CV_8U
);
}
}
#endif
/* __PHOTOMONTAGE_HPP__ */
#endif
/* __PHOTOMONTAGE_HPP__ */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment