1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165
|
Event Browser
=============
The Event Browser is the primary method of browsing the frame and selecting different drawcalls. It displays the user-annotated hierarchical display of sections.
Annotating your frame
---------------------
The Event Browser becomes most useful when the application has user-defined annotations of sections and subsections of the frames, to allow for a more logical and ordered browsing of the frame.
Doing this is API and platform specific. Example code for D3D11 is included below, using the ``D3DPERF`` library that is exported by ``d3d9.dll``, which can still be used in D3D11:
.. highlight:: c++
.. code:: c++
D3DPERF_BeginEvent(0xffffffff, L"Start of example");
D3DPERF_BeginEvent(0xff00ff00, L"Sub section");
// events inside the subsection
D3DPERF_EndEvent();
// events outside the subsection
D3DPERF_EndEvent();
// the newer ID3DUserDefinedAnnotation API is also supported
ID3DUserDefinedAnnotation *annot;
immediateContext->QueryInterface(__uuidof(ID3DUserDefinedAnnotation), (void **)&annot);
annot->BeginEvent(L"Sub section 2")
annot->EndEvent();
This will generate a section of the frame with a subsection that includes some events, and then some further events that are siblings of the subsection.
OpenGL can make use of the ``KHR_debug`` extension:
.. highlight:: c++
.. code:: c++
// omitted code to initialise the extension
glPushDebugGroupKHR(GL_DEBUG_SOURCE_APPLICATION, 0, -1, "Begin Section");
// contents of section here
glPopDebugGroupKHR();
Vulkan can use the ``VK_EXT_debug_marker`` extension:
.. highlight:: c++
.. code:: c++
// omitted code to initialise the extension
VkCommandBuffer cmd = ...;
VkDebugMarkerMarkerInfoEXT markerInfo = {};
markerInfo.sType = VK_STRUCTURE_TYPE_DEBUG_MARKER_MARKER_INFO_EXT;
markerInfo.pMarkerName = "Begin Section";
vkCmdDebugMarkerBeginEXT(cmd, &markerInfo);
// contents of section here
vkCmdDebugMarkerEndEXT(cmd);
Selecting available columns
---------------------------
By default, the columns in the event browser are EID and Name. Name cannot be removed as it contains the tree, but otherwise the columns can be customised both to hide/display or reorder and resize.
.. |timeline_marker| image:: ../imgs/icons/timeline_marker.png
To select which columns should be visible, right click the header or click the |timeline_marker| select columns button. To rearrange the columns simply click and drag on the header.
.. note::
Note that when timing drawcalls the duration column will automatically be added to display the data.
Timing drawcalls
----------------
.. |time| image:: ../imgs/icons/time.png
To time the GPU duration of each drawcall, click the timer button |time|.
This will automatically run a process to get the time of each drawcall and display it in the duration column, which will be added if necessary.
You can configure which time unit is used for the duration column on the fly in the :doc:`settings_window`.
To examine more GPU counters than just plain duration, see :doc:`performance_counter_viewer`.
Browsing the frame
------------------
The event browser is the primary way to browse through the frame. Events are listed as entries in the browser and the hierarchical labels mentioned above become tree nodes.
.. |flag_green| image:: ../imgs/icons/flag_green.png
The currently selected event is highlighted and indicated with a green flag |flag_green|. This is the event that RenderDoc is inspecting and is reflected in all the other windows of the UI.
.. figure:: ../imgs/QuickStart/QuickStart4.png
Current Event: The Event browser showing several sections and the current event.
The EID column indicates the event ID of the drawcall listed. Event IDs are assigned starting from 1 and increase every time an API call is made - for this reason drawcall EIDs are not necessarily contiguous.
Simply clicking on a different event will select it as current, and selecting a parent node with some child events will act as if the final child is selected - in other words selecting a node with several children will show the results of all children having happened.
You can also use keyboard shortcuts to browse through the frame. Pressing up or down arrow key will move up and down through the visible elements, skipping over any sections which are collapsed. These keys will move into and out of a sub-section into the next sibling afterwards - essentially going straight up and down as if there is not a tree and it is a straight list.
The left and right arrows go into and out of hierarchy levels. When within a level pressing left will jump to the parent node of the current level. Pressing left again will collapse that node, and so on. Pressing right will (if on a node with children) expand that node.
.. note::
This window supports copy and paste, so simply select the entries and ctrl-c to copy to the clipboard
Bookmarks
---------
.. |asterisk_orange| image:: ../imgs/icons/asterisk_orange.png
The |asterisk_orange| bookmark button will allow you to bookmark an event, the shortcut key is :kbd:`Ctrl-B`.
.. figure:: ../imgs/Screenshots/BookmarksBar.png
Bookmarks bar: The bookmarks bar with several EIDs bookmarks.
A list of bookmarked events will show up on a toolbar at the top of the event browser, they and the shortcut keys :kbd:`Ctrl-1` to :kbd:`Ctrl-0` will jump to the respective bookmarked EID. These shortcuts will work anywhere in the application.
For more information see :doc:`../how/how_annotate_capture`.
Searching and Jumping
---------------------
There are two other controls available in the Event Browser to aid in navigating the frame.
.. |find| image:: ../imgs/icons/find.png
Pressing :kbd:`Ctrl-F` will open the find-event toolbar |find|. This toolbar allows you to type in a partial text filter that will be matched against both labels and drawcall events. The find will be executed when you press enter, although you can then adjust the text and re-search if you wish.
If the event found lies inside an unexpanded section, the sections will be expanded until the matching event is visible.
Matching events will be highlighted with a find icon |find|, and pressing enter repeatedly will jump between matching events.
.. |cross| image:: ../imgs/icons/cross.png
The find toolbar isn't dismissed until you press escape in the text box, or click the close button |cross|.
.. |arrow_left| image:: ../imgs/icons/arrow_left.png
.. |arrow_right| image:: ../imgs/icons/arrow_right.png
You can also jump up and down between find results with the previous |arrow_left| and next |arrow_right| buttons.
.. figure:: ../imgs/Screenshots/FindResults.png
Highlighted Results: The results of a find are highlighted with an icon.
Pressing :kbd:`Ctrl-G` will open the jump to EID toolbar. This allows you to type in an EID and jump straight there, expanding nodes as necessary. If the EID typed doesn't exist in the list of drawcalls, the closest matching EID will be jumped to.
When you hit enter to jump to an EID, the toolbar closes and if you wish to jump again you must press :kbd:`Ctrl-G` again
.. figure:: ../imgs/Screenshots/JumpEID.png
Jumping around: The jump-to-EID toolbar prompting for an event.
|