00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00027
00028 #include <mln/core/image/image2d.hh>
00029 #include <mln/value/rgb8.hh>
00030 #include <mln/data/fill.hh>
00031 #include <mln/data/paste.hh>
00032 #include <mln/core/routine/duplicate.hh>
00033 #include <mln/literal/colors.hh>
00034 #include <mln/opt/at.hh>
00035
00036 #include <tests/data.hh>
00037 #include <doc/tools/sample_utils.hh>
00038
00039 int main()
00040 {
00041 using namespace mln;
00042
00043
00044 image2d<value::rgb8> ima(40, 40);
00045
00046
00047
00048 data::fill(ima, literal::red);
00049
00050
00051
00052 for (def::coord row = 20; row < 30; ++row)
00053 for (def::coord col = 20; col < 30; ++col)
00054 ima(point2d(row, col)) = literal::blue;
00055
00056
00057
00058 for (def::coord row = 20; row < 30; ++row)
00059 for (def::coord col = 20; col < 30; ++col)
00060 opt::at(ima, row, col) = literal::blue;
00061
00062 doc::ppmsave(ima, "tuto3_rw_image");
00063
00064 image2d<value::rgb8> ima2 = duplicate(ima);
00065
00066
00067 image2d<value::rgb8> lena;
00068 io::ppm::load(lena, MLN_IMG_DIR "/small.ppm");
00069
00070
00071
00072 data::fill(ima, lena);
00073
00074 doc::ppmsave(ima, "tuto3_rw_image");
00075
00076 ima = ima2;
00077
00078 data::paste(ima, lena);
00079
00080 doc::ppmsave(lena, "tuto3_rw_image");
00081 }