[−][src]Crate azul_webrender
A GPU based renderer for the web.
It serves as an experimental render backend for Servo, but it can also be used as such in a standalone application.
External dependencies
WebRender currently depends on FreeType
Api Structure
The main entry point to WebRender is the crate::Renderer
.
By calling Renderer::new(...)
you get a Renderer
, as well as
a RenderApiSender
. Your Renderer
is responsible to render the
previously processed frames onto the screen.
By calling yourRenderApiSender.create_api()
, you'll
get a RenderApi
instance, which is responsible for managing resources
and documents. A worker thread is used internally to untie the workload from the application
thread and therefore be able to make better use of multicore systems.
Frame
What is referred to as a frame
, is the current geometry on the screen.
A new Frame is created by calling set_display_list()
on the RenderApi
. When the geometry is processed, the application will be
informed via a RenderNotifier
, a callback which you pass to
Renderer::new
.
More information about stacking contexts.
set_display_list()
also needs to be supplied with
BuiltDisplayList
s. These are obtained by finalizing a
DisplayListBuilder
. These are used to draw your geometry. But it
doesn't only contain trivial geometry, it can also store another
StackingContext
, as they're nestable.
Re-exports
pub extern crate euclid; |
pub extern crate api; |
pub use api as webrender_api; |
Macros
c_str |
Structs
AsyncScreenshotHandle | A handle to a screenshot that is being asynchronously captured and scaled. |
BinaryRecorder | |
CpuProfile | |
DebugFlags | Flags to enable/disable various builtin debugging tools. |
Device | |
FormatDesc | |
GpuProfile | |
GraphicsApiInfo | |
ItemUid | A globally, unique identifier |
NativeSurfaceId | An arbitrary identifier for a native (OS compositor) surface |
NativeSurfaceInfo | Information about a bound surface that the native compositor returns to WR. |
NativeTileId | |
PipelineInfo | |
PrimitiveDebugId | |
ProgramBinary | |
ProgramCache | |
ProgramSourceDigest | |
RecordedFrameHandle | A handle to a recorded frame that was captured. |
RenderResults | Return type from render(), which contains some repr(C) statistics as well as some non-repr(C) data. |
Renderer | The renderer is responsible for submitting to the GPU the work prepared by the RenderBackend. |
RendererOptions | |
RendererStats | Some basic statistics about the rendered scene, used in Gecko, as well as in wrench reftests to ensure that tests are batching and/or allocating on render targets as we expect them to. |
ShaderPrecacheFlags | Flags that control how shaders are pre-cached, if at all. |
Shaders | |
SharedHitTester | |
TileCacheInstanceSerializer | A minimal subset of TileCacheInstance for debug capturing |
TileCacheLoggerUpdateLists | |
TileDescriptor | Uniquely describes the content of this tile, in a way that can be (reasonably) efficiently hashed and compared. |
TileId | A stable ID for a given tile, to help debugging. These are also used as unique identifiers for tile surfaces when using a native compositor. |
TileNode | A node in the dirty rect tracking quadtree. |
TileSerializer | A minimal subset of Tile for debug capturing |
WrShaders |
Enums
ChasePrimitive | |
CompareHelperResult | Optional extra information returned by is_same when logging is enabled. |
GraphicsApi | |
InvalidationReason | Debugging information about why a tile was invalidated |
PrimitiveCompareResult | The result of a primitive dependency comparison. Size is a u8 since this is a hot path in the code, and keeping the data small is a performance win. |
PrimitiveCompareResultDetail | A more detailed version of PrimitiveCompareResult used when debug logging is enabled. |
RendererError | |
RendererKind | |
TileNodeKind | Details for a node in a quadtree that tracks dirty rects for a tile. |
UploadMethod | Method of uploading texel data from CPU to GPU. |
VertexUsageHint |
Constants
MAX_VERTEX_TEXTURE_WIDTH |
Statics
WEBRENDER_RECORDING_HEADER |
Traits
ApiRecordingReceiver | |
AsyncPropertySampler | Allows callers to hook into the main render_backend loop and provide additional frame ops for generate_frame transactions. These functions are all called from the render backend thread. |
ProfilerHooks | Defines the interface for hooking up an external profiler to WR. |
ProgramCacheObserver | The interfaces that an application can implement to handle ProgramCache update |
SceneBuilderHooks | Allows callers to hook in at certain points of the async scene build. These functions are all called from the scene builder thread. |
ThreadListener |
Functions
build_shader_strings | Creates heap-allocated strings for both vertex and fragment shaders. Public to be accessible to tests. |
get_gl_target | |
set_profiler_hooks | Set the profiler callbacks, or None to disable the profiler. This function must only ever be called before any WR instances have been created, or the hooks will not be set. |
Type Definitions
FastHashMap | |
TileOffset |