[][src]Struct cairo::PsSurface

pub struct PsSurface(_);


impl PsSurface[src]

pub unsafe fn from_raw_full(
    ptr: *mut cairo_surface_t
) -> Result<PsSurface, Error>

impl PsSurface[src]

pub fn new<P: AsRef<Path>>(
    width: f64,
    height: f64,
    path: P
) -> Result<PsSurface, Error>

pub fn for_stream<W: Write + 'static>(
    width: f64,
    height: f64,
    stream: W
) -> Result<Self, Error>

Takes full ownership of the output stream, which is not allowed to borrow any lifetime shorter than 'static.

Because the underlying cairo_surface_t is reference-counted, a lifetime parameter in a Rust wrapper type would not be enough to track how long it can keep writing to the stream.

pub unsafe fn for_raw_stream<W: Write + 'static>(
    width: f64,
    height: f64,
    stream: *mut W
) -> Result<Self, Error>

Allows writing to a borrowed stream. The lifetime of the borrow is not tracked.


The value that stream points to must live at least until the underlying cairo_surface_t (which maybe be longer then the Rust PdfSurface wrapper, because of reference-counting), or until the output stream is removed from the surface with [Surface::take_output_stream].

Since the former is hard to track for sure, the latter is strongly recommended. The concrete type behind the Box<dyn Any> value returned by take_output_stream is private, so you won’t be able to downcast it. But removing it anyway ensures that later writes do no go through a dangling pointer.

pub fn get_levels() -> impl Iterator<Item = PsLevel>[src]

pub fn restrict(&self, level: PsLevel)[src]

pub fn get_eps(&self) -> bool[src]

pub fn set_eps(&self, eps: bool)[src]

pub fn set_size(&self, width: f64, height: f64)[src]

pub fn cairo_ps_surface_dsc_begin_setup(&self)[src]

pub fn cairo_ps_surface_dsc_begin_page_setup(&self)[src]

pub fn cairo_ps_surface_dsc_comment(&self, comment: &str)[src]

Methods from Deref<Target = Surface>

pub fn to_raw_none(&self) -> *mut cairo_surface_t[src]

pub fn create_similar(
    content: Content,
    width: i32,
    height: i32
) -> Result<Surface, Error>

pub fn create_for_rectangle(&self, bounds: Rectangle) -> Result<Surface, Error>[src]

pub fn get_mime_data(&self, mime_type: &str) -> Option<Vec<u8>>[src]

pub unsafe fn get_mime_data_raw(&self, mime_type: &str) -> Option<&[u8]>[src]

pub fn set_mime_data<T: AsRef<[u8]> + 'static>(
    mime_type: &str,
    slice: T
) -> Result<(), Error>

pub fn supports_mime_type(&self, mime_type: &str) -> bool[src]

pub fn get_device(&self) -> Option<Device>[src]

pub fn set_device_offset(&self, x_offset: f64, y_offset: f64)[src]

pub fn get_device_offset(&self) -> (f64, f64)[src]

pub fn set_device_scale(&self, x_scale: f64, y_scale: f64)[src]

pub fn get_device_scale(&self) -> (f64, f64)[src]

pub fn set_fallback_resolution(
    x_pixels_per_inch: f64,
    y_pixels_per_inch: f64

pub fn get_fallback_resolution(&self) -> (f64, f64)[src]

pub fn create_similar_image(
    format: Format,
    width: i32,
    height: i32
) -> Result<Surface, Error>

pub fn map_to_image(
    extents: Option<RectangleInt>
) -> Result<MappedImageSurface, Error>

pub fn mark_dirty(&self)[src]

pub fn mark_dirty_rectangle(&self, x: i32, y: i32, width: i32, height: i32)[src]

pub fn set_user_data<T: 'static>(
    key: &'static UserDataKey<T>,
    value: Rc<T>

Attach user data to self for the given key.

pub fn get_user_data<T: 'static>(
    key: &'static UserDataKey<T>
) -> Option<Rc<T>>

Return the user data previously attached to self with the given key, if any.

pub fn get_user_data_ptr<T: 'static>(
    key: &'static UserDataKey<T>
) -> Option<NonNull<T>>

Return the user data previously attached to self with the given key, if any, without incrementing the reference count.

The pointer is valid when it is returned from this method, until the cairo object that self represents is destroyed or remove_user_data or set_user_data is called with the same key.

pub fn remove_user_data<T: 'static>(&self, key: &'static UserDataKey<T>)[src]

Unattach from self the user data associated with key, if any. If there is no other Rc strong reference, the data is destroyed.

pub fn flush(&self)[src]

pub fn finish(&self)[src]

pub fn get_type(&self) -> SurfaceType[src]

pub fn finish_output_stream(&self) -> Result<Box<dyn Any>, StreamWithError>[src]

Finish the surface, then remove and return the output stream if any.

This calls Surface::finish, to make sure pending writes are done.

This is relevant for surfaces created for example with [PdfSurface::for_stream].

Use Box::downcast to recover the concrete stream type.


This method panics if:

  • This method was already called for this surface, or
  • This surface was not created with an output stream in the first place, or
  • A previous write to this surface panicked, or
  • A previous write happened while another write was ongoing, or
  • A write is ongoing now.

The latter two cases can only occur with a pathological output stream type that accesses the same surface again from Write::write_all.

Trait Implementations

impl Clone for PsSurface[src]

impl Debug for PsSurface[src]

impl Deref for PsSurface[src]

type Target = Surface

The resulting type after dereferencing.

impl Display for PsSurface[src]

impl FromGlibPtrBorrow<*mut cairo_surface_t> for PsSurface[src]

impl FromGlibPtrFull<*mut cairo_surface_t> for PsSurface[src]

impl FromGlibPtrNone<*mut cairo_surface_t> for PsSurface[src]

impl<'a> FromValueOptional<'a> for PsSurface[src]

impl SetValue for PsSurface[src]

impl SetValueOptional for PsSurface[src]

impl StaticType for PsSurface[src]

impl<'a> ToGlibPtr<'a, *mut cairo_surface_t> for PsSurface[src]

type Storage = &'a Surface

impl TryFrom<Surface> for PsSurface[src]

type Error = Surface

The type returned in the event of a conversion error.

Auto Trait Implementations

impl RefUnwindSafe for PsSurface

impl !Send for PsSurface

impl !Sync for PsSurface

impl Unpin for PsSurface

impl UnwindSafe for PsSurface

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized

impl<T> Borrow<T> for T where
    T: ?Sized

impl<T> BorrowMut<T> for T where
    T: ?Sized

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 

impl<T> ToOwned for T where
    T: Clone

type Owned = T

The resulting type after obtaining ownership.

impl<T> ToSendValue for T where
    T: ToValue + SetValue + Send + ?Sized

impl<T> ToString for T where
    T: Display + ?Sized

impl<T> ToValue for T where
    T: SetValue + ?Sized

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.