Данные о поверхности
This commit is contained in:
parent
361dc3cd77
commit
873a4762ef
|
@ -0,0 +1,16 @@
|
||||||
|
#ifndef SURFACE_H
|
||||||
|
#define SURFACE_H
|
||||||
|
|
||||||
|
#include <vulkan/vulkan.h>
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
typedef struct _Surface
|
||||||
|
{
|
||||||
|
VkSurfaceKHR surface; // Поверхность окна
|
||||||
|
VkSurfaceCapabilitiesKHR capabilities; // общая информация
|
||||||
|
std::vector<VkSurfaceFormatKHR> formats; // формат поверхности
|
||||||
|
std::vector<VkPresentModeKHR> presentModes; // режим показа
|
||||||
|
} Surface;
|
||||||
|
|
||||||
|
#endif // SURFACE_H
|
|
@ -5,6 +5,7 @@
|
||||||
#include <GLFW/glfw3.h>
|
#include <GLFW/glfw3.h>
|
||||||
|
|
||||||
#include "PhysicalDevice.h"
|
#include "PhysicalDevice.h"
|
||||||
|
#include "Surface.h"
|
||||||
|
|
||||||
class Vulkan
|
class Vulkan
|
||||||
{
|
{
|
||||||
|
@ -16,7 +17,8 @@ class Vulkan
|
||||||
PhysicalDevice physicalDevice; // Физическое устройство
|
PhysicalDevice physicalDevice; // Физическое устройство
|
||||||
VkDevice logicalDevice; // логическое устройство
|
VkDevice logicalDevice; // логическое устройство
|
||||||
VkQueue graphicalQueue; // очередь для работы с графикой
|
VkQueue graphicalQueue; // очередь для работы с графикой
|
||||||
VkSurfaceKHR surface; // Поверхность окна
|
Surface surface; // Поверхность окна
|
||||||
|
|
||||||
// Структура для хранения флагов
|
// Структура для хранения флагов
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
|
@ -28,6 +30,6 @@ class Vulkan
|
||||||
void selectPhysicalDevice(std::vector<const char*> &deviceExtensions); // Выбор физического устройства
|
void selectPhysicalDevice(std::vector<const char*> &deviceExtensions); // Выбор физического устройства
|
||||||
void createLogicalDevice(std::vector<const char*> &deviceExtensions); // Создание логического устройства
|
void createLogicalDevice(std::vector<const char*> &deviceExtensions); // Создание логического устройства
|
||||||
void createWindowSurface(GLFWwindow* window); // Создание поверхности окна
|
void createWindowSurface(GLFWwindow* window); // Создание поверхности окна
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // VK_H
|
#endif // VK_H
|
38
src/vk.cpp
38
src/vk.cpp
|
@ -10,7 +10,7 @@ void Vulkan::init(GLFWwindow* window)
|
||||||
createInstance(); // Создание экземпяра
|
createInstance(); // Создание экземпяра
|
||||||
createWindowSurface(window); // Создание поверхности
|
createWindowSurface(window); // Создание поверхности
|
||||||
// Расширения для устройства: имена задаются внутри фигурных скобок в кавычках
|
// Расширения для устройства: имена задаются внутри фигурных скобок в кавычках
|
||||||
std::vector<const char*> deviceExtensions({});
|
std::vector<const char*> deviceExtensions({"VK_KHR_swapchain"});
|
||||||
selectPhysicalDevice(deviceExtensions); // Выбор физического устройства
|
selectPhysicalDevice(deviceExtensions); // Выбор физического устройства
|
||||||
createLogicalDevice(deviceExtensions); // Создание физического устройства
|
createLogicalDevice(deviceExtensions); // Создание физического устройства
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ void Vulkan::init(GLFWwindow* window)
|
||||||
// завершение работы
|
// завершение работы
|
||||||
void Vulkan::destroy()
|
void Vulkan::destroy()
|
||||||
{
|
{
|
||||||
vkDestroySurfaceKHR(instance, surface, nullptr);
|
vkDestroySurfaceKHR(instance, surface.surface, nullptr);
|
||||||
vkDestroyDevice(logicalDevice, nullptr); // Уничтожение логического устройства
|
vkDestroyDevice(logicalDevice, nullptr); // Уничтожение логического устройства
|
||||||
vkDestroyInstance(instance, nullptr); // Уничтожение экземпляра Vulkan
|
vkDestroyInstance(instance, nullptr); // Уничтожение экземпляра Vulkan
|
||||||
}
|
}
|
||||||
|
@ -165,7 +165,7 @@ void Vulkan::createInstance()
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
// Выбор физического устройства на основании требований
|
// Выбор физического устройства на основании требований
|
||||||
PhysicalDevice selectPhysicalDeviceByProperties(std::vector<VkPhysicalDevice> & devices, std::vector<const char*> &requestedExtensions)
|
PhysicalDevice selectPhysicalDeviceByProperties(std::vector<VkPhysicalDevice> & devices, Surface & surface, std::vector<const char*> &requestedExtensions)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
PhysicalDevice result; // физическое устройство (PhysicalDevice.h)
|
PhysicalDevice result; // физическое устройство (PhysicalDevice.h)
|
||||||
|
@ -200,12 +200,38 @@ PhysicalDevice selectPhysicalDeviceByProperties(std::vector<VkPhysicalDevice> &
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Получение информации о поверхности
|
||||||
|
VkSurfaceCapabilitiesKHR capabilities;
|
||||||
|
vkGetPhysicalDeviceSurfaceCapabilitiesKHR(device, surface.surface, &capabilities);
|
||||||
|
|
||||||
|
// Получение форматов поверхности
|
||||||
|
uint32_t formatCount;
|
||||||
|
vkGetPhysicalDeviceSurfaceFormatsKHR(device, surface.surface, &formatCount, nullptr);
|
||||||
|
std::vector<VkSurfaceFormatKHR> formats(formatCount);
|
||||||
|
vkGetPhysicalDeviceSurfaceFormatsKHR(device, surface.surface, &formatCount, formats.data());
|
||||||
|
|
||||||
|
// Получение данных о поддерживаемых режимах показа
|
||||||
|
uint32_t presentModeCount;
|
||||||
|
vkGetPhysicalDeviceSurfacePresentModesKHR(device, surface.surface, &presentModeCount, nullptr);
|
||||||
|
std::vector<VkPresentModeKHR> presentModes(presentModeCount);
|
||||||
|
vkGetPhysicalDeviceSurfacePresentModesKHR(device, surface.surface, &presentModeCount, presentModes.data());
|
||||||
|
|
||||||
|
// Если есть форматы и режимы показа, то на данном устройстве можно создать список показа
|
||||||
|
bool swapchainSupport = formatCount && presentModeCount;
|
||||||
|
|
||||||
// Производим оценку
|
// Производим оценку
|
||||||
if (availableExtensionsCount == requestedExtensions.size()
|
if (availableExtensionsCount == requestedExtensions.size()
|
||||||
&& result.features.geometryShader
|
&& result.features.geometryShader
|
||||||
&& 4000 < result.memory.memoryHeaps[0].size / 1000 / 1000)
|
&& 4000 < result.memory.memoryHeaps[0].size / 1000 / 1000
|
||||||
|
&& swapchainSupport)
|
||||||
|
{
|
||||||
|
// Заполним данные о поверхности
|
||||||
|
surface.capabilities = capabilities;
|
||||||
|
surface.formats = formats;
|
||||||
|
surface.presentModes = presentModes;
|
||||||
|
// Вернем устройство
|
||||||
return result;
|
return result;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// Если устройство не найдено - вернем пустую структуру
|
// Если устройство не найдено - вернем пустую структуру
|
||||||
return PhysicalDevice();
|
return PhysicalDevice();
|
||||||
|
@ -229,7 +255,7 @@ void Vulkan::selectPhysicalDevice(std::vector<const char*> &deviceExtensions)
|
||||||
vkEnumeratePhysicalDevices(instance, &deviceCount, devices.data());
|
vkEnumeratePhysicalDevices(instance, &deviceCount, devices.data());
|
||||||
|
|
||||||
// Выбор физического устройства на основании требований
|
// Выбор физического устройства на основании требований
|
||||||
physicalDevice = selectPhysicalDeviceByProperties(devices, deviceExtensions);
|
physicalDevice = selectPhysicalDeviceByProperties(devices, surface, deviceExtensions);
|
||||||
|
|
||||||
// Если не удалось выбрать подходящее требованием устройство - выдадим исключение
|
// Если не удалось выбрать подходящее требованием устройство - выдадим исключение
|
||||||
if (!physicalDevice.device)
|
if (!physicalDevice.device)
|
||||||
|
@ -291,7 +317,7 @@ void Vulkan::createLogicalDevice(std::vector<const char*> &deviceExtensions)
|
||||||
// Создание поверхности окна
|
// Создание поверхности окна
|
||||||
void Vulkan::createWindowSurface(GLFWwindow* window)
|
void Vulkan::createWindowSurface(GLFWwindow* window)
|
||||||
{
|
{
|
||||||
if (glfwCreateWindowSurface(instance, window, nullptr, &surface) != VK_SUCCESS)
|
if (glfwCreateWindowSurface(instance, window, nullptr, &surface.surface) != VK_SUCCESS)
|
||||||
{
|
{
|
||||||
throw std::runtime_error("Unable to create window surface");
|
throw std::runtime_error("Unable to create window surface");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue