diff options
author | donbright <hugh.m.bright@gmail.com> | 2013-03-05 23:47:14 (GMT) |
---|---|---|
committer | donbright <hugh.m.bright@gmail.com> | 2013-03-05 23:47:14 (GMT) |
commit | 42f21c3a0850083d245aa3ac346a53e876f0679e (patch) | |
tree | facf41750e0fe27cc4cdaf352c9c8e687011d103 /src/imageutils-lodepng.cc | |
parent | 422c668dcb538f181683ae51305bf8d3404f48d6 (diff) | |
parent | 4734172c3a16cc06b09e4d2131aa8e380bd0f226 (diff) |
Merge pull request #288 from openscad/issue11_2
Issue11 2
Diffstat (limited to 'src/imageutils-lodepng.cc')
-rw-r--r-- | src/imageutils-lodepng.cc | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/imageutils-lodepng.cc b/src/imageutils-lodepng.cc new file mode 100644 index 0000000..cd104d6 --- /dev/null +++ b/src/imageutils-lodepng.cc @@ -0,0 +1,17 @@ +#include "imageutils.h" +#include "lodepng.h" +#include <stdio.h> +#include <stdlib.h> +#include <vector> +#include <iterator> +#include <algorithm> + +bool write_png(std::ostream &output, unsigned char *pixels, int width, int height) +{ + std::vector<unsigned char> dataout; + unsigned err = lodepng::encode(dataout, pixels, width, height, LCT_RGBA, 8); + if ( err ) return false; + output.write( reinterpret_cast<const char *>(&dataout[0]), dataout.size()); + if ( output.bad() ) std::cerr << "Error writing to ostream\n"; + return output.good(); +} |