From 47341aa5545e8b354c8cd45e1372f96d9e4f6c0d Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Aug 2001 09:57:47 +0000 Subject: now lines are drawn for the example, first steps to make clients independent. --- example.c | 111 ++++++++++++++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 87 insertions(+), 24 deletions(-) (limited to 'example.c') diff --git a/example.c b/example.c index 2fe1d3f..22d1c04 100644 --- a/example.c +++ b/example.c @@ -32,36 +32,92 @@ const int maxx=640, maxy=480, bpp=4; -void initBuffer(char* buffer) +/* This initializes a nice (?) background */ + +void initBuffer(unsigned char* buffer) { int i,j; for(i=0;iclientData); +} + +void newclient(rfbClientPtr cl) +{ + cl->clientData = (void*)calloc(sizeof(ClientData),1); + cl->clientGoneHook = clientgone; +} + +/* aux function to draw a line */ +void drawline(unsigned char* buffer,int rowstride,int bpp,int x1,int y1,int x2,int y2) +{ + int i,j; + i=x1-x2; j=y1-y2; + if(i<0) i=-i; + if(j<0) j=-j; + if(iy2) { i=y2; y2=y1; y1=i; i=x2; x2=x1; x1=i; } + if(y2==y1) { if(y2>0) y1--; else y2++; } + for(j=y1;j<=y2;j++) + for(i=0;ix2) { i=y2; y2=y1; y1=i; i=x2; x2=x1; x1=i; } + for(i=x1;i<=x2;i++) + for(j=0;jclientData; if(buttonMask && x>=0 && y>=0 && xmaxx) x2=maxx; - y1=y-buttonMask; if(y1<0) y1=0; - y2=y+buttonMask; if(y2>maxy) y2=maxy; - - for(i=x1*bpp;iscreen->frameBuffer[j*cl->screen->paddedWidthInBytes+i]=0xff; - rfbMarkRectAsModified(cl->screen,x1,y1,x2,y2); - rfbGotXCutText(cl->screen,"Hallo",5); - } -} + if(cd->oldButton==buttonMask) { /* draw a line */ + drawline(cl->screen->frameBuffer,cl->screen->paddedWidthInBytes,bpp, + x,y,cd->oldx,cd->oldy); + rfbMarkRectAsModified(cl->screen,x,y,cd->oldx,cd->oldy); + } else { /* draw a point (diameter depends on button) */ + x1=x-buttonMask; if(x1<0) x1=0; + x2=x+buttonMask; if(x2>maxx) x2=maxx; + y1=y-buttonMask; if(y1<0) y1=0; + y2=y+buttonMask; if(y2>maxy) y2=maxy; + + for(i=x1*bpp;iscreen->frameBuffer[j*cl->screen->paddedWidthInBytes+i]=0xff; + rfbMarkRectAsModified(cl->screen,x1,y1,x2-1,y2-1); + } + /* we could get a selection like that: + rfbGotXCutText(cl->screen,"Hallo",5); + */ + + cd->oldx=x; cd->oldy=y; cd->oldButton=buttonMask; + } else + cd->oldButton=0; +} + +/* Here the key events are handled */ void dokey(Bool down,KeySym key,rfbClientPtr cl) { @@ -73,21 +129,28 @@ void dokey(Bool down,KeySym key,rfbClientPtr cl) } } +/* Initialisation */ + int main(int argc,char** argv) { - rfbScreenInfoPtr rfbScreen = rfbDefaultScreenInit(argc,argv); - rfbScreen->desktopName="LibVNCServer Example"; + rfbScreenInfoPtr rfbScreen = + rfbDefaultScreenInit(argc,argv,maxx,maxy,8,3,bpp); + rfbScreen->desktopName = "LibVNCServer Example"; rfbScreen->frameBuffer = (char*)malloc(maxx*maxy*bpp); - rfbScreen->width=maxx; - rfbScreen->height=maxy; - rfbScreen->paddedWidthInBytes=maxx*bpp; - rfbScreen->ptrAddEvent=doptr; - rfbScreen->kbdAddEvent=dokey; + rfbScreen->rfbAlwaysShared = TRUE; + rfbScreen->ptrAddEvent = doptr; + rfbScreen->kbdAddEvent = dokey; + rfbScreen->newClientHook = newclient; initBuffer(rfbScreen->frameBuffer); + /* this is the blocking event loop, i.e. it never returns */ runEventLoop(rfbScreen,40000,FALSE); + + /* this is the non-blocking event loop; a background thread is started */ runEventLoop(rfbScreen,40000,TRUE); + + /* now we could do some cool things like rendering */ while(1); return(0); -- cgit v1.2.1