summaryrefslogtreecommitdiff
path: root/recordmydesktop
diff options
context:
space:
mode:
Diffstat (limited to 'recordmydesktop')
-rw-r--r--recordmydesktop/src/rectinsert.c20
-rw-r--r--recordmydesktop/src/setbrwindow.c14
2 files changed, 33 insertions, 1 deletions
diff --git a/recordmydesktop/src/rectinsert.c b/recordmydesktop/src/rectinsert.c
index 4caf1b8..dfe721e 100644
--- a/recordmydesktop/src/rectinsert.c
+++ b/recordmydesktop/src/rectinsert.c
@@ -269,6 +269,16 @@ int RectInsert(RectArea **root,WGeometry *wgeom){
int total_insertions=0;
RectArea *temp,*newnode=(RectArea *)malloc(sizeof(RectArea));
+ //align
+ //we do need to know boundaries
+ wgeom->width+=(wgeom->width%2)|(wgeom->x%2);
+ wgeom->height+=(wgeom->height%2)|(wgeom->y%2);
+ wgeom->width+=(wgeom->width%2);
+ wgeom->height+=(wgeom->height%2);
+ wgeom->x-=wgeom->x%2;
+ wgeom->y-=wgeom->y%2;
+// fprintf(stderr," %d %d %d %d\n",wgeom->x,
+
newnode->geom.x=wgeom->x;
newnode->geom.y=wgeom->y;
newnode->geom.width=wgeom->width;
@@ -290,7 +300,15 @@ int RectInsert(RectArea **root,WGeometry *wgeom){
if((!collres))
insert_ok=1;
else{
- insert_ok=0;
+ for(i=0;i<ngeoms;i++){
+ wgeom_return[i]->width+=(wgeom_return[i]->width%2)|(wgeom_return[i]->x%2);
+ wgeom_return[i]->height+=(wgeom_return[i]->height%2)|(wgeom_return[i]->y%2);
+ wgeom_return[i]->width+=(wgeom_return[i]->width%2);
+ wgeom_return[i]->height+=(wgeom_return[i]->height%2);
+ wgeom_return[i]->x-=wgeom_return[i]->x%2;
+ wgeom_return[i]->y-=wgeom_return[i]->y%2;
+ }
+ insert_ok=0;
switch(collres){
case 1://remove current node,reinsert new one
total_insertions--;
diff --git a/recordmydesktop/src/setbrwindow.c b/recordmydesktop/src/setbrwindow.c
index 13e7de3..3eda7ad 100644
--- a/recordmydesktop/src/setbrwindow.c
+++ b/recordmydesktop/src/setbrwindow.c
@@ -79,6 +79,20 @@ int SetBRWindow(Display *dpy,BRWindow *brwin,DisplaySpecs *specs,ProgArgs *args)
return 1;
}
}
+ //align in two
+ //an odd x can always go down and still be in recording area.
+ //Resolutions come in even numbers
+ //so if x is an odd numer, width max is an odd number, too
+ //thus since x will go down one then width can go up one too and still
+ //be inbounds
+ brwin->rgeom.width+=(brwin->rgeom.width%2)|(brwin->rgeom.x%2);
+ brwin->rgeom.height+=(brwin->rgeom.height%2)|(brwin->rgeom.y%2);
+ //but if x goes down 1 and width is already even,it becomes odd so:
+ brwin->rgeom.width+=(brwin->rgeom.width%2);
+ brwin->rgeom.height+=(brwin->rgeom.height%2);
+ brwin->rgeom.x-=brwin->rgeom.x%2;
+ brwin->rgeom.y-=brwin->rgeom.y%2;
+
//this is needed for theora
//+-8 pixels
brwin->rgeom.width=((((brwin->rgeom.width+16-(brwin->rgeom.width)%16+brwin->rgeom.x)<=specs->width)&&((brwin->rgeom.width)%16>8))?brwin->rgeom.width+16-(brwin->rgeom.width)%16:brwin->rgeom.width-(brwin->rgeom.width)%16);
© All Rights Reserved