Commit c301d627 authored by dscho's avatar dscho

x11vnc now works view only and with SHM

parent e0168dbd
...@@ -20,7 +20,7 @@ LIBS=$(LDFLAGS) $(VNCSERVERLIB) $(PTHREADLIB) ...@@ -20,7 +20,7 @@ LIBS=$(LDFLAGS) $(VNCSERVERLIB) $(PTHREADLIB)
OSX_LIBS = -framework ApplicationServices -framework Carbon OSX_LIBS = -framework ApplicationServices -framework Carbon
# for x11vnc # for x11vnc
XLIBS = -L/usr/X11R6/lib -lX11 XLIBS = -L/usr/X11R6/lib -lX11 -lXext
SOURCES=main.c rfbserver.c sraRegion.c auth.c sockets.c \ SOURCES=main.c rfbserver.c sraRegion.c auth.c sockets.c \
stats.c corre.c hextile.c rre.c translate.c cutpaste.c \ stats.c corre.c hextile.c rre.c translate.c cutpaste.c \
......
#include <X11/Xlib.h> #include <X11/Xlib.h>
#include <X11/keysym.h> #include <X11/keysym.h>
#ifndef NO_SHM
#include <X11/extensions/XShm.h>
#include <sys/shm.h>
#endif
#define KEYSYM_H #define KEYSYM_H
#include "rfb.h" #include "rfb.h"
int c=0,blockLength = 32; int c=0,blockLength = 32;
void getImage(Display *dpy,int xscreen,XImage **i) Bool useSHM =
#ifndef NO_SHM
TRUE;
XShmSegmentInfo shminfo;
#else
FALSE;
#endif
void getImage(int bpp,Display *dpy,int xscreen,XImage **i)
{ {
*i = XGetImage( dpy, if(useSHM && bpp>0) {
RootWindow(dpy,xscreen),
0,0, *i = XShmCreateImage( dpy,
DisplayWidth(dpy,xscreen), DefaultVisual( dpy, xscreen ),
DisplayHeight(dpy,xscreen), bpp,
AllPlanes, ZPixmap,
ZPixmap ); NULL,
&shminfo,
DisplayWidth(dpy,xscreen),
DisplayHeight(dpy,xscreen));
shminfo.shmid = shmget( IPC_PRIVATE,
(*i)->bytes_per_line * (*i)->height,
IPC_CREAT | 0777 );
shminfo.shmaddr = (*i)->data = (char *) shmat( shminfo.shmid, 0, 0 );
shminfo.readOnly = False;
XShmAttach( dpy, &shminfo );
XShmGetImage(dpy,RootWindow(dpy,xscreen),*i,0,0,AllPlanes);
} else {
*i = XGetImage(dpy,RootWindow(dpy,xscreen),0,0,DisplayWidth(dpy,xscreen),DisplayHeight(dpy,xscreen),
AllPlanes,ZPixmap );
}
} }
void checkForImageUpdates(rfbScreenInfoPtr s,char *b) void checkForImageUpdates(rfbScreenInfoPtr s,char *b)
...@@ -30,14 +59,14 @@ void checkForImageUpdates(rfbScreenInfoPtr s,char *b) ...@@ -30,14 +59,14 @@ void checkForImageUpdates(rfbScreenInfoPtr s,char *b)
for(l=j*s->paddedWidthInBytes;!changed&&l<y1;l+=s->paddedWidthInBytes) for(l=j*s->paddedWidthInBytes;!changed&&l<y1;l+=s->paddedWidthInBytes)
for(k=i*s->bitsPerPixel/8;k<x1;k++) for(k=i*s->bitsPerPixel/8;k<x1;k++)
if(s->frameBuffer[l+k]!=b[l+k]) { if(s->frameBuffer[l+k]!=b[l+k]) {
// fprintf(stderr,"changed: %d, %d\n",k,l); // fprintf(stderr,"changed: %d, %d\n",k,l);
changed=TRUE; changed=TRUE;
goto changed_p; goto changed_p;
} }
if(changed) { if(changed) {
changed_p: changed_p:
for(;l<0*y1;l++) for(l+=i*s->bitsPerPixel/8;l<y1;l+=s->paddedWidthInBytes)
memcpy(/*b+l,*/s->frameBuffer+l,b+l,x1-l); memcpy(/*b+l,*/s->frameBuffer+l,b+l,x1-i*s->bitsPerPixel/8);
rfbMarkRectAsModified(s,i,j,i+blockLength,j+blockLength); rfbMarkRectAsModified(s,i,j,i+blockLength,j+blockLength);
} }
} }
...@@ -54,7 +83,7 @@ int main(int argc,char** argv) ...@@ -54,7 +83,7 @@ int main(int argc,char** argv)
dpy = XOpenDisplay(""); dpy = XOpenDisplay("");
xscreen = DefaultScreen(dpy); xscreen = DefaultScreen(dpy);
getImage(dpy,xscreen,&framebufferImage); getImage(0,dpy,xscreen,&framebufferImage);
screen = rfbGetScreen(&argc,argv,framebufferImage->width, screen = rfbGetScreen(&argc,argv,framebufferImage->width,
framebufferImage->height, framebufferImage->height,
...@@ -95,23 +124,24 @@ int main(int argc,char** argv) ...@@ -95,23 +124,24 @@ int main(int argc,char** argv)
} }
backupImage = malloc(screen->height*screen->paddedWidthInBytes); backupImage = malloc(screen->height*screen->paddedWidthInBytes);
//memcpy(backupImage,framebufferImage->data,screen->height*screen->paddedWidthInBytes); memcpy(backupImage,framebufferImage->data,screen->height*screen->paddedWidthInBytes);
screen->frameBuffer = backupImage; screen->frameBuffer = backupImage;
screen->rfbDeferUpdateTime = 500; screen->rfbDeferUpdateTime = 50;
screen->cursor = 0; screen->cursor = 0;
rfbInitServer(screen); rfbInitServer(screen);
while(1) { while(1) {
//fprintf(stderr,"%d\r",c++);
rfbProcessEvents(screen,-1); rfbProcessEvents(screen,-1);
if(1 || /*c++>7 &&*/ (!screen->rfbClientHead || !FB_UPDATE_PENDING(screen->rfbClientHead))) { //if(1 || /*c++>7 &&*/ (!screen->rfbClientHead || !FB_UPDATE_PENDING(screen->rfbClientHead))) {
c=0; //c=0;
framebufferImage->f.destroy_image(framebufferImage); framebufferImage->f.destroy_image(framebufferImage);
getImage(dpy,xscreen,&framebufferImage); getImage(screen->rfbServerFormat.bitsPerPixel,dpy,xscreen,&framebufferImage);
//checkForImageUpdates(screen,framebufferImage->data); checkForImageUpdates(screen,framebufferImage->data);
} //}
fprintf(stderr,"%x\n%x\n---\n",screen->frameBuffer,framebufferImage->data); //fprintf(stderr,"%x\n%x\n---\n",screen->frameBuffer,framebufferImage->data);
memcpy(screen->frameBuffer,framebufferImage->data,screen->height/10*screen->paddedWidthInBytes); //memcpy(screen->frameBuffer,framebufferImage->data,screen->height*screen->paddedWidthInBytes);
rfbMarkRectAsModified(screen,0,0,screen->width,screen->height); rfbMarkRectAsModified(screen,0,0,screen->width,screen->height);
#if 0 #if 0
{ {
...@@ -120,8 +150,8 @@ int main(int argc,char** argv) ...@@ -120,8 +150,8 @@ int main(int argc,char** argv)
fprintf(f,"P6\n%d %d\n255\n",screen->width,screen->height); fprintf(f,"P6\n%d %d\n255\n",screen->width,screen->height);
for(j=0;j<screen->height;j++) for(j=0;j<screen->height;j++)
for(i=0;i<screen->width;i++) { for(i=0;i<screen->width;i++) {
//r=screen->frameBuffer[j*screen->paddedWidthInBytes+i*2]; //r=screen->frameBuffer[j*screen->paddedWidthInBytes+i*2];
r=framebufferImage->data[j*screen->paddedWidthInBytes+i*2]; r=framebufferImage->data[j*screen->paddedWidthInBytes+i*2];
fputc(((r>>screen->rfbServerFormat.redShift)&screen->rfbServerFormat.redMax)*255/screen->rfbServerFormat.redMax,f); fputc(((r>>screen->rfbServerFormat.redShift)&screen->rfbServerFormat.redMax)*255/screen->rfbServerFormat.redMax,f);
fputc(((r>>screen->rfbServerFormat.greenShift)&screen->rfbServerFormat.greenMax)*255/screen->rfbServerFormat.greenMax,f); fputc(((r>>screen->rfbServerFormat.greenShift)&screen->rfbServerFormat.greenMax)*255/screen->rfbServerFormat.greenMax,f);
fputc(((r>>screen->rfbServerFormat.blueShift)&screen->rfbServerFormat.blueMax)*255/screen->rfbServerFormat.blueMax,f); fputc(((r>>screen->rfbServerFormat.blueShift)&screen->rfbServerFormat.blueMax)*255/screen->rfbServerFormat.blueMax,f);
...@@ -130,6 +160,9 @@ int main(int argc,char** argv) ...@@ -130,6 +160,9 @@ int main(int argc,char** argv)
} }
#endif #endif
} }
#ifndef NO_SHM
XShmDetach(dpy,framebufferImage);
#endif
return(0); return(0);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment