Михаил Краснов - Графика DirectX в Delphi

Тут можно читать онлайн Михаил Краснов - Графика DirectX в Delphi - бесплатно ознакомительный отрывок. Жанр: comp-programming. Здесь Вы можете читать ознакомительный отрывок из книги онлайн без регистрации и SMS на сайте лучшей интернет библиотеки ЛибКинг или прочесть краткое содержание (суть), предисловие и аннотацию. Так же сможете купить и скачать торрент в электронном формате fb2, найти и слушать аудиокнигу на русском языке или узнать сколько частей в серии и всего страниц в публикации. Читателям доступно смотреть обложку, картинки, описание и отзывы (комментарии) о произведении.
  • Название:
    Графика DirectX в Delphi
  • Автор:
  • Жанр:
  • Издательство:
    неизвестно
  • Год:
    неизвестен
  • ISBN:
    нет данных
  • Рейтинг:
    3.56/5. Голосов: 91
  • Избранное:
    Добавить в избранное
  • Отзывы:
  • Ваша оценка:
    • 80
    • 1
    • 2
    • 3
    • 4
    • 5

Михаил Краснов - Графика DirectX в Delphi краткое содержание

Графика DirectX в Delphi - описание и краткое содержание, автор Михаил Краснов, читайте бесплатно онлайн на сайте электронной библиотеки LibKing.Ru

Графика DirectX в Delphi - читать онлайн бесплатно ознакомительный отрывок

Графика DirectX в Delphi - читать книгу онлайн бесплатно (ознакомительный отрывок), автор Михаил Краснов
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

else Firefi, j].B = 0;

end;

end;

Последний примитив, связанный с флагом DSDPTJTRIANGLEFAN, также предназначен для построения группы связанных треугольников, но данные потока здесь трактуются немного иначе, чем в предыдущем случае: вторая, третья и первая вершины определяют первый треугольник, третья, четвертая и первая ассоциированы со вторым треугольником, и т. д. То есть треугольники связаны, подобно раскрою зонтика или веера. Первая вершина потока ассоциирована с центральной точкой (рис. 7.17), а порядок перечисления вершин особенно важен для режима отключенной интерполяции цветов вершин.

По такой схеме удобно строить конусы и пирамиды а для плоскостных построений - фото 62

По такой схеме удобно строить конусы и пирамиды, а для плоскостных построений - выпуклые многоугольники, эллипсы и окружности. Приведу тривиальный пример на этот случай (проект из каталога Ех27).

Значение константы Level задает степень разбиения полного круга, количество вершин нам требуется на пару больше этого значения:

const

Level = 255;

var

VPoints : Array [0..Level + 1] of TCUSTOMVERTEX;

Нервая вершина массива хранит координаты центральной точки круга, все детальные равномерно располагаются на его границе:

const

Step = 2 * Pi / Level;

with VPoints [0] do begin // Первая точка - центр круга

х := 150;

Y := 150;

Color := D3DCOLOR_XRGB(0, 0, 0);

end;

If for i := 1 to Level + 1 do // Точки на краю круга

with VPoints [i] do begin

X := 150 + cos (Angle + i * Step) * Radius;

Y := 150 + sin (Angle + i * Step) * Radius;

Color := D3DCOLOR_XRGB(0, trunc(i * 255 / Level), 0);

end;

Для каждой вершины последовательно увеличивается вес зеленой составлявшей цвета. Для последней точки он принимает максимальное значение при произвольной величине константы Level. Градиент зеленого цвета я взял для того, чтобы получить в итоге некое подобие экрана радара (рис. 17.8).

Оконные приложения использующие Direct3D безболезненно переживают ситуации - фото 63

Оконные приложения, использующие Direct3D, безболезненно переживают ситуации потери фокуса и восстановления, но осталась еще одна исключительная ситуация - спящий режим. Возврат из этого режима гарантированно приведет к потере способности воспроизведения нашим приложением.

Для предупреждения таких исключений можно воспользоваться методом TestcooperativeLevel объекта устройства. Метод возвращает значение D3DERR_DEvicELOST в ситуации, когда устройство вывода недоступно, например, в спящем состоянии. Другое, кроме успешного, возвращаемое методом значение - DSDERF^DEVICENOTRESET, соответствует ситуации, когда устройство, в принципе, готово, но воспроизведение невозможно.

На примере этого проекта рассмотрим, как пользоваться данным методом, чтобы оконные приложения смогли пережить спящий режим. Код обработчика цикла ожидания приведите к следующему виду:

if FActive then begin Inc (Frames);

// Определяем состояние устройства

hRet := FD3DDevice.TestcooperativeLevel;

if hRet = D3DERR_DEVICELOST

// Сейчас устройство не готово, воспроизведение невозможно

then Exit

// Выход из спящего режима

else if Failed(hRet) then begin

// Заново инициализируем систему InitDSD;

InitPoints;

end;

// Воспроизведение осуществляем без проверки исключений

Render;

...

То есть при выходе из спящего режима необходимо повторно инициализировать графическую систему и заново подготовить буфер вершин.

Полноэкранный режим

Конечно, для многих ваших приложений потребуется именно полноэкранный режим, поэтому мы изучим нюансы, связанные с использованием Direct3D в таком режиме. Как обычно для этой книги, рассмотрим особенности на конкретном примере (проект каталога Ех28) модифицированного варианта вращающейся звезды. Теперь звезда вращается в полноэкранном режиме.

У формы поменялось значение свойства BorderStyle: чтобы окно приложения не просвечивало, реагируя на нахождение курсора вблизи границ, это свойство установлено в значение bsNone.

При инициализации графической системы нам требуется определить формат пиксела, вспомогательный массив содержит возможные значения формата, а метод checkDeviceType главного объекта позволяет определить, какое значение подходит для текущих установок рабочего стола:

const // Возможные форматы пиксела

К fmtFullscreenArray : Array [0..4] of DWORD =

(D3DFMT_R5G6B5,

D3DFMT_X1R5G5B5,

D3DFMTJU.R5G5B5,

D3DFMT_X8R8G8B8,

D3DFMT_A8R8G8B8) ;

var

FDSDfmtFullscreen : DWORD; // Формат пиксела

ScreenWidth, ScreenHeight : Integer; // Размеры рабочего стола

HalfScreenWidth, HalfScreenHeight : Integer; // Вспомогательные размеры

d3dpp : TD3DPRESENT_PARAMETERS; // Структура, хранящая параметры

function TfrmD3D.InitD3D : HRESULT;

var

iEtat : Integer;

begin

if FD3D = nil then FD3D := Direct3DCreate8(D3D_SDK_VERSION);

if FD3D = nil then begin

Result := E_FAIL;

Exit;

end;

// Подбираем формат пиксела для текущих установок

for iFmt := 0 to High(fmtFullscreenArray) do begin

if SUCCEEDED(FD3D.CheckDeviceType(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL,

fmtFullscreenArrayliFmt], fmtFullscreenArray[iFmt], FALSE))

then begin

FDSDfmtFullscreen := fmtFullscreenArray[iFmt];

Break; // Найден подходящий

end

end;

// Запоминаем размеры рабочего стола

ScreenWidth := GetSystemMetrics(SM_CXSCREEN);

ScreenHeight := GetSystemMetrics(SM_CYSCREEN);

// Координаты центра экрана

HalfScreenWidth := ScreenWidth div 2;

HalfScreenHeight := ScreenHeight div 2;

// Заполняем поля структуры

ZeroMemory(@d3dpp, SizeOf(dSdpp));

with d3dpp do begin

Windowed := False; // Полноэкранный режим

SwapEffect := D3DSWAPEFFECT_DISCARD;

BackBufferWidth .-= ScreenWidth;

BackBufferHeight := ScreenHeight;

BackBufferFormat := FD3DfmtFullscreen;

end;

Result := FD3D.CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, Handle,

D3DCREATE_SOFTWARE_VERTEXPROCESSING,

d3dpp, FD3DDevice);

end;

Обратите внимание, что объекты Direct3D обнуляются не в этой функции инициализации, а при создании формы. Перед созданием главного объекта определяем, не хранит ли эта переменная какое-нибудь значение. Делается это постольку, поскольку функция инициализации будет вызываться, возможно, неоднократно, в ситуации, когда главный объект уже существует.

Остальные действия в программе похожи на манипуляции, которые мы проделывали в полноэкранных приложениях, использующих DirectDraw: отслеживаем ситуацию потери активности, когда пользователь переключается, воспроизведение осуществляется только при активном состоянии.

Совершенно новым для нас является в этом примере то, что при восстановлении минимизированного приложения заново выполняется инициализация объекта устройства:

procedure TfrmD3D.ApplicationEventslRestore(Sender: TObject);

begin

if Assigned (FD3DVB) then begin // Освобождение объектов

FD3DVB._Release;

FD3DVB := nil;

end;

WindowState := wsMaximized; // Распахивание окна

InitD3D; // Повторяем код инициализации

InitPoints; // Инициализация буфера вершин

FActive := True;

end;

В ситуации ухода окна с экрана происходит потеря устройства воспроизведения, подобная потере поверхности в DirectDraw. При восстановлении окна воспроизведения самым безболезненным способом возврата к воспроизведению является повторная инициализация объекта устройства. Чтобы провести эту процедуру, объект устройства необходимо освободить ото всех связанных с ним дочерних объектов, в нашем примере это единственный объект - буфер вершин. Дальше мы повторно вызываем функцию инициализации графической системы. Главный объект заново создавать не нужно, поэтому в код внесены изменения, на которые я выше обращал ваше внимание. Поскольку буфер вершин нами был удален, после инициализации системы вызывается функция, заново создающая этот объект.

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать


Михаил Краснов читать все книги автора по порядку

Михаил Краснов - все книги автора в одном месте читать по порядку полные версии на сайте онлайн библиотеки LibKing.




Графика DirectX в Delphi отзывы


Отзывы читателей о книге Графика DirectX в Delphi, автор: Михаил Краснов. Читайте комментарии и мнения людей о произведении.


Понравилась книга? Поделитесь впечатлениями - оставьте Ваш отзыв или расскажите друзьям

Напишите свой комментарий
x