SOL9 Sample: BlurredImageTexture

SOL9 2.0 Samples

1 Screenshot


2 Source code

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


#include <sol/Stdio.h>
#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>
#include <sol/opengl/OpenGLGeometry.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          blurredImage;
    StringT<char>    imageFile;
    int              imageLoadingFlag;

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

        OpenCVImageInfo cvImageInfo;
        cvImageInfo.getImageInfo(blurredImage, 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->begin(GL_QUADS);
      texture->coord(0.0, 0.0); 
      gc->vertex(-1.0,  1.0, 1.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, 1.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();
      texture = new OpenGLTexture2D();
      
      gc->enable(GL_DEPTH_TEST);
      gc->enable(GL_TEXTURE_2D);
      gc->rotate(20.0, 0.0, 0.0, 1.0);

      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 blur(cv::Mat& originalImage)
    {
      int ksize = 13;
      int sigma = 10;
      ksize = (ksize/2)*2 + 1;
      blurredImage = cv::Mat::zeros(originalImage.size(), 
                                originalImage.type() );
      //Blur operation is applied to the original image.
      cv::GaussianBlur(originalImage, blurredImage, cv::Size(ksize, ksize), 
            (double)sigma, //sigmaX, 
            (double)sigma); //sigmaY 
    }

  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);
          blur(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\\flower.png"; 
    
    Args ar;
    ar.set(XmNimageFileName, filename);
    ar.set(XmNimageLoadingFlag, cv::IMREAD_COLOR);
    view = new SimpleView(this, "", ar);

    char title[MAX_PATH];
    sprintf(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,  600);
    args.set(XmNheight, 400);
    
    MainView view(applet, name, args);
    view.realize();
    applet.run();
    
  } catch (SOL::Exception& ex) {
    caught(ex);
  }
  //return 0;
}


Last modified: 17 Sep. 2017

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