| /* |
| * GDI mapping mode functions |
| * |
| * Copyright 1993 Alexandre Julliard |
| */ |
| |
| #include <math.h> |
| #include "gdi.h" |
| #include "metafile.h" |
| #include "stddebug.h" |
| /* #define DEBUG_GDI */ |
| #include "debug.h" |
| |
| |
| /*********************************************************************** |
| * MAPPING_FixIsotropic |
| * |
| * Fix viewport extensions for isotropic mode. |
| */ |
| void MAPPING_FixIsotropic( DC * dc ) |
| { |
| double xdim = (double)dc->w.VportExtX * dc->w.devCaps->horzSize / |
| (dc->w.devCaps->horzRes * dc->w.WndExtX); |
| double ydim = (double)dc->w.VportExtY * dc->w.devCaps->vertSize / |
| (dc->w.devCaps->vertRes * dc->w.WndExtY); |
| if (xdim > ydim) |
| { |
| dc->w.VportExtX = dc->w.VportExtX * fabs( ydim / xdim ); |
| if (!dc->w.VportExtX) dc->w.VportExtX = 1; |
| } |
| else |
| { |
| dc->w.VportExtY = dc->w.VportExtY * fabs( xdim / ydim ); |
| if (!dc->w.VportExtY) dc->w.VportExtY = 1; |
| } |
| } |
| |
| /*********************************************************************** |
| * DPtoLP (GDI.67) |
| */ |
| BOOL DPtoLP( HDC hdc, LPPOINT points, INT count ) |
| { |
| POINT * pt; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| |
| for (pt = points; count > 0; pt++, count--) |
| { |
| pt->x = XDPTOLP( dc, pt->x ); |
| pt->y = YDPTOLP( dc, pt->y ); |
| } |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * LPtoDP (GDI.99) |
| */ |
| BOOL LPtoDP( HDC hdc, LPPOINT points, int count ) |
| { |
| POINT * pt; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| |
| for (pt = points; count > 0; pt++, count--) |
| { |
| pt->x = XLPTODP( dc, pt->x ); |
| pt->y = YLPTODP( dc, pt->y ); |
| } |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * SetMapMode (GDI.3) |
| */ |
| WORD SetMapMode( HDC hdc, WORD mode ) |
| { |
| WORD prevMode; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return 0; |
| MF_MetaParam1(dc, META_SETMAPMODE, mode); |
| return 1; |
| } |
| |
| dprintf_gdi(stddeb, "SetMapMode: %04x %d\n", hdc, mode ); |
| |
| prevMode = dc->w.MapMode; |
| switch(mode) |
| { |
| case MM_TEXT: |
| dc->w.WndOrgX = dc->w.WndOrgY = 0; |
| dc->w.VportOrgX = dc->w.VportOrgY = 0; |
| dc->w.WndExtX = 1; |
| dc->w.WndExtY = 1; |
| dc->w.VportExtX = 1; |
| dc->w.VportExtY = 1; |
| break; |
| |
| case MM_LOMETRIC: |
| case MM_ISOTROPIC: |
| dc->w.WndOrgX = dc->w.WndOrgY = 0; |
| dc->w.VportOrgX = dc->w.VportOrgY = 0; |
| dc->w.WndExtX = dc->w.devCaps->horzSize; |
| dc->w.WndExtY = dc->w.devCaps->vertSize; |
| dc->w.VportExtX = dc->w.devCaps->horzRes / 10; |
| dc->w.VportExtY = dc->w.devCaps->vertRes / -10; |
| break; |
| |
| case MM_HIMETRIC: |
| dc->w.WndOrgX = dc->w.WndOrgY = 0; |
| dc->w.VportOrgX = dc->w.VportOrgY = 0; |
| dc->w.WndExtX = dc->w.devCaps->horzSize * 10; |
| dc->w.WndExtY = dc->w.devCaps->vertSize * 10; |
| dc->w.VportExtX = dc->w.devCaps->horzRes / 10; |
| dc->w.VportExtY = dc->w.devCaps->vertRes / -10; |
| break; |
| |
| case MM_LOENGLISH: |
| dc->w.WndOrgX = dc->w.WndOrgY = 0; |
| dc->w.VportOrgX = dc->w.VportOrgY = 0; |
| dc->w.WndExtX = dc->w.devCaps->horzSize; |
| dc->w.WndExtY = dc->w.devCaps->vertSize; |
| dc->w.VportExtX = (short)(254L * dc->w.devCaps->horzRes / 1000); |
| dc->w.VportExtY = (short)(-254L * dc->w.devCaps->vertRes / 1000); |
| break; |
| |
| case MM_HIENGLISH: |
| dc->w.WndOrgX = dc->w.WndOrgY = 0; |
| dc->w.VportOrgX = dc->w.VportOrgY = 0; |
| dc->w.WndExtX = dc->w.devCaps->horzSize * 10; |
| dc->w.WndExtY = dc->w.devCaps->vertSize * 10; |
| dc->w.VportExtX = (short)(254L * dc->w.devCaps->horzRes / 1000); |
| dc->w.VportExtY = (short)(-254L * dc->w.devCaps->vertRes / 1000); |
| break; |
| |
| case MM_TWIPS: |
| dc->w.WndOrgX = dc->w.WndOrgY = 0; |
| dc->w.VportOrgX = dc->w.VportOrgY = 0; |
| dc->w.WndExtX = (short)(144L * dc->w.devCaps->horzSize / 10); |
| dc->w.WndExtY = (short)(144L * dc->w.devCaps->vertSize / 10); |
| dc->w.VportExtX = (short)(254L * dc->w.devCaps->horzRes / 1000); |
| dc->w.VportExtY = (short)(-254L * dc->w.devCaps->vertRes / 1000); |
| break; |
| |
| case MM_ANISOTROPIC: |
| break; |
| |
| default: |
| return prevMode; |
| } |
| dc->w.MapMode = mode; |
| return prevMode; |
| } |
| |
| |
| /*********************************************************************** |
| * SetViewportExt (GDI.14) |
| */ |
| DWORD SetViewportExt( HDC hdc, short x, short y ) |
| { |
| SIZE size; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam2(dc, META_SETVIEWPORTEXT, x, y); |
| return 0; |
| } |
| |
| size.cx = dc->w.VportExtX; |
| size.cy = dc->w.VportExtY; |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return size.cx | (size.cy << 16); |
| if (!x || !y) return 0; |
| dc->w.VportExtX = x; |
| dc->w.VportExtY = y; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return size.cx | (size.cy << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * SetViewportExtEx (GDI.479) |
| */ |
| BOOL SetViewportExtEx( HDC hdc, short x, short y, LPSIZE size ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (size) |
| { |
| size->cx = dc->w.VportExtX; |
| size->cy = dc->w.VportExtY; |
| } |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return TRUE; |
| if (!x || !y) return FALSE; |
| dc->w.VportExtX = x; |
| dc->w.VportExtY = y; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * SetViewportOrg (GDI.13) |
| */ |
| DWORD SetViewportOrg( HDC hdc, short x, short y ) |
| { |
| POINT pt; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam2(dc, META_SETVIEWPORTORG, x, y); |
| return 0; |
| } |
| |
| pt.x = dc->w.VportOrgX; |
| pt.y = dc->w.VportOrgY; |
| dc->w.VportOrgX = x; |
| dc->w.VportOrgY = y; |
| return pt.x | (pt.y << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * SetViewportOrgEx (GDI.480) |
| */ |
| BOOL SetViewportOrgEx( HDC hdc, short x, short y, LPPOINT pt ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (pt) |
| { |
| pt->x = dc->w.VportOrgX; |
| pt->y = dc->w.VportOrgY; |
| } |
| dc->w.VportOrgX = x; |
| dc->w.VportOrgY = y; |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * SetWindowExt (GDI.12) |
| */ |
| DWORD SetWindowExt( HDC hdc, short x, short y ) |
| { |
| SIZE size; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam2(dc, META_SETWINDOWEXT, x, y); |
| return 0; |
| } |
| |
| size.cx = dc->w.WndExtX; |
| size.cy = dc->w.WndExtY; |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return size.cx | (size.cy << 16); |
| if (!x || !y) return 0; |
| dc->w.WndExtX = x; |
| dc->w.WndExtY = y; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return size.cx | (size.cy << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * SetWindowExtEx (GDI.481) |
| */ |
| BOOL SetWindowExtEx( HDC hdc, short x, short y, LPSIZE size ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (size) |
| { |
| size->cx = dc->w.WndExtX; |
| size->cy = dc->w.WndExtY; |
| } |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return TRUE; |
| if (!x || !y) return FALSE; |
| dc->w.WndExtX = x; |
| dc->w.WndExtY = y; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * SetWindowOrg (GDI.11) |
| */ |
| DWORD SetWindowOrg( HDC hdc, short x, short y ) |
| { |
| POINT pt; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam2(dc, META_SETWINDOWORG, x, y); |
| return 0; |
| } |
| |
| pt.x = dc->w.WndOrgX; |
| pt.y = dc->w.WndOrgY; |
| dc->w.WndOrgX = x; |
| dc->w.WndOrgY = y; |
| return pt.x | (pt.y << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * SetWindowOrgEx (GDI.482) |
| */ |
| BOOL SetWindowOrgEx( HDC hdc, short x, short y, LPPOINT pt ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (pt) |
| { |
| pt->x = dc->w.WndOrgX; |
| pt->y = dc->w.WndOrgY; |
| } |
| dc->w.WndOrgX = x; |
| dc->w.WndOrgY = y; |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * OffsetViewportOrg (GDI.17) |
| */ |
| DWORD OffsetViewportOrg( HDC hdc, short x, short y ) |
| { |
| POINT pt; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam2(dc, META_OFFSETVIEWPORTORG, x, y); |
| return 0; |
| } |
| |
| pt.x = dc->w.VportOrgX; |
| pt.y = dc->w.VportOrgY; |
| dc->w.VportOrgX += x; |
| dc->w.VportOrgY += y; |
| return pt.x | (pt.y << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * OffsetViewportOrgEx (GDI.476) |
| */ |
| BOOL OffsetViewportOrgEx( HDC hdc, short x, short y, LPPOINT pt ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (pt) |
| { |
| pt->x = dc->w.VportOrgX; |
| pt->y = dc->w.VportOrgY; |
| } |
| dc->w.VportOrgX += x; |
| dc->w.VportOrgY += y; |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * OffsetWindowOrg (GDI.15) |
| */ |
| DWORD OffsetWindowOrg( HDC hdc, short x, short y ) |
| { |
| POINT pt; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam2(dc, META_OFFSETWINDOWORG, x, y); |
| return 0; |
| } |
| |
| pt.x = dc->w.WndOrgX; |
| pt.y = dc->w.WndOrgY; |
| dc->w.WndOrgX += x; |
| dc->w.WndOrgY += y; |
| return pt.x | (pt.y << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * OffsetWindowOrgEx (GDI.477) |
| */ |
| BOOL OffsetWindowOrgEx( HDC hdc, short x, short y, LPPOINT pt ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (pt) |
| { |
| pt->x = dc->w.WndOrgX; |
| pt->y = dc->w.WndOrgY; |
| } |
| dc->w.WndOrgX += x; |
| dc->w.WndOrgY += y; |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * ScaleViewportExt (GDI.18) |
| */ |
| DWORD ScaleViewportExt( HDC hdc, short xNum, short xDenom, |
| short yNum, short yDenom ) |
| { |
| SIZE size; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam4(dc, META_SCALEVIEWPORTEXT, xNum, xDenom, yNum, yDenom); |
| return 0; |
| } |
| |
| size.cx = dc->w.VportExtX; |
| size.cy = dc->w.VportExtY; |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return size.cx | (size.cy << 16); |
| if (!xNum || !xDenom || !xNum || !yDenom) return 0; |
| dc->w.VportExtX = (dc->w.VportExtX * xNum) / xDenom; |
| dc->w.VportExtY = (dc->w.VportExtY * yNum) / yDenom; |
| if (dc->w.VportExtX == 0) dc->w.VportExtX = 1; |
| if (dc->w.VportExtY == 0) dc->w.VportExtY = 1; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return size.cx | (size.cy << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * ScaleViewportExtEx (GDI.484) |
| */ |
| BOOL ScaleViewportExtEx( HDC hdc, short xNum, short xDenom, |
| short yNum, short yDenom, LPSIZE size ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (size) |
| { |
| size->cx = dc->w.VportExtX; |
| size->cy = dc->w.VportExtY; |
| } |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return TRUE; |
| if (!xNum || !xDenom || !xNum || !yDenom) return FALSE; |
| dc->w.VportExtX = (dc->w.VportExtX * xNum) / xDenom; |
| dc->w.VportExtY = (dc->w.VportExtY * yNum) / yDenom; |
| if (dc->w.VportExtX == 0) dc->w.VportExtX = 1; |
| if (dc->w.VportExtY == 0) dc->w.VportExtY = 1; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return TRUE; |
| } |
| |
| |
| /*********************************************************************** |
| * ScaleWindowExt (GDI.16) |
| */ |
| DWORD ScaleWindowExt( HDC hdc, short xNum, short xDenom, |
| short yNum, short yDenom ) |
| { |
| SIZE size; |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) |
| { |
| dc = (DC *)GDI_GetObjPtr(hdc, METAFILE_DC_MAGIC); |
| if (!dc) return FALSE; |
| MF_MetaParam4(dc, META_SCALEWINDOWEXT, xNum, xDenom, yNum, yDenom); |
| return 0; |
| } |
| |
| size.cx = dc->w.WndExtX; |
| size.cy = dc->w.WndExtY; |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return size.cx | (size.cy << 16); |
| if (!xNum || !xDenom || !xNum || !yDenom) return FALSE; |
| dc->w.WndExtX = (dc->w.WndExtX * xNum) / xDenom; |
| dc->w.WndExtY = (dc->w.WndExtY * yNum) / yDenom; |
| if (dc->w.WndExtX == 0) dc->w.WndExtX = 1; |
| if (dc->w.WndExtY == 0) dc->w.WndExtY = 1; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return size.cx | (size.cy << 16); |
| } |
| |
| |
| /*********************************************************************** |
| * ScaleWindowExtEx (GDI.485) |
| */ |
| BOOL ScaleWindowExtEx( HDC hdc, short xNum, short xDenom, |
| short yNum, short yDenom, LPSIZE size ) |
| { |
| DC * dc = (DC *) GDI_GetObjPtr( hdc, DC_MAGIC ); |
| if (!dc) return FALSE; |
| if (size) |
| { |
| size->cx = dc->w.WndExtX; |
| size->cy = dc->w.WndExtY; |
| } |
| if ((dc->w.MapMode != MM_ISOTROPIC) && (dc->w.MapMode != MM_ANISOTROPIC)) |
| return TRUE; |
| if (!xNum || !xDenom || !xNum || !yDenom) return FALSE; |
| dc->w.WndExtX = (dc->w.WndExtX * xNum) / xDenom; |
| dc->w.WndExtY = (dc->w.WndExtY * yNum) / yDenom; |
| if (dc->w.WndExtX == 0) dc->w.WndExtX = 1; |
| if (dc->w.WndExtY == 0) dc->w.WndExtY = 1; |
| if (dc->w.MapMode == MM_ISOTROPIC) MAPPING_FixIsotropic( dc ); |
| return TRUE; |
| } |