java.lang.Object
org.openpdf.layout.SharedContext
The SharedContext is that which is kept between successive layout and render runs.
- Author:
- empty
-
Constructor Summary
ConstructorsConstructorDescriptionSharedContext(UserAgentCallback uac, float dpi, int pixelsPerDot) SharedContext(UserAgentCallback uac, FontResolver fr, ReplacedElementFactory ref, TextRenderer tr, float dpi) SharedContext(UserAgentCallback userAgent, FontResolver fontResolver, ReplacedElementFactory replacedElementFactory, TextRenderer textRenderer, float dpi, int dotsPerPixel) -
Method Summary
Modifier and TypeMethodDescriptionvoidbooleanbooleanbooleanbooleanvoidGets the baseURL attribute of the RenderingContext object@Nullable BoxgetBoxById(String id) @Nullable FSCanvasgetCss()intfloatgetDPI()Gets the dPI attribute of the RenderingContext object@Nullable Rectangle@Nullable FSFontgetFont(FontSpecification spec) Gets the fontResolver attribute of the Context objectgetIdMap()getMedia()The media for this contextfloatGets the dPI attribute in a more useful form of the RenderingContext object@Nullable NamespaceHandlergetUac()Gets the uac attribute of the RenderingContext objectfloatgetXHeight(FontContext fontContext, FontSpecification fs) booleanbooleanisPaged()Returns true if the currently set media type is paged.booleanisPrint()newLayoutContextInstance(FontContext fontContext) newRenderingContextInstance(OutputDevice outputDevice, FontContext fontContext) newRenderingContextInstance(OutputDevice outputDevice, FontContext fontContext, @Nullable Layer rootLayer, int initialPageNo) voidremoveBoxId(String id) voidreset()voidsetBaseURL(@Nullable String url) Sets the baseURL attribute of the RenderingContext objectvoidvoidsetCss(StyleReference css) voidsetDebug_draw_boxes(boolean debug_draw_boxes) voidsetDebug_draw_font_metrics(boolean debug_draw_font_metrics) voidsetDebug_draw_inline_boxes(boolean debug_draw_inline_boxes) voidsetDebug_draw_line_boxes(boolean debug_draw_line_boxes) voidsetDotsPerPixel(int pixelsPerDot) voidsetDPI(float dpi) Sets the effective DPI (Dots Per Inch) of the screen.voidsetFontMapping(String name, Font font) Adds or overrides a font mapping, meaning you can associate a particular font with a particular string.voidsetFontResolver(FontResolver resolver) Deprecated.pass textRenderer to a constructor instead of using settervoidvoidsetInteractive(boolean interactive) voidsetLineBreakingStrategy(LineBreakingStrategy lineBreakingStrategy) voidSet the current media type.voidvoidsetPrint(boolean print) voidvoidsetTemporaryCanvas(Rectangle rect) voidsetTextRenderer(TextRenderer textRenderer) Deprecated.pass textRenderer to a constructor instead of using settervoidsetUserAgentCallback(UserAgentCallback userAgentCallback)
-
Constructor Details
-
SharedContext
public SharedContext() -
SharedContext
public SharedContext(UserAgentCallback userAgent, FontResolver fontResolver, ReplacedElementFactory replacedElementFactory, TextRenderer textRenderer, float dpi, int dotsPerPixel) -
SharedContext
-
SharedContext
-
SharedContext
public SharedContext(UserAgentCallback uac, FontResolver fr, ReplacedElementFactory ref, TextRenderer tr, float dpi)
-
-
Method Details
-
setFormSubmissionListener
-
newLayoutContextInstance
-
newRenderingContextInstance
public RenderingContext newRenderingContextInstance(OutputDevice outputDevice, FontContext fontContext) -
newRenderingContextInstance
public RenderingContext newRenderingContextInstance(OutputDevice outputDevice, FontContext fontContext, @Nullable Layer rootLayer, int initialPageNo) -
getFontResolver
Gets the fontResolver attribute of the Context object- Returns:
- The fontResolver value
-
flushFonts
public void flushFonts() -
getMedia
The media for this context -
getTextRenderer
-
debugDrawBoxes
public boolean debugDrawBoxes() -
debugDrawLineBoxes
public boolean debugDrawLineBoxes() -
debugDrawInlineBoxes
public boolean debugDrawInlineBoxes() -
debugDrawFontMetrics
public boolean debugDrawFontMetrics() -
setDebug_draw_boxes
public void setDebug_draw_boxes(boolean debug_draw_boxes) -
setDebug_draw_line_boxes
public void setDebug_draw_line_boxes(boolean debug_draw_line_boxes) -
setDebug_draw_inline_boxes
public void setDebug_draw_inline_boxes(boolean debug_draw_inline_boxes) -
setDebug_draw_font_metrics
public void setDebug_draw_font_metrics(boolean debug_draw_font_metrics) -
getCss
-
setCss
-
getCanvas
-
setCanvas
-
setTemporaryCanvas
-
getFixedRectangle
-
setNamespaceHandler
-
getNamespaceHandler
-
addBoxId
-
getBoxById
-
removeBoxId
-
getIdMap
-
setTextRenderer
Deprecated.pass textRenderer to a constructor instead of using setterSets the textRenderer attribute of the RenderingContext object- Parameters:
textRenderer- The new textRenderer value
-
setMedia
Set the current media type. This is usually something like screen or print . See the media section of the CSS 2.1 spec for more information on media types.
- Parameters:
media- The new media value
-
getUac
Gets the uac attribute of the RenderingContext object- Returns:
- The uac value
-
getUserAgentCallback
-
setUserAgentCallback
-
getDPI
public float getDPI()Gets the dPI attribute of the RenderingContext object- Returns:
- The dPI value
-
setDPI
public void setDPI(float dpi) Sets the effective DPI (Dots Per Inch) of the screen. You should normally never need to override the dpi, as it is already set to the system default byToolkit.getDefaultToolkit().getScreenResolution(). You can override the value if you want to scale the fonts for accessibility or printing purposes. Currently, the DPI setting only affects font sizing.- Parameters:
dpi- The new dPI value
-
getMmPerPx
public float getMmPerPx()Gets the dPI attribute in a more useful form of the RenderingContext object- Returns:
- The dPI value
-
getFont
-
getXHeight
-
getBaseURL
Gets the baseURL attribute of the RenderingContext object- Returns:
- The baseURL value
-
setBaseURL
Sets the baseURL attribute of the RenderingContext object- Parameters:
url- The new baseURL value
-
isPaged
public boolean isPaged()Returns true if the currently set media type is paged. Currently, returns true only for print , projection , and embossed , handheld , and tv . See the media section of the CSS 2.1 spec for more information on media types.- Returns:
- The paged value
-
isInteractive
public boolean isInteractive() -
setInteractive
public void setInteractive(boolean interactive) -
isPrint
public boolean isPrint() -
setPrint
public void setPrint(boolean print) -
setFontMapping
Adds or overrides a font mapping, meaning you can associate a particular font with a particular string. For example, the following would load a font out of the cool.ttf file and associate it with the name CoolFont :
Font font = Font.createFont(Font.TRUETYPE_FONT, new FileInputStream("cool.ttf"); setFontMapping("CoolFont", font);You could then put the following css in your page
p { font-family: CoolFont Arial sans-serif; }You can also override existing font mappings, like replacing Arial with Helvetica.
- Parameters:
name- The new font namefont- The actual Font to map
-
setFontResolver
Deprecated.pass textRenderer to a constructor instead of using setter -
getDotsPerPixel
public int getDotsPerPixel() -
setDotsPerPixel
public void setDotsPerPixel(int pixelsPerDot) -
getStyle
-
getStyle
-
reset
public void reset() -
getReplacedElementFactory
-
setReplacedElementFactory
-
getLineBreakingStrategy
-
setLineBreakingStrategy
-