diff options
| author | Vicnet <vo.publique@gmail.com> | 2013-09-13 12:52:22 (GMT) | 
|---|---|---|
| committer | Vicnet <vo.publique@gmail.com> | 2013-09-13 12:52:22 (GMT) | 
| commit | 7b1e423f8214bb42c7668505066507e4d9c7091a (patch) | |
| tree | 19e9174a312f35af416f9fa4cd58f31876052e79 /src | |
| parent | f6343949ebc6936880a6cd62bfe3574541a11fb5 (diff) | |
| parent | ead8749e99238c18a3d7bb903f98bb7bca6a7685 (diff) | |
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'src')
| -rw-r--r-- | src/CGALEvaluator.cc | 9 | ||||
| -rw-r--r-- | src/Camera.h | 13 | ||||
| -rw-r--r-- | src/GLView.cc | 2 | ||||
| -rw-r--r-- | src/PlatformUtils.cc | 43 | ||||
| -rw-r--r-- | src/PlatformUtils.h | 2 | ||||
| -rw-r--r-- | src/QGLView.cc | 11 | ||||
| -rw-r--r-- | src/export.h | 1 | ||||
| -rw-r--r-- | src/export_png.cc | 47 | ||||
| -rw-r--r-- | src/imageutils-lodepng.cc | 7 | ||||
| -rw-r--r-- | src/mainwin.cc | 32 | ||||
| -rw-r--r-- | src/openscad.cc | 33 | 
11 files changed, 148 insertions, 52 deletions
| diff --git a/src/CGALEvaluator.cc b/src/CGALEvaluator.cc index adaec4a..ec01315 100644 --- a/src/CGALEvaluator.cc +++ b/src/CGALEvaluator.cc @@ -216,7 +216,7 @@ CGAL_Nef_polyhedron CGALEvaluator::applyResize(const CgaladvNode &node)  	bbox_size.push_back( bb.ymax()-bb.ymin() );  	bbox_size.push_back( bb.zmax()-bb.zmin() );  	int newsizemax_index = 0; -	for (int i=0;i<3;i++) { +	for (int i=0;i<N.dim;i++) {  		if (node.newsize[i]) {  			if (bbox_size[i]==NT3(0)) {  				PRINT("WARNING: Resize in direction normal to flat object is not implemented"); @@ -229,8 +229,11 @@ CGAL_Nef_polyhedron CGALEvaluator::applyResize(const CgaladvNode &node)  				newsizemax_index = i;  		}  	} -	NT3 autoscale = NT3( node.newsize[ newsizemax_index ] ) / bbox_size[ newsizemax_index ]; -	for (int i=0;i<3;i++) { + +	NT3 autoscale = NT3( 1 ); +	if ( node.newsize[ newsizemax_index ] != 0 ) +		autoscale = NT3( node.newsize[ newsizemax_index ] ) / bbox_size[ newsizemax_index ]; +	for (int i=0;i<N.dim;i++) {  		if (node.autosize[i] && node.newsize[i]==0)  			scale[i] = autoscale;  	} diff --git a/src/Camera.h b/src/Camera.h index dfc71f8..6079672 100644 --- a/src/Camera.h +++ b/src/Camera.h @@ -47,7 +47,8 @@ public:  		projection = Camera::PERSPECTIVE;  	} -	void setup( std::vector<double> params ) { +	void setup( std::vector<double> params ) +	{  		if ( params.size() == 7 ) {  			type = Camera::GIMBAL;  			object_trans << params[0], params[1], params[2]; @@ -62,6 +63,16 @@ public:  		}  	} +	void gimbalDefaultTranslate() +	{	// match the GUI viewport numbers (historical reasons) +		object_trans.x() *= -1; +		object_trans.y() *= -1; +		object_trans.z() *= -1; +		object_rot.x() = fmodf(360 - object_rot.x() + 90, 360 ); +		object_rot.y() = fmodf(360 - object_rot.y(), 360); +		object_rot.z() = fmodf(360 - object_rot.z(), 360); +	} +  	// Vectorcam  	Eigen::Vector3d eye;  	Eigen::Vector3d center; // (aka 'target') diff --git a/src/GLView.cc b/src/GLView.cc index 822a246..1cfe82c 100644 --- a/src/GLView.cc +++ b/src/GLView.cc @@ -460,7 +460,7 @@ void GLView::showAxes()  void GLView::showCrosshairs()  { -	// FIXME: this might not work with Vector camera +  // FIXME: this might not work with Vector camera    // FIXME: Crosshairs and axes are lighted, this doesn't make sense and causes them    // to change color based on view orientation.    glLineWidth(3); diff --git a/src/PlatformUtils.cc b/src/PlatformUtils.cc index 5dd007d..ccc2bc0 100644 --- a/src/PlatformUtils.cc +++ b/src/PlatformUtils.cc @@ -38,3 +38,46 @@ std::string PlatformUtils::libraryPath()  	}  	return boosty::stringy( path );  } + +#include "version_check.h" +#define STRINGIFY(x) #x +#define TOSTRING(x) STRINGIFY(x) +std::string PlatformUtils::info() +{ +	std::stringstream s; + +#if defined(__GNUG__) && !defined(__clang__) +	std::string compiler_info( "GCC " + std::string(TOSTRING(__VERSION__)) ); +#elif defined(_MSC_VER) +	std::string compiler_info( "MSVC " + std::string(TOSTRING(_MSC_FULL_VER)) ); +#elif defined(__clang__) +	std::string compiler_info( "Clang " + std::string(TOSTRING(__clang_version__)) ); +#else +	std::string compiler_info( "unknown compiler" ); +#endif + +#if defined( __MINGW64__ ) +	std::string mingwstatus("MingW64"); +#elif defined( __MINGW32__ ) +	std::string mingwstatus("MingW32"); +#else +	std::string mingwstatus("No"); +#endif + +#ifndef OPENCSG_VERSION_STRING +#define OPENCSG_VERSION_STRING "unknown, <1.3.2" +#endif + +	s << "OpenSCAD Version: " << TOSTRING(OPENSCAD_VERSION) +          << "\nCompiler: " << compiler_info +	  << "\nCompile date: " << __DATE__ +	  << "\nBoost version: " << BOOST_LIB_VERSION +	  << "\nEigen version: " << EIGEN_WORLD_VERSION << "." << EIGEN_MAJOR_VERSION << "." << EIGEN_MINOR_VERSION +	  << "\nCGAL version: " << TOSTRING(CGAL_VERSION) +	  << "\nOpenCSG version: " << OPENCSG_VERSION_STRING +	  << "\nQt version: " << qVersion() +	  << "\nMingW build: " << mingwstatus; + +	return s.str(); +} + diff --git a/src/PlatformUtils.h b/src/PlatformUtils.h index 089b3ca..18dd5fa 100644 --- a/src/PlatformUtils.h +++ b/src/PlatformUtils.h @@ -8,7 +8,7 @@ namespace PlatformUtils {  	std::string documentsPath();  	std::string libraryPath();  	bool createLibraryPath(); - +	std::string info();  }  #endif diff --git a/src/QGLView.cc b/src/QGLView.cc index b23ba8e..8aaeaf2 100644 --- a/src/QGLView.cc +++ b/src/QGLView.cc @@ -147,13 +147,18 @@ void QGLView::resizeGL(int w, int h)  void QGLView::paintGL()  { -	GLView::gimbalCamPaintGL(); +  GLView::gimbalCamPaintGL();    if (statusLabel) {      QString msg; + +    Camera nc( cam ); +    nc.gimbalDefaultTranslate();      msg.sprintf("Viewport: translate = [ %.2f %.2f %.2f ], rotate = [ %.2f %.2f %.2f ], distance = %.2f", -      -cam.object_trans.x(), -cam.object_trans.y(), -cam.object_trans.z(), -      fmodf(360 - cam.object_rot.x() + 90, 360), fmodf(360 - cam.object_rot.y(), 360), fmodf(360 - cam.object_rot.z(), 360), cam.viewer_distance); +      nc.object_trans.x(), nc.object_trans.y(), nc.object_trans.z(), +      nc.object_rot.x(), nc.object_rot.y(), nc.object_rot.z(), +      nc.viewer_distance ); +      statusLabel->setText(msg);    } diff --git a/src/export.h b/src/export.h index a565561..5dae7e0 100644 --- a/src/export.h +++ b/src/export.h @@ -12,6 +12,7 @@ void export_off(CGAL_Nef_polyhedron *root_N, std::ostream &output);  void export_dxf(CGAL_Nef_polyhedron *root_N, std::ostream &output);  void export_png_with_cgal(CGAL_Nef_polyhedron *root_N, Camera &c, std::ostream &output);  void export_png_with_opencsg(Tree &tree, Camera &c, std::ostream &output); +void export_png_with_throwntogether(Tree &tree, Camera &c, std::ostream &output);  #endif diff --git a/src/export_png.cc b/src/export_png.cc index c6c191c..744d681 100644 --- a/src/export_png.cc +++ b/src/export_png.cc @@ -41,26 +41,25 @@ void export_png_with_cgal(CGAL_Nef_polyhedron *root_N, Camera &cam, std::ostream  		cam.eye = cam.center - radius*2*cameradir;  	} -	//std::cerr << center << "\n"; -	//std::cerr << radius << "\n"; -  	glview->setCamera( cam );  	glview->setRenderer(&cgalRenderer);  	glview->paintGL();  	glview->save(output);  } +enum Previewer { OPENCSG, THROWN } previewer; +  #ifdef ENABLE_OPENCSG  #include "OpenCSGRenderer.h"  #include <opencsg.h>  #endif +#include "ThrownTogetherRenderer.h" -void export_png_with_opencsg(Tree &tree, Camera &cam, std::ostream &output) +void export_png_preview_common( Tree &tree, Camera &cam, std::ostream &output, Previewer previewer = OPENCSG )  { -#ifdef ENABLE_OPENCSG -  CsgInfo csgInfo = CsgInfo(); -  if ( !csgInfo.compile_chains( tree ) ) { -		fprintf(stderr,"Couldn't initialize OpenCSG chains\n"); +	CsgInfo csgInfo = CsgInfo(); +	if ( !csgInfo.compile_chains( tree ) ) { +		fprintf(stderr,"Couldn't initialize CSG chains\n");  		return;  	} @@ -71,7 +70,16 @@ void export_png_with_opencsg(Tree &tree, Camera &cam, std::ostream &output)  		return;  	} -	OpenCSGRenderer opencsgRenderer(csgInfo.root_chain, csgInfo.highlights_chain, csgInfo.background_chain, csgInfo.glview->shaderinfo); +	Renderer *renderer; +	if ( previewer == OPENCSG ) { +#ifdef ENABLE_OPENCSG +		OpenCSGRenderer openCSGRenderer(csgInfo.root_chain, csgInfo.highlights_chain, csgInfo.background_chain, csgInfo.glview->shaderinfo); +		renderer = &openCSGRenderer; +#endif +	} else { +		ThrownTogetherRenderer thrownTogetherRenderer( csgInfo.root_chain, csgInfo.highlights_chain, csgInfo.background_chain ); +		renderer = &thrownTogetherRenderer; +	}  	if (cam.type == Camera::NONE) {  		cam.type = Camera::VECTOR; @@ -86,15 +94,28 @@ void export_png_with_opencsg(Tree &tree, Camera &cam, std::ostream &output)  	}  	csgInfo.glview->setCamera( cam ); -	csgInfo.glview->setRenderer(&opencsgRenderer); -	OpenCSG::setContext(0); -	OpenCSG::setOption(OpenCSG::OffscreenSetting, OpenCSG::FrameBufferObject); +	csgInfo.glview->setRenderer( renderer ); +#ifdef ENABLE_OPENCSG +	OpenCSG::setContext( 0 ); +	OpenCSG::setOption( OpenCSG::OffscreenSetting, OpenCSG::FrameBufferObject ); +#endif  	csgInfo.glview->paintGL(); -	csgInfo.glview->save(output); +	csgInfo.glview->save( output ); +} + +void export_png_with_opencsg(Tree &tree, Camera &cam, std::ostream &output) +{ +#ifdef ENABLE_OPENCSG +	export_png_preview_common( tree, cam, output, OPENCSG );  #else  	fprintf(stderr,"This openscad was built without OpenCSG support\n");  #endif  } +void export_png_with_throwntogether(Tree &tree, Camera &cam, std::ostream &output) +{ +	export_png_preview_common( tree, cam, output, THROWN ); +} +  #endif // ENABLE_CGAL diff --git a/src/imageutils-lodepng.cc b/src/imageutils-lodepng.cc index cd104d6..a71a017 100644 --- a/src/imageutils-lodepng.cc +++ b/src/imageutils-lodepng.cc @@ -9,7 +9,12 @@  bool write_png(std::ostream &output, unsigned char *pixels, int width, int height)  {  	std::vector<unsigned char> dataout; -	unsigned err = lodepng::encode(dataout, pixels, width, height, LCT_RGBA, 8); +	lodepng::State state; +	state.encoder.auto_convert = LAC_NO; +	// some png renderers have different interpretations of alpha, so don't use it +	state.info_png.color.colortype = LCT_RGB; +	state.info_png.color.bitdepth = 8; +	unsigned err = lodepng::encode(dataout, pixels, width, height, state);  	if ( err ) return false;  	output.write( reinterpret_cast<const char *>(&dataout[0]), dataout.size());  	if ( output.bad() ) std::cerr << "Error writing to ostream\n"; diff --git a/src/mainwin.cc b/src/mainwin.cc index 3d50d6f..783772c 100644 --- a/src/mainwin.cc +++ b/src/mainwin.cc @@ -101,10 +101,6 @@  #endif // ENABLE_CGAL -#ifndef OPENCSG_VERSION_STRING -#define OPENCSG_VERSION_STRING "unknown, <1.3.2" -#endif -  #include "boosty.h"  extern QString examplesdir; @@ -1828,34 +1824,16 @@ MainWindow::helpManual()  	QDesktopServices::openUrl(QUrl("http://www.openscad.org/documentation.html"));  } -#define STRINGIFY(x) #x -#define TOSTRING(x) STRINGIFY(x)  void MainWindow::helpLibrary()  { -	QString libinfo; -	libinfo.sprintf("Boost version: %s\n" -									"Eigen version: %d.%d.%d\n" -									"CGAL version: %s\n" -									"OpenCSG version: %s\n" -									"Qt version: %s\n\n", -									BOOST_LIB_VERSION, -									EIGEN_WORLD_VERSION, EIGEN_MAJOR_VERSION, EIGEN_MINOR_VERSION, -									TOSTRING(CGAL_VERSION), -									OPENCSG_VERSION_STRING, -									qVersion()); - -#if defined( __MINGW64__ ) -	libinfo += QString("Compiled for MingW64\n\n"); -#elif defined( __MINGW32__ ) -	libinfo += QString("Compiled for MingW32\n\n"); -#endif - +	QString info( PlatformUtils::info().c_str() ); +	info += QString( qglview->getRendererInfo().c_str() );  	if (!this->openglbox) { -    this->openglbox = new QMessageBox(QMessageBox::Information,  -                                      "OpenGL Info", "OpenSCAD Detailed Library Info                  ", +		this->openglbox = new QMessageBox(QMessageBox::Information, +                                      "OpenGL Info", "OpenSCAD Detailed Library and Build Information",                                        QMessageBox::Ok, this);  	} -  this->openglbox->setDetailedText(libinfo + QString(qglview->getRendererInfo().c_str())); +	this->openglbox->setDetailedText( info );  	this->openglbox->show();  } diff --git a/src/openscad.cc b/src/openscad.cc index e657cb0..fb5ee44 100644 --- a/src/openscad.cc +++ b/src/openscad.cc @@ -37,6 +37,7 @@  #include "handle_dep.h"  #include "parsersettings.h"  #include "rendersettings.h" +#include "PlatformUtils.h"  #include <string>  #include <vector> @@ -50,6 +51,7 @@  #include "csgterm.h"  #include "CSGTermEvaluator.h" +#include "CsgInfo.h"  #include <QApplication>  #include <QString> @@ -82,12 +84,13 @@ static void help(const char *progname)  {  	int tab = int(strlen(progname))+8;  	fprintf(stderr,"Usage: %s [ -o output_file [ -d deps_file ] ]\\\n" -	        "%*s[ -m make_command ] [ -D var=val [..] ] [ --render ] \\\n" +	        "%*s[ -m make_command ] [ -D var=val [..] ] \\\n"  	        "%*s[ --camera=translatex,y,z,rotx,y,z,dist | \\\n"  	        "%*s  --camera=eyex,y,z,centerx,y,z ] \\\n"  	        "%*s[ --imgsize=width,height ] [ --projection=(o)rtho|(p)ersp] \\\n" +	        "%*s[ --render | --preview[=throwntogether] ] \\\n"  	        "%*sfilename\n", -					progname, tab, "", tab, "", tab, "", tab, "", tab, ""); +					progname, tab, "", tab, "", tab, "", tab, "", tab, "", tab, "");  	exit(1);  } @@ -99,6 +102,23 @@ static void version()  	exit(1);  } +static void info() +{ +	std::cout << PlatformUtils::info() << "\n\n"; + +	CsgInfo csgInfo = CsgInfo(); +	try { +		csgInfo.glview = new OffscreenView(512,512); +	} catch (int error) { +		fprintf(stderr,"Can't create OpenGL OffscreenView. Code: %i. Exiting.\n", error); +		exit(1); +	} + +	std::cout << csgInfo.glview->getRendererInfo() << "\n"; + +	exit(0); +} +  std::string commandline_commands;  std::string currentdir;  QString examplesdir; @@ -127,6 +147,10 @@ Camera get_camera( po::variables_map vm )  		}  	} +	if (camera.type == Camera::GIMBAL) { +		camera.gimbalDefaultTranslate(); +	} +  	if (vm.count("projection")) {  		string proj = vm["projection"].as<string>();  		if (proj=="o" || proj=="ortho" || proj=="orthogonal") @@ -199,7 +223,9 @@ int main(int argc, char **argv)  	desc.add_options()  		("help,h", "help message")  		("version,v", "print the version") +		("info", "print information about the building process")  		("render", "if exporting a png image, do a full CGAL render") +		("preview", po::value<string>(), "if exporting a png image, do an OpenCSG(default) or ThrownTogether preview")  		("camera", po::value<string>(), "parameters for camera when exporting png")  	        ("imgsize", po::value<string>(), "=width,height for exporting png")  		("projection", po::value<string>(), "(o)rtho or (p)erspective when exporting png") @@ -231,6 +257,7 @@ int main(int argc, char **argv)  	if (vm.count("help")) help(argv[0]);  	if (vm.count("version")) version(); +	if (vm.count("info")) info();  	if (vm.count("o")) {  		// FIXME: Allow for multiple output files? @@ -513,6 +540,8 @@ int main(int argc, char **argv)  				else {  					if (vm.count("render")) {  						export_png_with_cgal(&root_N, camera, fstream); +					} else if (vm.count("preview") && vm["preview"].as<string>() == "throwntogether" ) { +						export_png_with_throwntogether(tree, camera, fstream);  					} else {  						export_png_with_opencsg(tree, camera, fstream);  					} | 
