Make VRAM seperation work

This commit is contained in:
2025-01-26 17:27:47 +00:00
parent 4b46683a99
commit 9a80b17e0b

View File

@@ -1,30 +1,41 @@
component VRAMSegment inherits Rectangle { component VRAMSegment inherits Rectangle {
in property <int> area_overlap_width; in property <image> img;
in property <int> area_overlap_height; in property <int> clip_x;
in property <int> clip_y;
width: 64px; width: 64px;
height: 256px; height: 256px;
background: #37f560; clip: true;
Image {
Rectangle { source: img;
x: 0px; x: -root.clip_x*1px;
y: 0px; y: -root.clip_y*1px;
width: area_overlap_width > 64 ? 64px : area_overlap_width*1px;
height: area_overlap_height > 256 ? 256px : area_overlap_height*1px;
background: #d7e609;
} }
} }
component VRAMArea inherits Rectangle { component VRAMArea inherits Rectangle {
in property <int> display_area_width; in property <image> img;
in property <int> display_area_height; in property <int> img_x;
in property <int> img_y;
for idx in 16 : VRAMSegment { width: (64*16+15)*1px;
x: mod(idx,8)*(64+1)*1px; height: (256*2+1)*1px;
y: floor(idx/8)*(256+1)*1px;
area_overlap_width: parent.display_area_width - (mod(idx,8)*64); for idx in 32 : VRAMSegment {
area_overlap_height: parent.display_area_height - (256*floor(idx/8)); x: root.get_x(idx)*(64px + 1px);
y: root.get_y(idx)*(256px + 1px);
img: img;
clip_x: (root.get_x(idx)*64) - root.img_x;
clip_y: (root.get_y(idx)*256) - root.img_y;
}
function get_x(idx: int) -> int {
return mod(idx, 16);
}
function get_y(idx: int) -> int {
return floor(idx/16);
} }
} }
@@ -33,9 +44,19 @@ export component MainWindow inherits Window {
min-height: 640px; min-height: 640px;
VRAMArea { VRAMArea {
x: 0; x: 0px;
y: 0; y: 0px;
display_area_width: 32+64+3; img: @image-url("../../../../examples/PoolBox/assets/AllTheJaby.png");
display_area_height: 256+128; img_x: 0;
img_y: 0;
background: #0365f796;
}
VRAMArea {
x: 0px;
y: 0px;
img: @image-url("../../../../examples/PoolBox/assets/IMG_6921.png");
img_x: 80;
img_y: 80;
background: #ff000076;
} }
} }