1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
// Take a look at the license at the top of the repository in the LICENSE file.
use crate::Surface;
use glib::object::IsA;
use glib::translate::*;
// rustdoc-stripper-ignore-next
/// Trait containing manually implemented methods of [`Surface`](crate::Surface).
pub trait SurfaceExtManual: 'static {
/// Create a new Cairo surface that is as compatible as possible with the
/// given @self.
///
/// For example the new surface will have the same fallback resolution
/// and font options as @self. Generally, the new surface will also
/// use the same backend as @self, unless that is not possible for
/// some reason. The type of the returned surface may be examined with
/// cairo_surface_get_type().
///
/// Initially the surface contents are all 0 (transparent if contents
/// have transparency, black otherwise.)
///
/// This function always returns a valid pointer, but it will return a
/// pointer to a “nil” surface if @other is already in an error state
/// or any other error occurs.
/// ## `content`
/// the content for the new surface
/// ## `width`
/// width of the new surface
/// ## `height`
/// height of the new surface
///
/// # Returns
///
/// a pointer to the newly allocated surface. The caller
/// owns the surface and should call cairo_surface_destroy() when done
/// with it.
#[doc(alias = "gdk_surface_create_similar_surface")]
fn create_similar_surface(
&self,
content: cairo::Content,
width: i32,
height: i32,
) -> cairo::Surface;
/// Translates coordinates between two surfaces.
///
/// Note that this only works if @to and @self are popups or
/// transient-for to the same toplevel (directly or indirectly).
/// ## `to`
/// the target surface
/// ## `x`
/// coordinates to translate
/// ## `y`
/// coordinates to translate
///
/// # Returns
///
/// [`true`] if the coordinates were successfully translated
#[doc(alias = "gdk_surface_translate_coordinates")]
fn translate_coordinates(&self, to: &Surface, x: f64, y: f64) -> bool;
}
impl<O: IsA<Surface>> SurfaceExtManual for O {
fn create_similar_surface(
&self,
content: cairo::Content,
width: i32,
height: i32,
) -> cairo::Surface {
unsafe {
from_glib_full(ffi::gdk_surface_create_similar_surface(
self.as_ref().to_glib_none().0,
content.into(),
width,
height,
))
}
}
fn translate_coordinates(&self, to: &Surface, mut x: f64, mut y: f64) -> bool {
unsafe {
from_glib(ffi::gdk_surface_translate_coordinates(
self.as_ref().to_glib_none().0,
to.to_glib_none().0,
&mut x,
&mut y,
))
}
}
}