SOL9 Sample: DenoisedImageTexture

SOL9 2.0 Samples

1 Screenshot


2 Source code

/*
 * DenoisedImageTexture.cpp 
 * Copyright (c) 2015 Antillia.com TOSHIYUKI ARAI. ALL RIGHTS RESERVED. 
 */


#include <sol/StringT.h>
#include <sol/opengl/OpenGLMainView.h>
#include <sol/opengl/OpenGLView.h>
#include <sol/opengl/OpenGLGC.h>
#include <sol/opengl/OpenGLTexture2D.h>
#include <sol/opencv/OpenCVImageInfo.h>
#include <sol/opencv/OpenCVImageFileReader.h>

namespace SOL {

class MainView :public OpenGLMainView {
public:

private:
  //Inner class starts.
  class SimpleView: public OpenGLView {
  private:
    SmartPtr<OpenGLGC>         gc;
    SmartPtr<OpenGLTexture2D>  texture;
    bool             textured; 
    cv::Mat          denoisedImage;
    StringT<char>    imageFile;
    int              imageLoadingFlag;

  private:
    void imageToTexture()
    {
      try {
        int width  = 0;
        int height = 0;
        OpenGLImageInfo imageInfo;

        OpenCVImageInfo cvImageInfo;
        cvImageInfo.getImageInfo(denoisedImage, imageInfo);
        texture->image(imageInfo);

      } catch (SOL::Exception& ex) {
        caught(ex);
      }
    }

  public:
    virtual void display()
    {
      if (gc == NULL) {
        return;
      }
      
      if (textured == false) {
        imageToTexture();
        textured = true;
      }
      
      gc->clearColor(1.0, 1.0, 1.0, 1.0);
      gc->clear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
      gc->rotate(30.0, 0.0, 0.0, 1.0);

      gc->begin(GL_QUADS);
      texture->coord(0.0, 0.0);
      gc->vertex(-1.0,  1.0, 0.0);

      texture->coord(1.0, 0.0);
      gc->vertex( 1.0,  1.0, 0.0);

      texture->coord(1.0, 1.0);
      gc->vertex( 1.0, -1.0, 0.0);

      texture->coord(0.0, 1.0);
      gc->vertex(-1.0, -1.0, 0.0);
      gc->end();

    }
 
    virtual void resize(int w, int h)
    {
      if (w == 0 || h == 0) {
        return;
      }
      if (gc) {
      gc->matrixMode(GL_PROJECTION);
      gc->loadIdentity();
      gc->ortho(-1.25, 1.25, -1.25, 1.25, 1., 20.);

      gc->matrixMode(GL_MODELVIEW);
      gc->loadIdentity();
      gc->lookAt(0., 0., 10., 0., 0., 0., 0., 1., 0.);
      }
    }

    virtual void initialize()
    {
      gc = new OpenGLGC();
      
      gc->enable(GL_DEPTH_TEST);
      gc->enable(GL_TEXTURE_2D);
      gc->rotate(30.0, 0.0, 0.0, 1.0);

      texture = new OpenGLTexture2D();
      
      texture->bind();

      texture->parameter(GL_TEXTURE_MIN_FILTER, GL_LINEAR);
      texture->parameter(GL_TEXTURE_MAG_FILTER, GL_LINEAR);
      texture->env(GL_TEXTURE_ENV_MODE, GL_MODULATE); 
      
    }

    void denoise(cv::Mat& originalImage)
    {
      denoisedImage = cv::Mat::zeros(originalImage.size(), 
                                originalImage.type() );
      
      int hParameter         = 27;
      int templateWindowSize = 15;
      int searchWindowSize   = 13;

      fastNlMeansDenoising(originalImage, denoisedImage, (float)hParameter, 
           templateWindowSize, searchWindowSize);

    }

  public:
    SimpleView(OpenGLMainView* parent, const char* name, Args& args)
    :OpenGLView(parent, name, args)
    {
      try {
      textured = false;
      const char* filename = (const char*)args.get(XmNimageFileName);
      int   imageLoadingFlag = args.get(XmNimageLoadingFlag);

      if (filename) {
        OpenCVImageFileReader reader;
        cv::Mat image = reader.load(filename, imageLoadingFlag);
        denoise(image);
      }
      } catch (SOL::Exception& ex) {
        caught(ex);
      }
    } 

    ~SimpleView()
    {
    }

  };
  //Inner class ends.
    
private:
  SmartPtr<SimpleView>  view;

  void resize(int w, int h)
  {
    if (view) {
      view -> reshape(0, 0, w, h);
      view -> postResizeRequest(w, h);
    }
  }
  
public:
  MainView(Application& applet, const char* name, Args& args)
  :OpenGLMainView(applet, name,  args)
  {
    const char* filename = "..\\..\\opencv_app\\images\\MeshedNioh.png"; 

    Args ar;
    ar.set(XmNimageFileName, filename);
    ar.set(XmNimageLoadingFlag, cv::IMREAD_COLOR);
    view = new SimpleView(this, "", ar);

    char title[MAX_PATH];
    sprintf_s(title, CountOf(title), "%s - %s", filename, name);
    setText(title);
  }

  ~MainView()
  {
  }
};
}

//
void Main(int argc, char** argv) 
{
  try {
    const char*  name = appName(argv[0]);
    Application applet(name, argc, argv);

    Args args;
    args.set(XmNx,     40);
    args.set(XmNy,     40);
    args.set(XmNwidth, 500);
    args.set(XmNheight,500);
    
    MainView view(applet, name, args);
    view.realize();
    applet.run();
    
  } catch (SOL::Exception& ex) {
    caught(ex);
  }
}


Last modified: 17 Sep. 2017

Copyright (c) 2017 Antillia.com ALL RIGHTS RESERVED.