1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000,2001 by the OpenSG Forum *
9 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
11 \*---------------------------------------------------------------------------*/
12 /*---------------------------------------------------------------------------*\
15 * This library is free software; you can redistribute it and/or modify it *
16 * under the terms of the GNU Library General Public License as published *
17 * by the Free Software Foundation, version 2. *
19 * This library is distributed in the hope that it will be useful, but *
20 * WITHOUT ANY WARRANTY; without even the implied warranty of *
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
22 * Library General Public License for more details. *
24 * You should have received a copy of the GNU Library General Public *
25 * License along with this library; if not, write to the Free Software *
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
28 \*---------------------------------------------------------------------------*/
29 /*---------------------------------------------------------------------------*\
37 \*---------------------------------------------------------------------------*/
39 //---------------------------------------------------------------------------
41 //---------------------------------------------------------------------------
43 #include <OpenSG/OSGLog.h>
52 Image::Image(const Image
©
)
57 Image::Image(OSG::ImagePtr image
)
67 void Image::write(std::string filename
)
69 _image
->write(filename
.c_str());
72 Image
Image::clone(void)
76 clone
._image
= OSG::Image::create();
77 // beginEditCP(clone._image);
78 clone
._image
->set(_image
);
79 // endEditCP(clone._image);
85 void Image::diff(Image img
)
87 if( _image
->getWidth() != img
._image
->getWidth() ||
88 _image
->getHeight() != img
._image
->getHeight() ||
89 _image
->getPixelFormat() != img
._image
->getPixelFormat())
91 FWARNING(("Image::diff: incompatible images!"));
95 // beginEditCP(_image);
97 const OSG::UInt8
*sdata
= img
._image
->getData();
98 OSG::UInt8
*ddata
= _image
->editData();
100 OSG::UInt32 nb
= _image
->getSize(false,false,false);
102 for(OSG::UInt32 i
= 0; i
< nb
; ++i
, ++sdata
, ++ddata
)
104 *ddata
= OSG::osgabs(*ddata
- *sdata
);
107 // endEditCP(_image);