Слои
This commit is contained in:
parent
9019ce1554
commit
afe5860125
68
src/vk.cpp
68
src/vk.cpp
|
@ -13,8 +13,47 @@ void Vulkan::init()
|
||||||
// завершение работы
|
// завершение работы
|
||||||
void Vulkan::destroy()
|
void Vulkan::destroy()
|
||||||
{
|
{
|
||||||
// Уничтожение экземпляра Vulkan
|
vkDestroyInstance(instance, nullptr); // Уничтожение экземпляра Vulkan
|
||||||
vkDestroyInstance(instance, nullptr);
|
}
|
||||||
|
|
||||||
|
#include <cstring>
|
||||||
|
// Проверка слоев на доступность. Возвращает true, если все слои доступны
|
||||||
|
// по ссылке заполняет вектор недоступных слоев
|
||||||
|
bool checkValidationLayerSupport(std::vector <const char*> requestedLayers, std::vector <const char*> & unavailableLayers)
|
||||||
|
{
|
||||||
|
bool layerAvailable; // флаг доступности слоя для цикла
|
||||||
|
|
||||||
|
// Первым вызовом определим кол-во доступных слоев
|
||||||
|
uint32_t layerCount;
|
||||||
|
vkEnumerateInstanceLayerProperties(&layerCount, nullptr);
|
||||||
|
|
||||||
|
// Вторым вызовом запишем в вектор доступные слои
|
||||||
|
std::vector<VkLayerProperties> availableLayers(layerCount);
|
||||||
|
vkEnumerateInstanceLayerProperties(&layerCount, availableLayers.data());
|
||||||
|
|
||||||
|
// Цикл по запрошенным слоям
|
||||||
|
for (const char* layerName : requestedLayers)
|
||||||
|
{
|
||||||
|
layerAvailable = false;
|
||||||
|
|
||||||
|
// Цикл по доступным слоям
|
||||||
|
for (const auto& layerProperties : availableLayers)
|
||||||
|
{
|
||||||
|
// Сравнение строк
|
||||||
|
if (strcmp(layerName, layerProperties.layerName) == 0)
|
||||||
|
{
|
||||||
|
layerAvailable = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Если слой не найден то заносим в массив недоступных
|
||||||
|
if (!layerAvailable) {
|
||||||
|
unavailableLayers.push_back(layerName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return unavailableLayers.size() == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Vulkan::createInstance()
|
void Vulkan::createInstance()
|
||||||
|
@ -47,10 +86,33 @@ void Vulkan::createInstance()
|
||||||
createInfo.enabledExtensionCount = static_cast<uint32_t>(extensions.size());
|
createInfo.enabledExtensionCount = static_cast<uint32_t>(extensions.size());
|
||||||
createInfo.ppEnabledExtensionNames = extensions.data();
|
createInfo.ppEnabledExtensionNames = extensions.data();
|
||||||
|
|
||||||
|
// Подключение слоев
|
||||||
|
std::vector<const char*> validationLayers = {
|
||||||
|
"VK_LAYER_KHRONOS_validation"
|
||||||
|
};
|
||||||
|
|
||||||
|
if (states.VALIDATION)
|
||||||
|
{
|
||||||
|
createInfo.enabledLayerCount = static_cast<uint32_t>(validationLayers.size());
|
||||||
|
createInfo.ppEnabledLayerNames = validationLayers.data();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Проверим доступность слоев
|
||||||
|
std::vector<const char*> unavailableLayers;
|
||||||
|
if (!checkValidationLayerSupport(validationLayers, unavailableLayers))
|
||||||
|
{
|
||||||
|
std::cout << "Запрошены недоступные слои:\n";
|
||||||
|
// Цикл по недоступным слоям
|
||||||
|
for (const char* layer : unavailableLayers)
|
||||||
|
std::cout << layer << "\n";
|
||||||
|
// Отправим исключение об отсутствующем слое
|
||||||
|
throw std::runtime_error("Requested layer unavailable");
|
||||||
|
}
|
||||||
|
|
||||||
// Создание экземпляра Vulkan
|
// Создание экземпляра Vulkan
|
||||||
VkResult result = vkCreateInstance(&createInfo, nullptr, &instance);
|
VkResult result = vkCreateInstance(&createInfo, nullptr, &instance);
|
||||||
if (result != VK_SUCCESS)
|
if (result != VK_SUCCESS)
|
||||||
{ // Отправим исключение в случае ошибок создания экземпляра Vulkan
|
{ // Отправим исключение в случае ошибок создания экземпляра
|
||||||
throw std::runtime_error("Instance create error");
|
throw std::runtime_error("Instance create error");
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue