mirror of
https://chromium.googlesource.com/crosvm/crosvm
synced 2025-02-10 20:19:07 +00:00
crosvm is switching the import style to use one import per line. While more verbose, this will greatly reduce the occurence of merge conflicts going forward. Note: This is using a nightly feature of rustfmt. So it's a one-off re-format only. We are considering adding a nightly toolchain to enable the feature permanently. BUG=b:239937122 TEST=CQ Change-Id: Id2dd4dbdc0adfc4f8f3dd1d09da1daafa2a39992 Reviewed-on: https://chromium-review.googlesource.com/c/crosvm/crosvm/+/3784345 Reviewed-by: Daniel Verkamp <dverkamp@chromium.org> Tested-by: Dennis Kempin <denniskempin@google.com> Commit-Queue: Dennis Kempin <denniskempin@google.com>
28 lines
817 B
Rust
28 lines
817 B
Rust
use gpu_display::GpuDisplay;
|
|
use gpu_display::SurfaceType;
|
|
|
|
fn main() {
|
|
let mut disp = GpuDisplay::open_x(None::<&str>).unwrap();
|
|
let surface_id = disp
|
|
.create_surface(None, 1280, 1024, SurfaceType::Scanout)
|
|
.unwrap();
|
|
|
|
let mem = disp.framebuffer(surface_id).unwrap();
|
|
for y in 0..1024 {
|
|
let mut row = [0u32; 1280];
|
|
for (x, item) in row.iter_mut().enumerate() {
|
|
let b = ((x as f32 / 1280.0) * 256.0) as u32;
|
|
let g = ((y as f32 / 1024.0) * 256.0) as u32;
|
|
*item = b | (g << 8);
|
|
}
|
|
mem.as_volatile_slice()
|
|
.offset(1280 * 4 * y)
|
|
.unwrap()
|
|
.copy_from(&row);
|
|
}
|
|
disp.flip(surface_id);
|
|
|
|
while !disp.close_requested(surface_id) {
|
|
disp.dispatch_events().unwrap();
|
|
}
|
|
}
|