Expand description
The webrender_api crate contains an assortment types and functions used
by WebRender consumers as well as, in many cases, WebRender itself.
This separation allows Servo to parallelize compilation across webrender
and other crates that depend on webrender_api. So in practice, we put
things in this crate when Servo needs to use them. Firefox depends on the
webrender crate directly, and so this distinction is not really relevant
there.
Re-exports§
- pub extern crate euclid;
Modules§
Macros§
- enumerate_interners 
- Meta-macro to enumerate the various interner identifiers and types.
Structs§
- AddBlobImage 
- Creates a blob-image resource with provided parameters.
- AddFontInstance 
- Creates a font instance resource.
- AddImage
- Creates an image resource with provided parameters.
- AuxIter
- BackdropFilter Display Item 
- Renders a filtered region of its backdrop
- BlendPrimitive 
- BlobImage Descriptor 
- Metadata (but not storage) for a blob image.
- BlobImage Key 
- An opaque identifier describing a blob image registered with WebRender. This is used as a handle to reference blob images, and can be used as an image in display items.
- BlobImage Params 
- Input parameters for the BlobImageRasterizer.
- BlobImage Request 
- A key identifying blob image rasterization work requested from the blob image rasterizer.
- BlurPrimitive 
- BorderDisplay Item 
- BorderRadius 
- BorderSide 
- BoxShadowDisplay Item 
- BuiltDisplay List 
- A display list.
- BuiltDisplay List Descriptor 
- Describes the memory layout of a display list.
- BuiltDisplay List Iter 
- CaptureBits 
- Bit flags for WR stages to store in a capture.
- CapturedDocument 
- Information about a loaded capture of each document
that is returned by RenderBackend.
- ClearCache 
- Mask for clearing caches in debug commands.
- ClearRectangle Display Item 
- Clears all colors from the area, making it possible to cut holes in the window. (useful for things like the macos frosted-glass effect).
- ClipChain Id 
- ClipChain Item 
- Just an abstraction for bundling up a bunch of clips into a “super clip”.
- ClipDisplay Item 
- ColorF
- Represents RGBA screen colors with floating point numbers.
- ColorMatrix Primitive 
- cbindgen:derive-eq=false
- ColorU
- Represents RGBA screen colors with one byte per channel.
- CommonItem Properties 
- A grouping of fields a lot of display items need, just to avoid repeating these over and over in this file.
- ComplexClip Region 
- ComponentTransfer Primitive 
- CompositePrimitive 
- DebugFlags 
- Flags to enable/disable various builtin debugging tools.
- DisplayItem Ref 
- DisplayList Builder 
- DocumentId 
- A key uniquely identifying a WebRender document.
- DocumentTransaction 
- DropShadow Primitive 
- DynamicProperties 
- When using generate_frame(), a list ofPropertyValuestructures can optionally be supplied to provide the current value of any animated properties.
- Epoch
- An epoch identifies the state of a pipeline in time.
- ExternalEvent 
- An opaque pointer-sized value.
- ExternalImage 
- The data that an external client should provide about an external image. For instance, if providing video frames, the application could call wr.render() whenever a new video frame is ready. Note that the UV coords are supplied in texel-space!
- ExternalImage Data 
- Descriptor for external image resources. See ImageData.
- ExternalImage Id 
- An arbitrary identifier for an external image provided by the application. It must be a unique identifier for each external image.
- ExternalScroll Id 
- An external identifier that uniquely identifies a scroll frame independent of its ClipId, which may change from frame to frame. This should be unique within a pipeline. WebRender makes no attempt to ensure uniqueness. The zero value is reserved for use by the root scroll node of every pipeline, which always has an external id.
- FilterData 
- FilterPrimitive 
- SVG Filter Primitive. See: https://github.com/eqrion/cbindgen/issues/9 cbindgen:derive-eq=false
- FloodPrimitive 
- FontInstance Data 
- Data corresponding to an instantiation of a font, with size and other options specified.
- FontInstance Flags 
- FontInstance Key 
- FontInstance Options 
- FontInstance Platform Options 
- FontKey
- FontVariation 
- GlyphDimensions 
- GlyphInstance 
- GlyphOptions 
- Gradient
- GradientBuilder 
- Construct a gradient to be used in display lists.
- GradientDisplay Item 
- The area
- GradientStop 
- HitTestDisplay Item 
- A minimal hit-testable item for the parent browser’s convenience, and is slimmer than a RectangleDisplayItem (no color). The existence of this as a distinct item also makes it easier to inspect/debug display items.
- HitTestFlags 
- HitTestItem 
- Describe an item that matched a hit-test query.
- HitTestResult 
- Returned by RenderApi::hit_test.
- IdNamespace
- ID namespaces uniquely identify different users of WebRender’s API.
- IdentityPrimitive 
- IframeDisplay Item 
- ImageDescriptor 
- Metadata (but not storage) describing an image In WebRender.
- ImageDescriptor Flags 
- Various flags that are part of an image descriptor.
- ImageDisplay Item 
- This describes an image that fills the specified area. It stretches or shrinks the image as necessary. While RepeatingImageDisplayItem could otherwise provide a superset of the functionality, it has been problematic inferring the desired repetition properties when snapping changes the size of the primitive.
- ImageKey 
- An opaque identifier describing an image registered with WebRender.
This is used as a handle to reference images, and is used as the
hash map key for the actual image storage in the ResourceCache.
- ImageMask 
- InternerSubReport 
- InterningMemory Report 
- Memory report for interning-related data structures. cbindgen:derive-eq=false
- ItemRange 
- ItemStats 
- Stats for an individual item
- LineDisplay Item 
- MemoryReport 
- Collection of heap sizes, in bytes. cbindgen:derive-eq=false
- NativeFont Handle 
- NinePatch Border 
- NormalBorder 
- NotificationRequest 
- A request to notify a handler when the transaction reaches certain stages of the rendering pipeline.
- OffsetPrimitive 
- OpacityPrimitive 
- PipelineId 
- From the point of view of WR, PipelineIdis completely opaque and generic as long as it’s clonable, serializable, comparable, and hashable.
- PremultipliedColorF 
- Represents pre-multiplied RGBA colors with floating point numbers.
- PrimitiveFlags 
- PropertyBinding Id 
- A key to identify an animated property binding.
- PropertyBinding Key 
- A unique key that is used for connecting animated property values to bindings in the display list.
- PropertyValue 
- The current value of an animated property. This is supplied by the calling code.
- PushShadow Display Item 
- PushStacking Context Display Item 
- QualitySettings 
- Various settings that the caller can select based on desired tradeoffs between rendering quality and performance / power usage.
- RadialGradient 
- RadialGradient Display Item 
- RasterizedBlob Image 
- Representation of a rasterized blob image. This is obtained by passing
BlobImageDatato the embedding via the rasterization callback.
- RectangleDisplay Item 
- A solid color to draw (may not actually be a rectangle due to complex clips)
- ReferenceFrame 
- ReferenceFrame Display List Item 
- RenderApi 
- The main entry point to interact with WebRender.
- RenderApiSender 
- Allows the API to communicate with WebRender.
- RepeatingImage Display Item 
- This describes a background-image and its tiling. It repeats in a grid to fill the specified area.
- SaveState 
- ScrollFrame Display Item 
- ScrollNode State 
- Shadow
- SpaceAndClip Info 
- Per-primitive information about the nodes in the clip tree and the spatial tree that the primitive belongs to.
- SpatialId 
- A reference to a spatial node defining item positioning.
- StackingContext 
- StickyFrame Display Item 
- StickyOffset Bounds 
- The minimum and maximum allowable offset for a sticky frame in a single dimension.
- SyntheticItalics 
- TempFilter Data 
- TextDisplay Item 
- Transaction
- A Transaction is a group of commands to apply atomically to a document.
- TransactionMsg 
- Represents a transaction in the format sent through the channel.
- UpdateBlob Image 
- Updates an already existing blob-image resource.
- UpdateImage 
- Updates an already existing image resource.
- YuvImageDisplay Item 
- ZoomFactor 
- Represents a zoom factor.
Enums§
- AddFont
- Creates a font resource.
- AlphaType 
- ApiMsg
- Message sent by the RenderApito the render backend thread.
- BlobImage Error 
- Error code for when blob rasterization failed.
- BorderDetails 
- BorderRadius Kind 
- BorderStyle 
- BoxShadowClip Mode 
- Checkpoint
- A stage of the rendering pipeline.
- ClipId
- A reference to a clipping node defining how an item is clipped.
- ClipIntern 
- ClipMode 
- ColorDepth 
- Specifies the color depth of an image. Currently only used for YUV images.
- ColorRange 
- ColorSpace 
- ComponentTransfer Func Type 
- CompositeOperator 
- Available composite operoations for the composite filter primitive
- DebugCommand 
- Update of the state of built-in debugging facilities.
- DirtyRect 
- The possible states of a Dirty rect.
- DisplayItem 
- ExtendMode 
- ExternalImage Source 
- The source for an external image.
- ExternalImage Type 
- Storage format identifier for externally-managed images.
- FilterData Intern 
- FilterOp 
- CSS filter.
- FilterPrimitive Input 
- An input to a SVG filter primitive.
- FilterPrimitive Kind 
- See: https://github.com/eqrion/cbindgen/issues/9 cbindgen:derive-eq=false
- FontHinting 
- FontLCDFilter 
- FontRender Mode 
- FontTemplate 
- Container for the raw data describing a font. This might be a stream of bytes corresponding to a downloaded font, or a handle to a native font from the operating system.
- FrameMsg 
- Frame messages affect frame generation (applied after building the scene).
- ImageData 
- Represents the backing store of an arbitrary series of pixels for display by WebRender. This storage can take several forms.
- ImageFormat 
- Specifies the format of a series of pixels, in driver terms.
- ImageRendering 
- LineOrientation 
- LineStyle 
- MixBlendMode 
- NinePatch Border Source 
- PrimitiveKeyKind 
- Information specific to a primitive type that uniquely identifies a primitive template by key.
- PropertyBinding 
- A binding property can either be a specific value (the normal, non-animated case) or point to a binding location to fetch the current value from. Note that Binding has also a non-animated value, the value is used for the case where the animation is still in-delay phase (i.e. the animation doesn’t produce any animation values).
- RasterSpace 
- Configure whether the contents of a stacking context should be rasterized in local space or screen space. Local space rasterized pictures are typically used when we want to cache the output, and performance is important. Note that this is a performance hint only, which WR may choose to ignore.
- ReferenceFrame Kind 
- RepeatMode 
- ResourceUpdate 
- Update of a persistent resource in WebRender.
- SceneMsg 
- Frame messages affect building the scene.
- ScrollClamping 
- Describe whether or not scrolling should be clamped by the content bounds.
- ScrollLocation 
- ScrollSensitivity 
- TextureTarget 
- Specifies the type of texture target in driver terms.
- TransformStyle 
- YuvColorSpace 
- YuvData
- YuvFormat
Constants§
Traits§
- AsyncBlob Image Rasterizer 
- A group of rasterization requests to execute synchronously on the scene builder thread.
- BlobImage Handler 
- A handler on the render backend that can create rasterizer objects which will be sent to the scene builder thread to execute the rasterization.
- BlobImage Resources 
- The resources exposed by the resource cache available for use by the blob rasterizer.
- ExternalImage Handler 
- The interfaces that an application can implement to support providing external image buffers. When the application passes an external image to WR, it should keep that external image life time. People could check the epoch id in RenderNotifier at the client side to make sure that the external image is not used by WR. Then, do the clean up for that external image.
- NotificationHandler 
- A handler to notify when a transaction reaches certain stages of the rendering pipeline.
- OutputImage Handler 
- Allows callers to receive a texture with the contents of a specific pipeline copied to it.
- RenderNotifier 
- A handler to integrate WebRender with the thread that contains the Renderer.
Type Aliases§
- BlobImage Data 
- Backing store for blob image command streams.
- BlobImage Result 
- Result type for blob raserization.
- DocumentLayer 
- Documents are rendered in the ascending order of their associated layer values.
- GlyphIndex 
- ItemTag
- A tag that can be used to identify items during hit testing. If the tag is missing then the item doesn’t take part in hit testing at all. This is composed of two numbers. In Servo, the first is an identifier while the second is used to select the cursor that should be used during mouse movement. In Gecko, the first is a scrollframe identifier, while the second is used to store various flags that APZ needs to properly process input events.
- PipelineSource Id 
- This type carries no valuable semantics for WR. However, it reflects the fact that
clients (Servo) may generate pipelines by different semi-independent sources.
These pipelines still belong to the same IdNamespaceand the sameDocumentId. Having this extra Id field enables them to generatePipelineIdwithout collision.
- TileSize 
- Width and height in device pixels of image tiles.
- VoidPtrTo Size Fn 
- A C function that takes a pointer to a heap allocation and returns its size.