macOS: Move NSOpenGLPixelFormat creation back into QCocoaGLContext
The code was factored out in0058f00b6
to be shared with Wayland, but the Wayland platform plugin now lives in its own repository (as of75a66c3d
), and doesn't support running on macOS anymore. Change-Id: Ied54f5f3e0a3e6fdaaedfcd456a140b46706f33c Reviewed-by: Simon Hausmann <simon.hausmann@qt.io> Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
This commit is contained in:
parent
cda9bd664d
commit
40fe5d43fd
@ -1,135 +0,0 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2016 The Qt Company Ltd.
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** This file is part of the plugins of the Qt Toolkit.
|
||||
**
|
||||
** $QT_BEGIN_LICENSE:LGPL$
|
||||
** Commercial License Usage
|
||||
** Licensees holding valid commercial Qt licenses may use this file in
|
||||
** accordance with the commercial license agreement provided with the
|
||||
** Software or, alternatively, in accordance with the terms contained in
|
||||
** a written agreement between you and The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU Lesser General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU Lesser
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.LGPL3 included in the
|
||||
** packaging of this file. Please review the following information to
|
||||
** ensure the GNU Lesser General Public License version 3 requirements
|
||||
** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 2.0 or (at your option) the GNU General
|
||||
** Public license version 3 or any later version approved by the KDE Free
|
||||
** Qt Foundation. The licenses are as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-2.0.html and
|
||||
** https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
** $QT_END_LICENSE$
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#include "cglconvenience_p.h"
|
||||
#include <QtCore/qglobal.h>
|
||||
#include <QtCore/private/qcore_mac_p.h>
|
||||
#include <AppKit/AppKit.h>
|
||||
#include <QVector>
|
||||
#include <qdebug.h>
|
||||
|
||||
// Match up with createNSOpenGLPixelFormat below!
|
||||
QSurfaceFormat qcgl_surfaceFormat()
|
||||
{
|
||||
QSurfaceFormat format;
|
||||
format.setRenderableType(QSurfaceFormat::OpenGL);
|
||||
format.setRedBufferSize(8);
|
||||
format.setGreenBufferSize(8);
|
||||
format.setBlueBufferSize(8);
|
||||
format.setAlphaBufferSize(8);
|
||||
/*
|
||||
format.setDepthBufferSize(24);
|
||||
format.setAccumBufferSize(0);
|
||||
format.setStencilBufferSize(8);
|
||||
format.setSampleBuffers(false);
|
||||
format.setSamples(1);
|
||||
format.setDepth(true);
|
||||
format.setRgba(true);
|
||||
format.setAlpha(true);
|
||||
format.setAccum(false);
|
||||
format.setStencil(true);
|
||||
format.setStereo(false);
|
||||
format.setDirectRendering(false);
|
||||
*/
|
||||
return format;
|
||||
}
|
||||
|
||||
void *qcgl_createNSOpenGLPixelFormat(const QSurfaceFormat &format)
|
||||
{
|
||||
|
||||
QVector<NSOpenGLPixelFormatAttribute> attrs;
|
||||
|
||||
if (format.swapBehavior() == QSurfaceFormat::DoubleBuffer
|
||||
|| format.swapBehavior() == QSurfaceFormat::DefaultSwapBehavior)
|
||||
attrs.append(NSOpenGLPFADoubleBuffer);
|
||||
else if (format.swapBehavior() == QSurfaceFormat::TripleBuffer)
|
||||
attrs.append(NSOpenGLPFATripleBuffer);
|
||||
|
||||
|
||||
// Select OpenGL profile
|
||||
attrs << NSOpenGLPFAOpenGLProfile;
|
||||
if (format.profile() == QSurfaceFormat::CoreProfile) {
|
||||
if (format.version() >= qMakePair(4, 1))
|
||||
attrs << NSOpenGLProfileVersion4_1Core;
|
||||
else if (format.version() >= qMakePair(3, 2))
|
||||
attrs << NSOpenGLProfileVersion3_2Core;
|
||||
else
|
||||
attrs << NSOpenGLProfileVersionLegacy;
|
||||
} else {
|
||||
attrs << NSOpenGLProfileVersionLegacy;
|
||||
}
|
||||
|
||||
if (format.depthBufferSize() > 0)
|
||||
attrs << NSOpenGLPFADepthSize << format.depthBufferSize();
|
||||
if (format.stencilBufferSize() > 0)
|
||||
attrs << NSOpenGLPFAStencilSize << format.stencilBufferSize();
|
||||
if (format.alphaBufferSize() > 0)
|
||||
attrs << NSOpenGLPFAAlphaSize << format.alphaBufferSize();
|
||||
if ((format.redBufferSize() > 0) &&
|
||||
(format.greenBufferSize() > 0) &&
|
||||
(format.blueBufferSize() > 0)) {
|
||||
const int colorSize = format.redBufferSize() +
|
||||
format.greenBufferSize() +
|
||||
format.blueBufferSize();
|
||||
attrs << NSOpenGLPFAColorSize << colorSize << NSOpenGLPFAMinimumPolicy;
|
||||
}
|
||||
|
||||
if (format.samples() > 0) {
|
||||
attrs << NSOpenGLPFAMultisample
|
||||
<< NSOpenGLPFASampleBuffers << (NSOpenGLPixelFormatAttribute) 1
|
||||
<< NSOpenGLPFASamples << (NSOpenGLPixelFormatAttribute) format.samples();
|
||||
}
|
||||
|
||||
if (format.stereo())
|
||||
attrs << NSOpenGLPFAStereo;
|
||||
|
||||
attrs << NSOpenGLPFAAllowOfflineRenderers;
|
||||
|
||||
QByteArray useLayer = qgetenv("QT_MAC_WANTS_LAYER");
|
||||
if (!useLayer.isEmpty() && useLayer.toInt() > 0) {
|
||||
// Disable the software rendering fallback. This makes compositing
|
||||
// OpenGL and raster NSViews using Core Animation layers possible.
|
||||
attrs << NSOpenGLPFANoRecovery;
|
||||
}
|
||||
|
||||
attrs << 0;
|
||||
|
||||
NSOpenGLPixelFormat* pixelFormat = [[NSOpenGLPixelFormat alloc] initWithAttributes:attrs.constData()];
|
||||
return pixelFormat;
|
||||
}
|
@ -1,17 +0,0 @@
|
||||
TARGET = QtCglSupport
|
||||
MODULE = cgl_support
|
||||
|
||||
QT = core-private gui
|
||||
CONFIG += static internal_module
|
||||
|
||||
DEFINES += QT_NO_CAST_FROM_ASCII
|
||||
|
||||
HEADERS += \
|
||||
cglconvenience_p.h
|
||||
|
||||
OBJECTIVE_SOURCES += \
|
||||
cglconvenience.mm
|
||||
|
||||
LIBS_PRIVATE += -framework AppKit -framework OpenGL
|
||||
|
||||
load(qt_module)
|
@ -1,61 +0,0 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2016 The Qt Company Ltd.
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** This file is part of the plugins of the Qt Toolkit.
|
||||
**
|
||||
** $QT_BEGIN_LICENSE:LGPL$
|
||||
** Commercial License Usage
|
||||
** Licensees holding valid commercial Qt licenses may use this file in
|
||||
** accordance with the commercial license agreement provided with the
|
||||
** Software or, alternatively, in accordance with the terms contained in
|
||||
** a written agreement between you and The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU Lesser General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU Lesser
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.LGPL3 included in the
|
||||
** packaging of this file. Please review the following information to
|
||||
** ensure the GNU Lesser General Public License version 3 requirements
|
||||
** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 2.0 or (at your option) the GNU General
|
||||
** Public license version 3 or any later version approved by the KDE Free
|
||||
** Qt Foundation. The licenses are as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-2.0.html and
|
||||
** https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
** $QT_END_LICENSE$
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef QMACGLCONVENIENCE_H
|
||||
#define QMACGLCONVENIENCE_H
|
||||
|
||||
//
|
||||
// W A R N I N G
|
||||
// -------------
|
||||
//
|
||||
// This file is not part of the Qt API. It exists purely as an
|
||||
// implementation detail. This header file may change from version to
|
||||
// version without notice, or even be removed.
|
||||
//
|
||||
// We mean it.
|
||||
//
|
||||
|
||||
#include <QSurfaceFormat>
|
||||
#include <QString>
|
||||
#include <OpenGL/OpenGL.h>
|
||||
|
||||
QSurfaceFormat qcgl_surfaceFormat();
|
||||
void *qcgl_createNSOpenGLPixelFormat(const QSurfaceFormat &format);
|
||||
|
||||
#endif // QMACGLCONVENIENCE_H
|
@ -40,8 +40,6 @@ darwin {
|
||||
SUBDIRS += \
|
||||
clipboard \
|
||||
graphics
|
||||
macos: \
|
||||
SUBDIRS += cglconvenience
|
||||
}
|
||||
|
||||
qtConfig(vulkan): \
|
||||
|
@ -80,7 +80,7 @@ LIBS += -framework AppKit -framework Carbon -framework IOKit -lcups
|
||||
QT += \
|
||||
core-private gui-private \
|
||||
accessibility_support-private clipboard_support-private theme_support-private \
|
||||
fontdatabase_support-private graphics_support-private cgl_support-private
|
||||
fontdatabase_support-private graphics_support-private
|
||||
|
||||
CONFIG += no_app_extension_api_only
|
||||
|
||||
|
@ -42,7 +42,6 @@
|
||||
#include "qcocoahelpers.h"
|
||||
#include <qdebug.h>
|
||||
#include <QtCore/private/qcore_mac_p.h>
|
||||
#include <QtCglSupport/private/cglconvenience_p.h>
|
||||
#include <QtPlatformHeaders/qcocoanativecontext.h>
|
||||
#include <dlfcn.h>
|
||||
|
||||
@ -154,7 +153,7 @@ QCocoaGLContext::QCocoaGLContext(const QSurfaceFormat &format, QPlatformOpenGLCo
|
||||
QMacAutoReleasePool pool; // For the SG Canvas render thread
|
||||
|
||||
// create native context for the requested pixel format and share
|
||||
NSOpenGLPixelFormat *pixelFormat = static_cast <NSOpenGLPixelFormat *>(qcgl_createNSOpenGLPixelFormat(m_format));
|
||||
NSOpenGLPixelFormat *pixelFormat = createNSOpenGLPixelFormat(m_format);
|
||||
m_shareContext = share ? static_cast<QCocoaGLContext *>(share)->nsOpenGLContext() : nil;
|
||||
m_context = [[NSOpenGLContext alloc] initWithFormat:pixelFormat shareContext:m_shareContext];
|
||||
|
||||
@ -202,7 +201,6 @@ QVariant QCocoaGLContext::nativeHandle() const
|
||||
return QVariant::fromValue<QCocoaNativeContext>(QCocoaNativeContext(m_context));
|
||||
}
|
||||
|
||||
// Match up with createNSOpenGLPixelFormat!
|
||||
QSurfaceFormat QCocoaGLContext::format() const
|
||||
{
|
||||
return m_format;
|
||||
@ -362,7 +360,64 @@ void QCocoaGLContext::update()
|
||||
|
||||
NSOpenGLPixelFormat *QCocoaGLContext::createNSOpenGLPixelFormat(const QSurfaceFormat &format)
|
||||
{
|
||||
return static_cast<NSOpenGLPixelFormat *>(qcgl_createNSOpenGLPixelFormat(format));
|
||||
QVector<NSOpenGLPixelFormatAttribute> attrs;
|
||||
|
||||
if (format.swapBehavior() == QSurfaceFormat::DoubleBuffer
|
||||
|| format.swapBehavior() == QSurfaceFormat::DefaultSwapBehavior)
|
||||
attrs.append(NSOpenGLPFADoubleBuffer);
|
||||
else if (format.swapBehavior() == QSurfaceFormat::TripleBuffer)
|
||||
attrs.append(NSOpenGLPFATripleBuffer);
|
||||
|
||||
|
||||
// Select OpenGL profile
|
||||
attrs << NSOpenGLPFAOpenGLProfile;
|
||||
if (format.profile() == QSurfaceFormat::CoreProfile) {
|
||||
if (format.version() >= qMakePair(4, 1))
|
||||
attrs << NSOpenGLProfileVersion4_1Core;
|
||||
else if (format.version() >= qMakePair(3, 2))
|
||||
attrs << NSOpenGLProfileVersion3_2Core;
|
||||
else
|
||||
attrs << NSOpenGLProfileVersionLegacy;
|
||||
} else {
|
||||
attrs << NSOpenGLProfileVersionLegacy;
|
||||
}
|
||||
|
||||
if (format.depthBufferSize() > 0)
|
||||
attrs << NSOpenGLPFADepthSize << format.depthBufferSize();
|
||||
if (format.stencilBufferSize() > 0)
|
||||
attrs << NSOpenGLPFAStencilSize << format.stencilBufferSize();
|
||||
if (format.alphaBufferSize() > 0)
|
||||
attrs << NSOpenGLPFAAlphaSize << format.alphaBufferSize();
|
||||
if ((format.redBufferSize() > 0) &&
|
||||
(format.greenBufferSize() > 0) &&
|
||||
(format.blueBufferSize() > 0)) {
|
||||
const int colorSize = format.redBufferSize() +
|
||||
format.greenBufferSize() +
|
||||
format.blueBufferSize();
|
||||
attrs << NSOpenGLPFAColorSize << colorSize << NSOpenGLPFAMinimumPolicy;
|
||||
}
|
||||
|
||||
if (format.samples() > 0) {
|
||||
attrs << NSOpenGLPFAMultisample
|
||||
<< NSOpenGLPFASampleBuffers << (NSOpenGLPixelFormatAttribute) 1
|
||||
<< NSOpenGLPFASamples << (NSOpenGLPixelFormatAttribute) format.samples();
|
||||
}
|
||||
|
||||
if (format.stereo())
|
||||
attrs << NSOpenGLPFAStereo;
|
||||
|
||||
attrs << NSOpenGLPFAAllowOfflineRenderers;
|
||||
|
||||
QByteArray useLayer = qgetenv("QT_MAC_WANTS_LAYER");
|
||||
if (!useLayer.isEmpty() && useLayer.toInt() > 0) {
|
||||
// Disable the software rendering fallback. This makes compositing
|
||||
// OpenGL and raster NSViews using Core Animation layers possible.
|
||||
attrs << NSOpenGLPFANoRecovery;
|
||||
}
|
||||
|
||||
attrs << 0;
|
||||
|
||||
return [[NSOpenGLPixelFormat alloc] initWithAttributes:attrs.constData()];
|
||||
}
|
||||
|
||||
NSOpenGLContext *QCocoaGLContext::nsOpenGLContext() const
|
||||
|
Loading…
Reference in New Issue
Block a user