本文整理匯總了Python中PyQt5.QtGui.QOpenGLContext.swapBuffers方法的典型用法代碼示例。如果您正苦於以下問題:Python QOpenGLContext.swapBuffers方法的具體用法?Python QOpenGLContext.swapBuffers怎麽用?Python QOpenGLContext.swapBuffers使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類PyQt5.QtGui.QOpenGLContext
的用法示例。
在下文中一共展示了QOpenGLContext.swapBuffers方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: OpenGLWindow
# 需要導入模塊: from PyQt5.QtGui import QOpenGLContext [as 別名]
# 或者: from PyQt5.QtGui.QOpenGLContext import swapBuffers [as 別名]
#.........這裏部分代碼省略.........
def paint(self, painter):
pass
def render(self, gl):
pass
def addGlFunctuins(self, GL, functions):
for function, arguments in functions.items():
GL[function].restype = None
GL[function].argtypes = arguments
setattr(self.m_gl, function, GL[function])
@exitOnKeyboardInterrupt
def renderNow(self):
if not self.isExposed():
return
self.m_update_pending = False
needsInitialize = False
if self.m_context is None:
self.m_context = QOpenGLContext(self)
self.m_context.setFormat(self.requestedFormat())
self.m_context.create()
needsInitialize = True
self.m_context.makeCurrent(self)
if needsInitialize:
# Sorry, no support for higher versions for now.
profile = QOpenGLVersionProfile()
profile.setVersion(2, 0)
self.m_gl = self.m_context.versionFunctions(profile)
self.m_gl.initializeOpenGLFunctions()
#print(self.m_context.hasExtension('GL_EXT_framebuffer_object'))
#print(self.m_context.hasExtension('GL_ARB_texture_float'))
#print(*sorted(self.m_context.extensions()), sep='\n')
# Small hack. Guess noone mind?
import ctypes
import ctypes.util
GL = ctypes.CDLL(ctypes.util.find_library('GL'))
self.addGlFunctuins(GL, {
'glFramebufferTexture2D': (ctypes.c_uint, ctypes.c_uint, ctypes.c_uint, ctypes.c_uint, ctypes.c_int)
})
self.logger = QOpenGLDebugLogger()
self.logger.initialize()
self.logger.loggedMessages()
self.logger.messageLogged.connect(self.handleLoggedMassage)
self.logger.startLogging()
self.initialize(self.m_gl)
if not self.m_device:
self.m_device = QOpenGLPaintDevice()
self.m_gl.glClear(self.m_gl.GL_COLOR_BUFFER_BIT | self.m_gl.GL_DEPTH_BUFFER_BIT);
self.m_device.setSize(self.size())
painter = QPainter(self.m_device)
painter.beginNativePainting()
self.render(self.m_gl)
painter.endNativePainting()
self.paint(painter)
self.m_context.swapBuffers(self)
if self.m_animating:
self.renderLater()
def handleLoggedMassage(self, message):
# This three really annoyng and brings no useful info =\
if not (message.message().find('Use glDrawRangeElements() to avoid this.') > -1 or
message.message().find('CPU mapping a busy miptree') > -1 or
message.message().find('Flushing before mapping a referenced bo.') > -1
):
print(message.message().strip())
def event(self, event):
if event.type() == QEvent.UpdateRequest:
self.renderNow()
return True
return super(OpenGLWindow, self).event(event)
def exposeEvent(self, event):
self.renderNow()
def resizeEvent(self, event):
self.renderNow()
示例2: OpenGLWindow
# 需要導入模塊: from PyQt5.QtGui import QOpenGLContext [as 別名]
# 或者: from PyQt5.QtGui.QOpenGLContext import swapBuffers [as 別名]
class OpenGLWindow(QWindow):
def __init__(self, parent=None):
super(OpenGLWindow, self).__init__(parent)
self.m_update_pending = False
self.m_animating = False
self.m_context = None
self.m_gl = None
self.setSurfaceType(QWindow.OpenGLSurface)
def initialize(self):
pass
def setAnimating(self, animating):
self.m_animating = animating
if animating:
self.renderLater()
def renderLater(self):
if not self.m_update_pending:
self.m_update_pending = True
QGuiApplication.postEvent(self, QEvent(QEvent.UpdateRequest))
def renderNow(self):
if not self.isExposed():
return
self.m_update_pending = False
needsInitialize = False
if self.m_context is None:
self.m_context = QOpenGLContext(self)
self.m_context.setFormat(self.requestedFormat())
self.m_context.create()
needsInitialize = True
self.m_context.makeCurrent(self)
if needsInitialize:
self.m_gl = self.m_context.versionFunctions()
self.m_gl.initializeOpenGLFunctions()
self.initialize()
self.render(self.m_gl)
self.m_context.swapBuffers(self)
if self.m_animating:
self.renderLater()
def event(self, event):
if event.type() == QEvent.UpdateRequest:
self.renderNow()
return True
return super(OpenGLWindow, self).event(event)
def exposeEvent(self, event):
self.renderNow()
def resizeEvent(self, event):
self.renderNow()
示例3: ViewerWindow
# 需要導入模塊: from PyQt5.QtGui import QOpenGLContext [as 別名]
# 或者: from PyQt5.QtGui.QOpenGLContext import swapBuffers [as 別名]
#.........這裏部分代碼省略.........
self.update_view_matrix()
self.last_mouse_pos = 0,0
self.on_resize(*self.size)
def render(self):
if not self.isExposed():
return
self.context.makeCurrent(self)
bits = 0
bits |= gl.GL_COLOR_BUFFER_BIT
bits |= gl.GL_DEPTH_BUFFER_BIT
bits |= gl.GL_STENCIL_BUFFER_BIT
gl.glClear(bits)
gl.glEnable(gl.GL_PROGRAM_POINT_SIZE)
for program in self.layer_manager.programs():
if program.do_blending:
if self.bg_white:
gl.glEnable(gl.GL_BLEND)
gl.glBlendFunc(gl.GL_SRC_ALPHA, gl.GL_SRC_ALPHA)
else:
gl.glEnable(gl.GL_BLEND)
gl.glBlendFunc(gl.GL_ONE, gl.GL_SRC_ALPHA)
else:
gl.glDisable(gl.GL_BLEND)
self.layer_manager.draw()
if self.hud_program.is_visible:
self.hud_program.draw()
self.context.swapBuffers(self)
def event(self, event):
# print event.type()
if event.type() == QEvent.UpdateRequest:
self.render()
return True
return super(ViewerWindow, self).event(event)
def exposeEvent(self, event):
self.render()
def resizeEvent(self, event):
size = event.size()
self.on_resize(size.width(), size.height())
self.render()
def update_view_matrix(self):
self.view = np.eye(4, dtype=np.float32)
translate(self.view, self.translation[0], self.translation[1], self.translation[2] )
scale(self.view, self.scale, self.scale, self.scale)
self.view = self.view.dot( np.array(q.matrix(self.rotation), dtype=np.float32) )
# translate(self.view, -self.translation[0], -self.translation[1], -self.translation[2] )
translate(self.view, 0,0, self.camera_position)
for program in self.layer_manager.programs():
program.setUniform('u_view', self.view)
if program.draw_type == 'points':
program.setUniform('u_model_scale', self.scale)
def update_projection_matrix(self):
view_width, view_height = [x/self.radius for x in self.size]