Class OffscreenCanvas
- java.lang.Object
-
- org.jzy3d.plot3d.rendering.canvas.OffscreenCanvas
-
- All Implemented Interfaces:
ICanvas
,INativeCanvas
public class OffscreenCanvas extends Object implements ICanvas, INativeCanvas
AnICanvas
implementation able to render the chart in an offscreen canvas, meaning no frame or GUI is needed to get a chart. Subsequently, one will wish to generate chart images by calling:chart.screenshot();
GLCapabilities
are modified while an instance ofOffscreenCanvas
is modified.- Author:
- Nils Hoffman, Martin Pernollet
-
-
Field Summary
Fields Modifier and Type Field Description protected List<ICanvasListener>
canvasListeners
protected com.jogamp.opengl.GLCapabilities
capabilities
protected com.jogamp.opengl.GLOffscreenAutoDrawable
offscreenDrawable
protected Renderer3d
renderer
protected View
view
-
Fields inherited from interface org.jzy3d.plot3d.rendering.canvas.ICanvas
ALLOW_WATCH_PIXEL_SCALE, LAST_RENDER_TIME_UNDEFINED
-
-
Constructor Summary
Constructors Constructor Description OffscreenCanvas(IChartFactory factory, Scene scene, Quality quality, com.jogamp.opengl.GLCapabilities capabilities, int width, int height)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
addCanvasListener(ICanvasListener listener)
void
addKeyController(Object o)
A generic interface for mouse listener to remain Windowing toolkit independant.void
addMouseController(Object o)
A generic interface for mouse listener to remain Windowing toolkit independant.void
dispose()
Performs all required cleanup when destroying a Canvas.protected void
firePixelScaleChanged(double pixelScaleX, double pixelScaleY)
void
forceRepaint()
Invoked when a user requires the Canvas to be repainted (e.g. a non 3d layer has changed).List<ICanvasListener>
getCanvasListeners()
com.jogamp.opengl.GLCapabilities
getCapabilities()
String
getDebugInfo()
com.jogamp.opengl.GLOffscreenAutoDrawable
getDrawable()
Returns the GLDrawable associated with the canvasdouble
getLastRenderingTimeMs()
Coord2d
getPixelScale()
Provide pixel scale as feasible by the Hardware, OS, and JVM, independently of what was asked byICanvas.setPixelScale(float[])
.Coord2d
getPixelScaleJVM()
Provide pixel scale as considered feasible by the JVM.Renderer3d
getRenderer()
int
getRendererHeight()
Returns the renderer's height, i.e. the display height.int
getRendererWidth()
Returns the renderer's width, i.e. the display width.View
getView()
Provide a reference to the View that renders into this canvas.void
initBuffer(com.jogamp.opengl.GLCapabilities capabilities, int width, int height)
Initialize aGLOffscreenAutoDrawable
to the desired dimensions Might be aGLPixelBuffer
orGLFBODrawable
depending on the providedGLCapabilities
({@link GLCapabilities#setPBuffer(true)} to enable PBuffer).boolean
isNative()
Return true if the canvas renders GL with GPU, false if renders GL using CPU executed Java code.void
removeCanvasListener(ICanvasListener listener)
void
removeKeyController(Object o)
A generic interface for key listener to remain Windowing toolkit independant. * Implementation of this method should simply cast the input assuming it will correspond to canvas-compatible key listener.void
removeMouseController(Object o)
A generic interface for key listener to remain Windowing toolkit independant.com.jogamp.opengl.util.texture.TextureData
screenshot()
Returns an image with the current renderer's sizevoid
screenshot(File file)
void
setPixelScale(float[] scale)
Defines pixel scale.
-
-
-
Field Detail
-
view
protected View view
-
renderer
protected Renderer3d renderer
-
offscreenDrawable
protected com.jogamp.opengl.GLOffscreenAutoDrawable offscreenDrawable
-
capabilities
protected com.jogamp.opengl.GLCapabilities capabilities
-
canvasListeners
protected List<ICanvasListener> canvasListeners
-
-
Constructor Detail
-
OffscreenCanvas
public OffscreenCanvas(IChartFactory factory, Scene scene, Quality quality, com.jogamp.opengl.GLCapabilities capabilities, int width, int height)
-
-
Method Detail
-
initBuffer
public void initBuffer(com.jogamp.opengl.GLCapabilities capabilities, int width, int height)
Initialize aGLOffscreenAutoDrawable
to the desired dimensions Might be aGLPixelBuffer
orGLFBODrawable
depending on the providedGLCapabilities
({@link GLCapabilities#setPBuffer(true)} to enable PBuffer). Can be called several time to reset buffer dimensions.- Parameters:
capabilities
- with a setOnscreen flag set to true, otherwise forced to true.width
- image widthheight
- image width
-
getCapabilities
public com.jogamp.opengl.GLCapabilities getCapabilities()
-
getLastRenderingTimeMs
public double getLastRenderingTimeMs()
- Specified by:
getLastRenderingTimeMs
in interfaceICanvas
-
setPixelScale
public void setPixelScale(float[] scale)
Description copied from interface:ICanvas
Defines pixel scale. On MacOS Retina displays, a X*Y chart uses a (X*2)*(Y*2) viewport. This makes some calculation based on viewport (such asCamera.screenToModel(IPainter, org.jzy3d.maths.Coord3d)
output wrong result. When running on Retina display, those two options fixed buggy mouse selections on Retina:- setPixelScale(new float[]{0.5f,0.5f})
- setPixelScale(new float[] { ScalableSurface.IDENTITY_PIXELSCALE,
ScalableSurface.IDENTITY_PIXELSCALE })
- Specified by:
setPixelScale
in interfaceICanvas
-
getPixelScale
public Coord2d getPixelScale()
Description copied from interface:ICanvas
Provide pixel scale as feasible by the Hardware, OS, and JVM, independently of what was asked byICanvas.setPixelScale(float[])
. Hence the two functions may not be consistent together.- Specified by:
getPixelScale
in interfaceICanvas
-
getPixelScaleJVM
public Coord2d getPixelScaleJVM()
Description copied from interface:ICanvas
Provide pixel scale as considered feasible by the JVM.- Specified by:
getPixelScaleJVM
in interfaceICanvas
-
getDrawable
public com.jogamp.opengl.GLOffscreenAutoDrawable getDrawable()
Description copied from interface:INativeCanvas
Returns the GLDrawable associated with the canvas- Specified by:
getDrawable
in interfaceINativeCanvas
-
dispose
public void dispose()
Description copied from interface:ICanvas
Performs all required cleanup when destroying a Canvas.
-
forceRepaint
public void forceRepaint()
Description copied from interface:ICanvas
Invoked when a user requires the Canvas to be repainted (e.g. a non 3d layer has changed).- Specified by:
forceRepaint
in interfaceICanvas
-
screenshot
public com.jogamp.opengl.util.texture.TextureData screenshot()
Description copied from interface:INativeCanvas
Returns an image with the current renderer's size- Specified by:
screenshot
in interfaceICanvas
- Specified by:
screenshot
in interfaceINativeCanvas
-
screenshot
public void screenshot(File file) throws IOException
- Specified by:
screenshot
in interfaceICanvas
- Throws:
IOException
-
getView
public View getView()
Provide a reference to the View that renders into this canvas.
-
getRendererWidth
public int getRendererWidth()
Description copied from interface:ICanvas
Returns the renderer's width, i.e. the display width.- Specified by:
getRendererWidth
in interfaceICanvas
-
getRendererHeight
public int getRendererHeight()
Description copied from interface:ICanvas
Returns the renderer's height, i.e. the display height.- Specified by:
getRendererHeight
in interfaceICanvas
-
getRenderer
public Renderer3d getRenderer()
- Specified by:
getRenderer
in interfaceINativeCanvas
-
getDebugInfo
public String getDebugInfo()
- Specified by:
getDebugInfo
in interfaceICanvas
-
addMouseController
public void addMouseController(Object o)
Description copied from interface:ICanvas
A generic interface for mouse listener to remain Windowing toolkit independant. Implementation of this method should simply cast the input assuming it will correspond to canvas-compatible mouse listener.- Specified by:
addMouseController
in interfaceICanvas
-
addKeyController
public void addKeyController(Object o)
Description copied from interface:ICanvas
A generic interface for mouse listener to remain Windowing toolkit independant. Implementation of this method should simply cast the input assuming it will correspond to canvas-compatible mouse listener.- Specified by:
addKeyController
in interfaceICanvas
-
removeMouseController
public void removeMouseController(Object o)
Description copied from interface:ICanvas
A generic interface for key listener to remain Windowing toolkit independant. Implementation of this method should simply cast the input assuming it will correspond to canvas-compatible key listener.- Specified by:
removeMouseController
in interfaceICanvas
-
removeKeyController
public void removeKeyController(Object o)
Description copied from interface:ICanvas
A generic interface for key listener to remain Windowing toolkit independant. * Implementation of this method should simply cast the input assuming it will correspond to canvas-compatible key listener.- Specified by:
removeKeyController
in interfaceICanvas
-
addCanvasListener
public void addCanvasListener(ICanvasListener listener)
- Specified by:
addCanvasListener
in interfaceICanvas
-
removeCanvasListener
public void removeCanvasListener(ICanvasListener listener)
- Specified by:
removeCanvasListener
in interfaceICanvas
-
getCanvasListeners
public List<ICanvasListener> getCanvasListeners()
- Specified by:
getCanvasListeners
in interfaceICanvas
-
firePixelScaleChanged
protected void firePixelScaleChanged(double pixelScaleX, double pixelScaleY)
-
-