QSGRenderNode Class

QSGRenderNode 클래스는 시나리오 그래프에서 사용 중인 그래픽 API를 대상으로 하는 커스텀 렌더링 명령 집합을 나타냅니다. 더 보기...

헤더: #include <QSGRenderNode>
CMake: find_package(Qt6 REQUIRED COMPONENTS Quick)
target_link_libraries(mytarget PRIVATE Qt6::Quick)
qmake: QT += quick
상속합니다: QSGNode

공용 타입

struct RenderState
enum RenderingFlag { BoundedRectRendering, DepthAwareRendering, OpaqueRendering, NoExternalRendering }
flags RenderingFlags
enum StateFlag { ViewportState, ScissorState, DepthState, StencilState, ColorState, …, RenderTargetState }
flags StateFlags

공용 함수

virtual ~QSGRenderNode() override
virtual QSGRenderNode::StateFlags changedStates() const
const QSGClipNode *clipList() const
(since 6.6) QRhiCommandBuffer *commandBuffer() const
virtual QSGRenderNode::RenderingFlags flags() const
qreal inheritedOpacity() const
const QMatrix4x4 *matrix() const
(since 6.0) virtual void prepare()
(since 6.5) const QMatrix4x4 *projectionMatrix() const
virtual QRectF rect() const
virtual void releaseResources()
virtual void render(const QSGRenderNode::RenderState *state) = 0
(since 6.6) QRhiRenderTarget *renderTarget() const

상세 설명

QSGRenderNode는 QRhi (Qt 6.6 이후의 일반적인 접근 방식)를 통해, OpenGL, Vulkan, Metal 등의 3D 그래픽 API를 통해 직접, 또는 software 백엔드가 사용중인 경우 QPainter 를 통해 자체 커스텀 렌더링을 수행하는 씬 그래프 노드를 만들 수 있습니다.

QSGRenderNode는 사용자 정의 2D/3D 렌더링을 Qt Quick 씬에 통합하는 세 가지 방법 중 하나를 가능하게 합니다. 다른 두 가지 옵션은 before 또는 after 씬의 자체 렌더링을 수행하거나 Qt Quick 씬의 전용 렌더링 대상(텍스처)을 대상으로 별도의 렌더 패스를 생성한 다음 씬의 항목에 텍스처를 표시하도록 하는 것입니다. QSGRenderNode 기반 접근 방식은 추가 렌더 패스나 렌더 타깃이 포함되지 않는다는 점에서 전자와 유사하며, Qt Quick 씬의 자체 렌더링에 사용자 지정 렌더링 명령을 "인라인"으로 삽입할 수 있습니다. 세 가지 접근 방식에 대한 자세한 내용은 Qt Quick 씬 그래프를 참조하세요.

씬 그래프 - 커스텀 QSGRenderNode도참조하십시오 .

멤버 유형 문서

열거형 QSGRenderNode::렌더링플래그
플래그 QSGRenderNode::렌더링플래그

flags()에서 반환된 비트마스크의 가능한 값입니다.

Constant설명
QSGRenderNode::BoundedRectRendering0x01render()의 구현이 아이템 좌표에서 rect()에서 보고된 영역 밖에서는 렌더링하지 않음을 나타냅니다. 이러한 노드 구현은 시나리오 백엔드에 따라 더 효율적인 렌더링으로 이어질 수 있습니다. 예를 들어, 씬의 모든 렌더 노드에 이 플래그가 설정되어 있으면 software 백엔드는 보다 최적화된 부분 업데이트 경로를 계속 사용할 수 있습니다.
QSGRenderNode::DepthAwareRendering0x02render()의 구현이 RenderState::projectionMatrix() 및 matrix()에서 검색된 행렬에 의해 변환된 다음 render()의 참고 사항에 설명된 대로 씬 좌표에서 0의 Z 값만 생성하여 시나리오 그래프 기대치를 준수함을 나타냅니다. 이러한 노드 구현은 시나리오 백엔드에 따라 보다 효율적인 렌더링으로 이어질 수 있습니다. 예를 들어, 씬의 모든 렌더 노드에 이 플래그가 설정되어 있으면 일괄 처리 OpenGL 렌더러가 계속해서 최적의 경로를 사용할 수 있습니다.
QSGRenderNode::OpaqueRendering0x04render()의 구현이 rect()에서 보고된 전체 영역에 대해 불투명 픽셀을 출력함을 나타냅니다. 기본적으로 렌더러는 render()가 반투명 또는 완전 투명 픽셀도 출력할 수 있다고 가정해야 합니다. 이 플래그를 설정하면 경우에 따라 성능이 향상될 수 있습니다.
QSGRenderNode::NoExternalRendering0x08prepare() 및 render()의 구현이 OpenGL, Vulkan 또는 Metal과 같은 3D API를 직접 호출하는 대신 QRhi API 제품군을 독점적으로 사용함을 나타냅니다.

RenderingFlags 유형은 QFlags<RenderingFlag>에 대한 typedef입니다. RenderingFlag 값의 OR 조합을 저장합니다.

render(), prepare(), rect() 및 QRhi참조하십시오 .

열거형 QSGRenderNode::StateFlag
플래그 QSGRenderNode::StateFlags

이 열거형에는 changedStates()에서 반환된 비트마스크에 사용할 수 있는 값이 들어 있습니다.

Constant설명
QSGRenderNode::ViewportState0x40뷰포트
QSGRenderNode::ScissorState0x04시저 테스트 활성화 상태, 시저 사각형
QSGRenderNode::DepthState0x01이 값은 Qt 6에서는 영향을 미치지 않습니다.
QSGRenderNode::StencilState0x02이 값은 Qt 6에서는 영향을 미치지 않습니다.
QSGRenderNode::ColorState0x08이 값은 Qt 6에서 적용되지 않습니다.
QSGRenderNode::BlendState0x10이 값은 Qt 6에서 영향을 미치지 않습니다.
QSGRenderNode::CullState0x20이 값은 Qt 6에서 영향을 미치지 않습니다.
QSGRenderNode::RenderTargetState0x80이 값은 Qt 6에서 영향을 미치지 않습니다.

StateFlags 유형은 QFlags<StateFlag>에 대한 typedef입니다. StateFlag 값의 OR 조합을 저장합니다.

멤버 함수 문서

[override virtual noexcept] QSGRenderNode::~QSGRenderNode()

렌더 노드를 파괴합니다. 파생 클래스는 여기서 releaseResources()와 유사한 정리를 수행해야 합니다.

QRhiQRhiBuffer, QRhiTexture, QRhiGraphicsPipeline 등과 같은 리소스에서는 종종 소멸자를 구현할 필요가 없고 소스 코드가 더 간결해질 수 있는 std::unique_ptr과 같은 스마트 포인터를 사용하는 것이 좋은 관행입니다. 그러나 고유_ptrs에 여러 번의 reset() 호출을 포함하는 releaseResources() 구현은 여전히 중요하다는 점에 유의하세요.

releaseResources()도 참조하세요 .

[virtual] QSGRenderNode::StateFlags QSGRenderNode::changedStates() const

이 함수는 render() 함수에 의해 변경된 그래픽 상태를 나타내는 각 비트를 나타내는 마스크를 반환해야 합니다.

참고: Qt 6 및 QRhi 기반 렌더링에서 관련 값은 ViewportStateScissorState 뿐입니다. 다른 값도 반환될 수 있지만 실제로는 무시됩니다.

Constant설명
ViewportState뷰포트
ScissorState가위 테스트 활성화 상태, 가위 사각형
DepthState이 값은 Qt 6에서는 영향을 미치지 않습니다.
StencilState이 값은 Qt 6에서는 영향을 미치지 않습니다.
ColorState이 값은 Qt 6에서 적용되지 않습니다.
BlendState이 값은 Qt 6에서 영향을 미치지 않습니다.
CullState이 값은 Qt 6에서 영향을 미치지 않습니다.
RenderTargetState이 값은 Qt 6에서 적용되지 않습니다.

참고: software 백엔드는 QPainter 을 노출하고 render() 호출 전후에 저장 및 복원합니다. 따라서 여기에서 변경된 상태를 보고할 필요는 없습니다.

기본 구현은 render()에서 관련 상태가 변경되지 않았음을 의미하는 0을 반환합니다.

참고: 이 함수는 render() 전에 호출할 수 있습니다.

const QSGClipNode *QSGRenderNode::clipList() const

현재 클립 목록을 반환합니다.

[since 6.6] QRhiCommandBuffer *QSGRenderNode::commandBuffer() const

현재 명령 버퍼를 반환합니다.

이 함수는 Qt 6.6에 도입되었습니다.

renderTarget()도 참조하십시오 .

[virtual] QSGRenderNode::RenderingFlags QSGRenderNode::flags() const

이 렌더 노드의 동작을 설명하는 플래그를 반환합니다.

기본 구현은 0을 반환합니다.

RenderingFlagrect()도 참조하세요 .

qreal QSGRenderNode::inheritedOpacity() const

현재 유효 불투명도를 반환합니다.

const QMatrix4x4 *QSGRenderNode::matrix() const

현재 모델 뷰 행렬에 대한 포인터를 반환합니다.

[virtual, since 6.0] void QSGRenderNode::prepare()

프레임 준비 단계에서 호출됩니다. render ()를 호출할 때마다 이 함수가 호출됩니다.

render()와 달리 이 함수는 시나리오 그래프가 기본 명령 버퍼에 현재 프레임에 대한 렌더 패스를 기록하기 시작하기 전에 호출됩니다. 이 함수는 렌더링 패스 전에 복사 유형의 연산을 기록해야 하는 Vulkan과 같은 그래픽 API로 렌더링을 수행할 때 유용합니다.

기본 구현은 비어 있습니다.

QRhi 을 사용하여 렌더링하는 QSGRenderNode 을 구현할 때는 QQuickWindow::rhi()를 통해 QQuickWindow 에서 QRhi 객체를 쿼리합니다. 작업을 제출할 QRhiCommandBuffer 을 얻으려면 commandBuffer()을 호출합니다. 활성 렌더링 대상에 대한 정보를 쿼리하려면 renderTarget()를 호출합니다. 자세한 내용은 {씬 그래프 - 커스텀 QSGRenderNode} 예제를 참조하십시오.

이 함수는 Qt 6.0에 도입되었습니다.

[since 6.5] const QMatrix4x4 *QSGRenderNode::projectionMatrix() const

현재 투영 행렬에 대한 포인터를 반환합니다.

render()에서 이 행렬은 RenderState::projectionMatrix()에서 반환되는 것과 동일한 행렬입니다. 이 게터는 prepare()에서도 투영 행렬을 쿼리할 수 있도록 존재합니다.

최신 그래픽 API 또는 Qt의 자체 그래픽 추상화 레이어로 작업할 때 *projectionMatrix() * *matrix() 을 균일한 버퍼에 로드하고 싶을 가능성이 높습니다. 그러나 이는 prepare()에서 수행해야 하는 작업이므로 렌더링 패스의 기록 외부에서 수행해야 합니다. 따라서 prepare() 및 render()에서 두 행렬을 모두 QSGRenderNode 에서 직접 쿼리할 수 있습니다.

이 함수는 Qt 6.5에 도입되었습니다.

[virtual] QRectF QSGRenderNode::rect() const

render()가 터치하는 영역의 경계 사각형을 항목 좌표로 반환합니다. 이 값은 flags()에 BoundedRectRendering 이 포함된 경우에만 사용되며, 그렇지 않은 경우에는 무시됩니다.

BoundedRectRendering 와 함께 사각형을 보고하는 것은 software 백엔드에서 특히 중요한데, 그렇지 않으면 씬에 렌더노드가 있으면 전체 화면 업데이트가 트리거되어 모든 부분 업데이트 최적화를 건너뛸 수 있기 때문입니다.

해당 QQuickItem 의 전체 영역을 커버하는 렌더노드의 경우 반환값은 (0, 0, item->width(), item->height())가 됩니다.

참고: 이 함수에서 올바르게 보고되는 한, 시나리오 그래프 노드는 QQuickItem 지오메트리에 구속되지 않으므로 항목의 너비와 높이로 지정된 경계 밖에서도 노드를 자유롭게 렌더링할 수 있습니다.

flags()도 참조하세요 .

[virtual] void QSGRenderNode::releaseResources()

이 함수는 이 노드에서 할당된 모든 커스텀 그래픽 리소스를 즉시 해제해야 할 때 호출됩니다. 노드가 사용 중인 그래픽 API를 통해 그래픽 리소스(버퍼, 텍스처, 렌더 타겟, 펜스 등)를 직접 할당하지 않는 경우에는 여기서 할 일이 없습니다.

모든 사용자 지정 리소스를 해제하지 않으면 이후 그래픽 시스템 재초기화에 실패할 수 있으므로 일부 시스템에서 그래픽 장치 손실 시나리오에서 잘못된 동작이 발생할 수 있습니다.

참고: 일부 시나리오 백엔드에서는 이 함수를 호출하지 않도록 선택할 수 있습니다. 따라서 QSGRenderNode 구현은 소멸자와 releaseResources() 모두에서 정리를 수행할 것으로 예상됩니다.

소멸자와 달리 render()는 releaseResources() 호출 후 호출될 때 필요한 모든 리소스를 다시 초기화할 수 있을 것으로 예상됩니다.

OpenGL을 사용하면 소멸자와 이 함수를 호출할 때 시나리오 그래프의 OpenGL 컨텍스트가 모두 최신 상태가 됩니다.

[pure virtual] void QSGRenderNode::render(const QSGRenderNode::RenderState *state)

이 함수는 렌더러에 의해 호출되며 QRhi 또는 기본 그래픽 API(OpenGL, Direct3D 등)를 통해 직접 호출하는 명령으로 이 노드를 페인팅해야 합니다.

유효 불투명도는 inheritedOpacity()로 검색할 수 있습니다.

투영 행렬은 state 를 통해 사용할 수 있으며, 모델 뷰 행렬은 matrix()로 가져올 수 있습니다. 그러면 결합된 행렬은 투영 행렬에 모델 보기 행렬을 곱한 값입니다. 투영 행렬에 의해 씬에서 항목의 올바른 스태킹이 보장됩니다.

제공된 행렬을 사용할 때 정점 데이터의 좌표계는 일반적인 QQuickItem 규칙을 따릅니다. 왼쪽 위는 (0, 0), 오른쪽 아래는 QQuickItem 의 너비() 및 높이()에서 1을 뺀 값에 해당합니다. 예를 들어, 버텍스 좌표 레이아웃이 두 개의 실수(x-y)라고 가정할 때 항목의 절반을 차지하는 삼각형은 시계 반대 방향을 사용하여 (너비-1, 높이-1), (0, 0), (0, 높이-1)로 지정할 수 있습니다.

참고: QSGRenderNode 은 사용자 지정 2D 또는 2.5D Qt Quick 항목을 구현하기 위한 수단으로 제공됩니다. 실제 3D 콘텐츠를 Qt Quick 장면에 통합하기 위한 것이 아닙니다. 이러한 사용 사례는 사용자 지정 렌더링을 통합하는 다른 방법으로 더 잘 지원됩니다.

참고: QSGRenderNode 은 특히 조각 처리 능력이 제한된 시스템에서 텍스처 기반 접근 방식(예: QQuickRhiItem)보다 성능이 훨씬 우수할 수 있습니다. 텍스처로 렌더링한 다음 텍스처 쿼드를 그리는 작업을 피할 수 있기 때문입니다. 대신 QSGRenderNode 을 사용하면 시나리오 그래프의 다른 명령에 따라 드로우 호출을 기록할 수 있으므로 추가 렌더링 대상과 잠재적으로 비용이 많이 드는 텍스처링 및 블렌딩을 피할 수 있습니다.

클립 정보는 함수가 호출되기 전에 계산됩니다. 클리핑을 고려하려는 구현은 state 에 있는 정보를 기반으로 시소 또는 스텐실을 설정할 수 있습니다. 스텐실 버퍼는 필요한 클립 모양으로 채워지지만, 스텐실 테스트를 활성화하는 것은 구현에 달려 있습니다.

일부 시나리오 백엔드, 특히 소프트웨어는 가위나 스텐실을 사용하지 않습니다. 이 경우 클립 영역은 일반 QRegion 으로 제공됩니다.

QRhi 을 사용하여 렌더링하는 QSGRenderNode 을 구현할 때는 QQuickWindow::rhi()를 통해 QQuickWindow 에서 QRhi 객체를 쿼리하세요. 작업을 제출할 QRhiCommandBuffer 을 얻으려면 commandBuffer()을 호출합니다. 활성 렌더링 대상에 대한 정보를 쿼리하려면 renderTarget()를 호출합니다. 자세한 내용은 {씬 그래프 - 커스텀 QSGRenderNode} 예제를 참조하십시오.

Qt 6 및 QRhi 기반 씬 그래프 렌더러를 사용하면 이 함수를 호출할 때 OpenGL이 사용 중일 때에도 활성(OpenGL) 상태에 대해 가정하지 않아야 합니다. 이 함수가 호출될 때 명령 목록/버퍼에 바인딩된 파이프라인 및 동적 상태에 대해 아무것도 가정하지 마십시오.

참고: 뎁스 쓰기는 비활성화해야 합니다. 깊이 쓰기를 활성화하면 사용 중인 시나리오 백엔드 및 씬의 콘텐츠에 따라 예기치 않은 결과가 발생할 수 있으므로 주의해야 합니다.

참고: Qt 6에서는 changedStates() 사용이 제한됩니다. 자세한 내용은 changedStates() 설명서를 참조하세요.

QRhi 를 직접 사용하는 경우를 포함하여 일부 그래픽 API의 경우 prepare() 를 추가로 다시 구현하거나 QQuickWindow::beforeRendering() 신호에 연결해야 할 수 있습니다. 이 신호는 명령 버퍼에 렌더패스의 시작을 기록하기 전에 호출/방출됩니다(Vulkan의 경우 vkCmdBeginRenderPass, Metal의 경우 MTLRenderCommandEncoder를 통해 인코딩을 시작하기 전에). 이러한 API를 사용하면 렌더() 내부에서 레코딩 복사 작업을 수행할 수 없습니다. 대신 prepare() 또는 이전 렌더링에 연결된 슬롯(DirectConnection 사용)에서 이러한 작업을 수행하세요.

QSGRendererInterfaceQQuickWindow::rendererInterface()도 참조하세요 .

[since 6.6] QRhiRenderTarget *QSGRenderNode::renderTarget() const

현재 렌더링 대상을 반환합니다.

이는 주로 QRhiRenderTargetrenderPassDescriptor 또는 pixel size 에 액세스하는 QRhi 을 사용하는 prepare() 및 render() 구현을 활성화하기 위해 제공됩니다.

QRhiRenderPassDescriptor 을 제공해야 하는 QRhiGraphicsPipeline 을 빌드하려면 렌더링 대상에서 renderPassDescriptor를 쿼리하세요. 그러나 렌더 타깃은 사용자 정의 QQuickItemQSGRenderNode 의 수명에 따라 변경될 수 있습니다. 예를 들어 항목 또는 그 조상에 layer.enabled: true 를 동적으로 설정하면 어떻게 되는지 생각해 보세요. 이렇게 하면 창에 직접 렌더링하는 것이 아니라 텍스처로 렌더링하므로 QSGRenderNode 은 그때부터 다른 렌더 타깃으로 작동하게 됩니다. 그러면 새 렌더 타겟의 픽셀 형식이 달라져 이미 빌드된 그래픽 파이프라인이 호환되지 않을 수 있습니다. 이 문제는 다음과 같은 로직으로 처리할 수 있습니다:

if (m_pipeline && renderTarget()->renderPassDescriptor()->serializedFormat() != m_renderPassFormat) {
    delete m_pipeline;
    m_pipeline = nullptr;
}
if (!m_pipeline) {
    // Build a new QRhiGraphicsPipeline.
    // ...
    // Store the serialized format for fast and simple comparisons later on.
    m_renderPassFormat = renderTarget()->renderPassDescriptor()->serializedFormat();
}

이 함수는 Qt 6.6에 도입되었습니다.

commandBuffer()도 참조하십시오 .

© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.