Merge pull request #668 from campagnola/mshunshin-hidpi_fix
OpenGL high-dpi fix
This commit is contained in:
commit
9fd9e9a1b3
@ -16,9 +16,13 @@ class GLViewWidget(QtOpenGL.QGLWidget):
|
|||||||
- Axis/grid display
|
- Axis/grid display
|
||||||
- Export options
|
- Export options
|
||||||
|
|
||||||
|
|
||||||
|
High-DPI displays: Qt5 should automatically detect the correct resolution.
|
||||||
|
For Qt4, specify the ``devicePixelRatio`` argument when initializing the
|
||||||
|
widget (usually this value is 1-2).
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, parent=None):
|
def __init__(self, parent=None, devicePixelRatio=None):
|
||||||
global ShareWidget
|
global ShareWidget
|
||||||
|
|
||||||
if ShareWidget is None:
|
if ShareWidget is None:
|
||||||
@ -37,6 +41,7 @@ class GLViewWidget(QtOpenGL.QGLWidget):
|
|||||||
'azimuth': 45, ## camera's azimuthal angle in degrees
|
'azimuth': 45, ## camera's azimuthal angle in degrees
|
||||||
## (rotation around z-axis 0 points along x-axis)
|
## (rotation around z-axis 0 points along x-axis)
|
||||||
'viewport': None, ## glViewport params; None == whole widget
|
'viewport': None, ## glViewport params; None == whole widget
|
||||||
|
'devicePixelRatio': devicePixelRatio,
|
||||||
}
|
}
|
||||||
self.setBackgroundColor('k')
|
self.setBackgroundColor('k')
|
||||||
self.items = []
|
self.items = []
|
||||||
@ -79,10 +84,21 @@ class GLViewWidget(QtOpenGL.QGLWidget):
|
|||||||
|
|
||||||
def getViewport(self):
|
def getViewport(self):
|
||||||
vp = self.opts['viewport']
|
vp = self.opts['viewport']
|
||||||
|
dpr = self.devicePixelRatio()
|
||||||
if vp is None:
|
if vp is None:
|
||||||
return (0, 0, self.width(), self.height())
|
return (0, 0, int(self.width() * dpr), int(self.height() * dpr))
|
||||||
else:
|
else:
|
||||||
return vp
|
return tuple([int(x * dpr) for x in vp])
|
||||||
|
|
||||||
|
def devicePixelRatio(self):
|
||||||
|
dpr = self.opts['devicePixelRatio']
|
||||||
|
if dpr is not None:
|
||||||
|
return dpr
|
||||||
|
|
||||||
|
if hasattr(QtOpenGL.QGLWidget, 'devicePixelRatio'):
|
||||||
|
return QtOpenGL.QGLWidget.devicePixelRatio(self)
|
||||||
|
else:
|
||||||
|
return 1.0
|
||||||
|
|
||||||
def resizeGL(self, w, h):
|
def resizeGL(self, w, h):
|
||||||
pass
|
pass
|
||||||
@ -99,7 +115,8 @@ class GLViewWidget(QtOpenGL.QGLWidget):
|
|||||||
def projectionMatrix(self, region=None):
|
def projectionMatrix(self, region=None):
|
||||||
# Xw = (Xnd + 1) * width/2 + X
|
# Xw = (Xnd + 1) * width/2 + X
|
||||||
if region is None:
|
if region is None:
|
||||||
region = (0, 0, self.width(), self.height())
|
dpr = self.devicePixelRatio()
|
||||||
|
region = (0, 0, self.width() * dpr, self.height() * dpr)
|
||||||
|
|
||||||
x0, y0, w, h = self.getViewport()
|
x0, y0, w, h = self.getViewport()
|
||||||
dist = self.opts['distance']
|
dist = self.opts['distance']
|
||||||
|
@ -122,7 +122,7 @@ if HAVE_OPENGL:
|
|||||||
if not self.uploaded:
|
if not self.uploaded:
|
||||||
self.uploadTexture()
|
self.uploadTexture()
|
||||||
|
|
||||||
glViewport(0, 0, self.width(), self.height())
|
glViewport(0, 0, self.width() * self.devicePixelRatio(), self.height() * self.devicePixelRatio())
|
||||||
glEnable(GL_TEXTURE_2D)
|
glEnable(GL_TEXTURE_2D)
|
||||||
glBindTexture(GL_TEXTURE_2D, self.texture)
|
glBindTexture(GL_TEXTURE_2D, self.texture)
|
||||||
glColor4f(1,1,1,1)
|
glColor4f(1,1,1,1)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user