qvolray

changeset 26:f4cc61b5a3eb

foo
author John Tsiombikas <nuclear@member.fsf.org>
date Sat, 14 Apr 2012 04:59:14 +0300 (2012-04-14)
parents 63bc059778d0
children 011ac823600c
files sdr/volray.p.glsl src/ui.cc src/ui.h src/ui_maingl.h
diffstat 4 files changed, 50 insertions(+), 32 deletions(-) [+]
line diff
     1.1 --- a/sdr/volray.p.glsl	Sat Apr 14 01:13:43 2012 +0300
     1.2 +++ b/sdr/volray.p.glsl	Sat Apr 14 04:59:14 2012 +0300
     1.3 @@ -21,7 +21,7 @@
     1.4  
     1.5  vec3 sky(Ray ray);
     1.6  vec3 ray_march(Ray ray, float t0, float t1);
     1.7 -vec3 shade(Ray ray, vec3 pos, vec3 norm);
     1.8 +vec3 shade(Ray ray, vec3 pos, vec3 norm, vec3 ldir);
     1.9  Ray get_primary_ray();
    1.10  ISect intersect_aabb(Ray ray, AABBox aabb);
    1.11  ISect intersect_sphere(Ray ray, float rad);
    1.12 @@ -78,6 +78,7 @@
    1.13  	float energy = 1.0;
    1.14  	float t = t0;
    1.15  	vec3 col = vec3(0.0, 0.0, 0.0);
    1.16 +	const vec3 ldir = normalize(vec3(-1, 1, -4));
    1.17  
    1.18  
    1.19  	while(t < t1) {
    1.20 @@ -90,7 +91,7 @@
    1.21  		float energy_drop = exp(val * -ray_step);	// * scatter_coeff ?
    1.22  		energy *= energy_drop;
    1.23  
    1.24 -		vec3 irrad = shade(ray, pos, normalize(norm));
    1.25 +		vec3 irrad = shade(ray, pos, normalize(norm), ldir);
    1.26  
    1.27  		col += (1.0 - energy_drop) * energy * irrad;
    1.28  		if(energy < 0.001) {
    1.29 @@ -101,11 +102,10 @@
    1.30  	return col;
    1.31  }
    1.32  
    1.33 -vec3 shade(Ray ray, vec3 pos, vec3 norm)
    1.34 +vec3 shade(Ray ray, vec3 pos, vec3 norm, vec3 ldir)
    1.35  {
    1.36 -	vec3 ldir = -normalize(ray.dir);
    1.37 -	vec3 vdir = ldir;
    1.38 -	vec3 hdir = ldir;//normalize(ldir + vdir);
    1.39 +	vec3 vdir = -normalize(ray.dir);
    1.40 +	vec3 hdir = normalize(ldir + vdir);
    1.41  
    1.42  	float ndotl = abs(dot(ldir, norm));
    1.43  	float ndoth = abs(dot(hdir, norm));
     2.1 --- a/src/ui.cc	Sat Apr 14 01:13:43 2012 +0300
     2.2 +++ b/src/ui.cc	Sat Apr 14 04:59:14 2012 +0300
     2.3 @@ -1,18 +1,22 @@
     2.4  #include <stdio.h>
     2.5  #include <stdlib.h>
     2.6 +#include <vector>
     2.7  #include <QtGui>
     2.8  #include "ui.h"
     2.9  
    2.10 -static GLView *glview;
    2.11  static Volume *volume;
    2.12  
    2.13 +static GLView *maingl;
    2.14 +static std::vector<GLView*> glviews;
    2.15 +
    2.16  MainWindow::MainWindow()
    2.17  {
    2.18  	setWindowTitle("Volume Renderer");
    2.19  
    2.20  	// OpenGL view
    2.21 -	glview = new GLView;
    2.22 -	setCentralWidget(glview);
    2.23 +	maingl = new GLView;
    2.24 +	glviews.push_back(maingl);
    2.25 +	setCentralWidget(maingl);
    2.26  
    2.27  	// side-window
    2.28  	sidewin = new SideWindow;
    2.29 @@ -64,6 +68,9 @@
    2.30  {
    2.31  	QGroupBox *groupbox = new QGroupBox("Volume slice");
    2.32  	{
    2.33 +		GLView *slice_view = new GLView;
    2.34 +		glviews.push_back(slice_view);
    2.35 +
    2.36  		QCheckBox *chk_clip = new QCheckBox("clip");
    2.37  		chk_clip->setChecked(false);
    2.38  		connect(chk_clip, SIGNAL(stateChanged(int)), this, SLOT(clip_change(int)));
    2.39 @@ -74,6 +81,7 @@
    2.40  		connect(zslider, SIGNAL(valueChanged(int)), this, SLOT(zslider_change(int)));
    2.41  
    2.42  		QVBoxLayout *vbox = new QVBoxLayout;
    2.43 +		vbox->addWidget(slice_view);
    2.44  		vbox->addWidget(chk_clip);
    2.45  		vbox->addWidget(zslider);
    2.46  
    2.47 @@ -102,7 +110,7 @@
    2.48  
    2.49  void post_redisplay()
    2.50  {
    2.51 -	glview->updateGL();
    2.52 +	maingl->updateGL();
    2.53  }
    2.54  
    2.55  
     3.1 --- a/src/ui.h	Sat Apr 14 01:13:43 2012 +0300
     3.2 +++ b/src/ui.h	Sat Apr 14 04:59:14 2012 +0300
     3.3 @@ -3,15 +3,16 @@
     3.4  
     3.5  #include <QMainWindow>
     3.6  #include <QDockWidget>
     3.7 -#include <QGLWidget>
     3.8  #include "volray.h"
     3.9  
    3.10 -class GLView;
    3.11  class SideWindow;
    3.12  
    3.13 +// This is the main application window (duh)
    3.14  class MainWindow : public QMainWindow {
    3.15 +private:
    3.16  	Q_OBJECT
    3.17 -private:
    3.18 +
    3.19 +	MainGLView *maingl;
    3.20  	SideWindow *sidewin;
    3.21  
    3.22  private slots:
    3.23 @@ -21,8 +22,15 @@
    3.24  	MainWindow();
    3.25  };
    3.26  
    3.27 +/* This is the detachable window with the volume slice view
    3.28 + * transfer function, etc
    3.29 + */
    3.30  class SideWindow : public QDockWidget {
    3.31 +private:
    3.32  	Q_OBJECT
    3.33 +
    3.34 +	SliceGLView *slice_view;
    3.35 +
    3.36  private slots:
    3.37  	void zslider_change(int val);
    3.38  	void clip_change(int checked);
    3.39 @@ -31,25 +39,7 @@
    3.40  	SideWindow();
    3.41  };
    3.42  
    3.43 -class GLView : public QGLWidget {
    3.44 -	Q_OBJECT
    3.45 -
    3.46 -protected:
    3.47 -	void initializeGL();
    3.48 -	void resizeGL(int xsz, int ysz);
    3.49 -	void paintGL();
    3.50 -
    3.51 -	void mousePressEvent(QMouseEvent *ev);
    3.52 -	void mouseReleaseEvent(QMouseEvent *ev);
    3.53 -	void mouseMoveEvent(QMouseEvent *ev);
    3.54 -
    3.55 -public:
    3.56 -	GLView(QWidget *parent = 0);
    3.57 -
    3.58 -	QSize minimumSizeHint() const;
    3.59 -	QSize sizeHint() const;
    3.60 -};
    3.61 -
    3.62 +// call to force a redisplay on all GL views
    3.63  void post_redisplay();
    3.64  
    3.65  
     4.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     4.2 +++ b/src/ui_maingl.h	Sat Apr 14 04:59:14 2012 +0300
     4.3 @@ -0,0 +1,20 @@
     4.4 +#include <QGLWidget>
     4.5 +
     4.6 +class MainGLView : public QGLWidget {
     4.7 +	Q_OBJECT
     4.8 +
     4.9 +protected:
    4.10 +	void initializeGL();
    4.11 +	void resizeGL(int xsz, int ysz);
    4.12 +	void paintGL();
    4.13 +
    4.14 +	void mousePressEvent(QMouseEvent *ev);
    4.15 +	void mouseReleaseEvent(QMouseEvent *ev);
    4.16 +	void mouseMoveEvent(QMouseEvent *ev);
    4.17 +
    4.18 +public:
    4.19 +	MainGLView();
    4.20 +
    4.21 +	QSize minimumSizeHint() const;
    4.22 +	QSize sizeHint() const;
    4.23 +};