15c6c1daeSBarry Smith 25c6c1daeSBarry Smith #include <petscdraw.h> /*I "petscdraw.h" I*/ 35c6c1daeSBarry Smith 45c6c1daeSBarry Smith #undef __FUNCT__ 55c6c1daeSBarry Smith #define __FUNCT__ "PetscDrawZoom" 65c6c1daeSBarry Smith /*@C 75c6c1daeSBarry Smith PetscDrawZoom - Allows one to create a graphic that users may zoom into. 85c6c1daeSBarry Smith 95c6c1daeSBarry Smith Collective on PetscDraw 105c6c1daeSBarry Smith 115c6c1daeSBarry Smith Input Parameters: 125c6c1daeSBarry Smith + draw - the window where the graph will be made. 135c6c1daeSBarry Smith . func - users function that draws the graphic 145c6c1daeSBarry Smith - ctx - pointer to any user required data 155c6c1daeSBarry Smith 165c6c1daeSBarry Smith Level: advanced 175c6c1daeSBarry Smith 185c6c1daeSBarry Smith Concepts: graphics^zooming 195c6c1daeSBarry Smith Concepts: drawing^zooming 205c6c1daeSBarry Smith Concepts: zooming^in graphics 215c6c1daeSBarry Smith 225c6c1daeSBarry Smith .seealso: 235c6c1daeSBarry Smith @*/ 245c6c1daeSBarry Smith PetscErrorCode PetscDrawZoom(PetscDraw draw,PetscErrorCode (*func)(PetscDraw,void*),void *ctx) 255c6c1daeSBarry Smith { 265c6c1daeSBarry Smith PetscErrorCode ierr; 275c6c1daeSBarry Smith PetscDrawButton button; 285c6c1daeSBarry Smith PetscReal dpause,xc,yc,scale = 1.0,w,h,xr,xl,yr,yl,xmin,xmax,ymin,ymax; 295c6c1daeSBarry Smith PetscBool isnull; 305c6c1daeSBarry Smith 315c6c1daeSBarry Smith PetscFunctionBegin; 325c6c1daeSBarry Smith ierr = PetscDrawIsNull(draw,&isnull);CHKERRQ(ierr); 335c6c1daeSBarry Smith if (isnull) PetscFunctionReturn(0); 345c6c1daeSBarry Smith 355c6c1daeSBarry Smith ierr = PetscDrawCheckResizedWindow(draw);CHKERRQ(ierr); 365c6c1daeSBarry Smith ierr = PetscDrawSynchronizedClear(draw);CHKERRQ(ierr); 37e118a51fSLisandro Dalcin ierr = PetscDrawCollectiveBegin(draw);CHKERRQ(ierr); 385c6c1daeSBarry Smith ierr = (*func)(draw,ctx);CHKERRQ(ierr); 39e118a51fSLisandro Dalcin ierr = PetscDrawCollectiveEnd(draw);CHKERRQ(ierr); 405c6c1daeSBarry Smith ierr = PetscDrawSynchronizedFlush(draw);CHKERRQ(ierr); 415c6c1daeSBarry Smith 425c6c1daeSBarry Smith ierr = PetscDrawGetPause(draw,&dpause);CHKERRQ(ierr); 435c6c1daeSBarry Smith if (dpause >= 0) { 445c6c1daeSBarry Smith ierr = PetscSleep(dpause);CHKERRQ(ierr); 455c6c1daeSBarry Smith goto theend; 465c6c1daeSBarry Smith } 475c6c1daeSBarry Smith if (dpause != -1) goto theend; 485c6c1daeSBarry Smith 495c6c1daeSBarry Smith ierr = PetscDrawCheckResizedWindow(draw);CHKERRQ(ierr); 505c6c1daeSBarry Smith ierr = PetscDrawSynchronizedGetMouseButton(draw,&button,&xc,&yc,0,0);CHKERRQ(ierr); 515c6c1daeSBarry Smith ierr = PetscDrawGetCoordinates(draw,&xl,&yl,&xr,&yr);CHKERRQ(ierr); 52*9f80f0efSLisandro Dalcin xmin = xl; xmax = xr; w = xr - xl; 53*9f80f0efSLisandro Dalcin ymin = yl; ymax = yr; h = yr - yl; 545c6c1daeSBarry Smith 55e118a51fSLisandro Dalcin while (button != PETSC_BUTTON_NONE && button != PETSC_BUTTON_RIGHT) { 565c6c1daeSBarry Smith ierr = PetscDrawSynchronizedClear(draw);CHKERRQ(ierr); 57*9f80f0efSLisandro Dalcin switch (button) { 58*9f80f0efSLisandro Dalcin case PETSC_BUTTON_LEFT: scale = 0.5; break; 59*9f80f0efSLisandro Dalcin case PETSC_BUTTON_CENTER: scale = 2.0; break; 60*9f80f0efSLisandro Dalcin case PETSC_BUTTON_WHEEL_UP: scale = 8/10.; break; 61*9f80f0efSLisandro Dalcin case PETSC_BUTTON_WHEEL_DOWN: scale = 10/8.; break; 62*9f80f0efSLisandro Dalcin default: scale = 1.0; 63*9f80f0efSLisandro Dalcin } 645c6c1daeSBarry Smith xl = scale*(xl + w - xc) + xc - w*scale; 655c6c1daeSBarry Smith xr = scale*(xr - w - xc) + xc + w*scale; 665c6c1daeSBarry Smith yl = scale*(yl + h - yc) + yc - h*scale; 675c6c1daeSBarry Smith yr = scale*(yr - h - yc) + yc + h*scale; 685c6c1daeSBarry Smith w *= scale; h *= scale; 695c6c1daeSBarry Smith ierr = PetscDrawSetCoordinates(draw,xl,yl,xr,yr);CHKERRQ(ierr); 70e118a51fSLisandro Dalcin ierr = PetscDrawCollectiveBegin(draw);CHKERRQ(ierr); 715c6c1daeSBarry Smith ierr = (*func)(draw,ctx);CHKERRQ(ierr); 72e118a51fSLisandro Dalcin ierr = PetscDrawCollectiveEnd(draw);CHKERRQ(ierr); 735c6c1daeSBarry Smith ierr = PetscDrawSynchronizedFlush(draw);CHKERRQ(ierr); 745c6c1daeSBarry Smith ierr = PetscDrawCheckResizedWindow(draw);CHKERRQ(ierr); 755c6c1daeSBarry Smith ierr = PetscDrawSynchronizedGetMouseButton(draw,&button,&xc,&yc,0,0);CHKERRQ(ierr); 765c6c1daeSBarry Smith } 775c6c1daeSBarry Smith ierr = PetscDrawSetCoordinates(draw,xmin,ymin,xmax,ymax);CHKERRQ(ierr); 785c6c1daeSBarry Smith theend: 795c6c1daeSBarry Smith PetscFunctionReturn(0); 805c6c1daeSBarry Smith } 815c6c1daeSBarry Smith 82