Ajout de l'ensemble du workspace.
[GPU.git] / WCudaMSE / Student_OMP_Image / src / cpp / core / 01_Rippling / a_image / RipplingImage.cpp
diff --git a/WCudaMSE/Student_OMP_Image/src/cpp/core/01_Rippling/a_image/RipplingImage.cpp b/WCudaMSE/Student_OMP_Image/src/cpp/core/01_Rippling/a_image/RipplingImage.cpp
new file mode 100755 (executable)
index 0000000..4afae0f
--- /dev/null
@@ -0,0 +1,104 @@
+#include <iostream>\r
+#include <assert.h>\r
+#include <omp.h>\r
+#include <math.h>\r
+\r
+#include "MathTools.h"\r
+#include "RipplingImage.h"\r
+#include "StringTools.h"\r
+#include "OmpTools.h"\r
+\r
+using std::cout;\r
+using std::endl;\r
+using std::string;\r
+\r
+/*----------------------------------------------------------------------*\\r
+ |*                    Declaration                                     *|\r
+ \*---------------------------------------------------------------------*/\r
+\r
+/*--------------------------------------*\\r
+ |*            Public                  *|\r
+ \*-------------------------------------*/\r
+\r
+/*--------------------------------------*\\r
+ |*            Private                 *|\r
+ \*-------------------------------------*/\r
+\r
+/*----------------------------------------------------------------------*\\r
+ |*                    Implementation                                  *|\r
+ \*---------------------------------------------------------------------*/\r
+\r
+/*--------------------------------------*\\r
+ |*            Public                  *|\r
+ \*-------------------------------------*/\r
+\r
+RipplingImage::RipplingImage(unsigned int w, unsigned int h, float dt) :\r
+       ImageMOOs_A(w, h)\r
+    {\r
+    assert(w==h); // Image carrer\r
+\r
+    this->ptrRipplingMOO=new RipplingMOO(w,h,dt);\r
+    }\r
+\r
+RipplingImage::~RipplingImage(void)\r
+    {\r
+    delete ptrRipplingMOO;\r
+    }\r
+\r
+/*--------------------------------------*\\r
+ |*            Override                *|\r
+ \*-------------------------------------*/\r
+\r
+/**\r
+ * Override\r
+ * call periodicly by the api\r
+ */\r
+void RipplingImage::fillImageGL(uchar4* ptrTabPixels, int w, int h)\r
+    {\r
+    ptrRipplingMOO->process(ptrTabPixels,w,h);\r
+    }\r
+\r
+/**\r
+ * Override\r
+ * call periodicly by the api\r
+ */\r
+void RipplingImage::animationStep(bool& isNeedUpdateView)\r
+    {\r
+    ptrRipplingMOO->animationStep();\r
+    }\r
+\r
+/**\r
+ * Override\r
+ * call periodicly by the api\r
+ */\r
+void RipplingImage::paintPrimitives(Graphic2Ds& graphic2D)\r
+    {\r
+    const Font_A* ptrFont = graphic2D.getFont(TIMES_ROMAN_24);\r
+\r
+    float r = 1;\r
+    float g = 0;\r
+    float b = 0;\r
+    graphic2D.setColorRGB(r, g, b);\r
+\r
+    // Top\r
+       {\r
+       float t=ptrRipplingMOO->getT();\r
+\r
+       string message = "It's up to you!  t= " + StringTools::toString(t);\r
+       graphic2D.drawTitleTop(message, ptrFont);\r
+       }\r
+\r
+    // Bottom\r
+       {\r
+       graphic2D.drawTitleBottom("Rippling OMP", ptrFont);\r
+       }\r
+    }\r
+\r
+/*--------------------------------------*\\r
+ |*            Private                 *|\r
+ \*-------------------------------------*/\r
+\r
+\r
+/*----------------------------------------------------------------------*\\r
+ |*                    End                                             *|\r
+ \*---------------------------------------------------------------------*/\r