Home

Awesome

Export figure to 3D interactive PDF

Summary

Export figure as a U3D file or directly to 3D interactive graphics within a PDF. Licensed under 2-clause BSD.

Documentation

PDF created for figure below (3d <font color="red">needs</font> Adobe Reader).

<img src="https://raw.githubusercontent.com/johnyf/binaries/master/fig2u3d/logo.png" width=200>

The LaTeX needed looks like:

\documentclass{article}
\usepackage{graphicx}
\usepackage[dvipdfmx]{media9}

\begin{document}
	\begin{figure}
		\centering
		\includemedia[
			width=0.8\textwidth,
			activate=pagevisible,
			%deactivate=pageinvisible,
			3Dtoolbar,
			3Dviews=./example_supercyclide.vws
		]{
			\includegraphics[width=0.8\textwidth]{example_supercyclide.pdf}
		}{./example_supercyclide.u3d}
		\caption{An implicitly defined elliptic supercyclide.}
		\label{fig:example_supercyclide}
	\end{figure}
\end{document}

Description

fig2u3d saves the figure as a U3D file for inclusion as an interactive 3-dimensional figure within a PDF. Either LaTeX or Adobe Acrobat can be used to embed the U3D file in the PDF.

The idtf2u3d executables are included from this project (see dependencies below).

A vws file is also created, which contains the current camera view of the axes saved. This file can be used to set the figure's default view in the PDF to be the same with the open figure window in MATLAB.

The media9 LaTeX package can import U3D files with their associated VWS files in a PDF document.

For PDF readers which do not render 3D figures, it is possible to include an alternative 2D image as a substitute to the 3D object. For conveniency, the script saves a 2D image together with U3D file. File type and other options for exporting this 2D image can be specified as additional arguments.

fig2pdf3d Converts the figure directly to a PDF containing only an interactive 3D graphics object.

Graphics object supported for export include:

Line colors and marker styles, surfaces and quivers with NaNs and surface shading are supported. Multiple instances of various objects can be plotted in the same axes and exported. Note that some limitations apply, for example filled contours are not yet supported.

<img src="https://raw.githubusercontent.com/johnyf/binaries/master/fig2u3d/fig2u3d_workflow.png" width=400>

Installation

Download & unpack from the release the:

Add all the above and their subdirectories to your MATLAB path, e.g. using the pathtool command.

Optional

Acknowledgments

Dependencies included

Other

License

This project is licensed under the 2-clause BSD license. The license file includes the authors of all dependencies, so that they can be distributed with this project.

Hosted

Development on github, releases here and also via File Exchange.

Keywords

3d, u3d, graphics, export, save, plot, surface, vector, quiver, quivergroup, mesh, contourgroup, contour, data export, mathematics, vision, latex, pdf, media9, movie15, pdflatex, xelatex