Метод ID3D10Device::D rawAuto (d3d10.h)
Рисование геометрии неизвестного размера, созданной этапом шейдера геометрии. См. примечания.
Синтаксис
void DrawAuto();
Возвращаемое значение
None
Remarks
API рисования отправляет работу в конвейер отрисовки.
После потоковой передачи данных в буферы этапов SO эти буферы можно снова привязать к этапу сборщика входных данных во входном слоте 0, и DrawAuto нарисует их без необходимости знать объем данных, записанных в буферы. Измерение объема данных, записываемых в буферы этапов SO, поддерживается внутренне при передаче данных. Это означает, что ЦП не нужно получить измерение перед повторной привязкой данных, которые были потоковой передачи в качестве входных данных. Хотя этот объем отслеживается внутри, приложения по-прежнему несут ответственность за использование входных макетов для описания формата данных в буферах этапов SO, чтобы макеты были доступны, когда буферы снова привязаны к ассемблере ввода.
На следующей схеме показан процесс DrawAuto.
Вызов DrawAuto не изменяет состояние буферов потокового вывода, которые были снова привязаны как входные данные.
DrawAuto работает только при рисовании с одним входным буфером, привязанным в качестве входных данных к этапу IA в слоте 0. Приложения должны создать ресурс буфера SO с флагами привязки, D3D10_BIND_VERTEX_BUFFER и D3D10_BIND_STREAM_OUTPUT.
Этот API не поддерживает индексирование или инстансирование.
Если приложению необходимо получить размер буфера потокового вывода, оно может запрашивать статистику по выходным данным потоковой передачи с помощью D3D10_QUERY_SO_STATISTICS.
Пример использования DrawAuto можно найти в примерах ParticlesGS и PipesGS Sample.
Требования
Требование | Значение |
---|---|
Целевая платформа | Windows |
Header | d3d10.h |
Библиотека | D3D10.lib |