AJA NTV2 SDK  17.1.3.1410
NTV2 SDK 17.1.3.1410
ntv2outputtestpattern.cpp
Go to the documentation of this file.
1 /* SPDX-License-Identifier: MIT */
9 // Includes
10 #include "ntv2outputtestpattern.h"
11 #include "ntv2devicescanner.h"
12 #include "ntv2testpatterngen.h"
13 #include "ajabase/system/process.h"
14 
15 #define AsULWordPtr(_p_) reinterpret_cast<const ULWord*> (_p_)
16 
17 
18 using namespace std;
19 
20 
21 const uint32_t kAppSignature (NTV2_FOURCC('T','e','s','t'));
22 
23 
24 AJALabelValuePairs TestPatConfig::Get (const bool inCompact) const
25 {
26  AJALabelValuePairs result (PlayerConfig::Get (inCompact));
27  AJASystemInfo::append(result, "Background Pattern", fTestPatternName);
28  return result;
29 }
30 
31 std::ostream & operator << (std::ostream & ioStrm, const TestPatConfig & inObj)
32 {
33  return ioStrm << AJASystemInfo::ToString(inObj.Get());
34 }
35 
36 
38  : mConfig (inConfig),
39  mDeviceID (DEVICE_ID_NOTFOUND),
40  mSavedTaskMode (NTV2_TASK_MODE_INVALID),
41  mSavedConnections ()
42 {
43 } // constructor
44 
45 
47 {
48  // Restore prior widget routing...
49  mDevice.ApplySignalRoute(mSavedConnections, /*replace?*/true);
50 
51  // Restore the prior service level, and release the device...
52  mDevice.SetEveryFrameServices(mSavedTaskMode);
53  mDevice.ReleaseStreamForApplication (kAppSignature, static_cast<int32_t>(AJAProcess::GetPid()));
54 
55 } // destructor
56 
57 
59 {
60  // Open the device...
62  {cerr << "## ERROR: Device '" << mConfig.fDeviceSpec << "' not found" << endl; return AJA_STATUS_OPEN;}
63  mDeviceID = mDevice.GetDeviceID(); // Keep this ID handy -- it's used frequently
64 
65  if (!mDevice.IsDeviceReady(false))
66  {cerr << "## ERROR: Device '" << mDevice.GetDisplayName() << "' not ready" << endl; return AJA_STATUS_INITIALIZE;}
67  if (!mDevice.features().CanDoPlayback())
68  {cerr << "## ERROR: '" << mDevice.GetDisplayName() << "' is capture-only" << endl; return AJA_STATUS_FEATURE;}
69 
70  const UWord maxNumChannels (mDevice.features().GetNumFrameStores());
71 
72  if ((mConfig.fOutputChannel == NTV2_CHANNEL1) && (!mDevice.features().CanDoFrameStore1Display()))
73  { // Some older devices (e.g. Corvid1) can only output from FrameStore 2...
74  mConfig.fOutputChannel = NTV2_CHANNEL2;
75  cerr << "## WARNING: '" << mDevice.GetDisplayName() << "' switched to Ch2 (Ch1 is input-only)" << endl;
76  }
77  if (UWord(mConfig.fOutputChannel) >= maxNumChannels)
78  {
79  cerr << "## ERROR: '" << mDevice.GetDisplayName() << "' can't use Ch" << DEC(mConfig.fOutputChannel+1)
80  << " -- only supports Ch1" << (maxNumChannels > 1 ? string("-Ch") + string(1, char(maxNumChannels+'0')) : "") << endl;
82  }
83 
84  if (!mConfig.fDoMultiFormat)
85  {
86  mDevice.GetConnections(mSavedConnections); // Save current routing, so it can be restored later
87  mDevice.GetEveryFrameServices(mSavedTaskMode); // Save the current task mode
89  return AJA_STATUS_BUSY; // Device is in use by another app -- fail
90  }
91  mDevice.SetEveryFrameServices(NTV2_OEM_TASKS); // Set OEM service level
92 
93  if (mDevice.features().CanDoMultiFormat())
94  mDevice.SetMultiFormatMode(mConfig.fDoMultiFormat);
95  else
96  mConfig.fDoMultiFormat = false;
97 
98  // Set up the desired video configuration...
99  AJAStatus status (SetUpVideo());
100  if (AJA_FAILURE(status))
101  return status;
102 
103  #if defined(_DEBUG)
104  AJALabelValuePairs info(mConfig.Get());
105  if (!mDevice.GetDescription().empty())
106  for (AJALabelValuePairsConstIter it(info.begin()); it != info.end(); ++it)
107  if (it->first.find("Device Specifier") == 0)
108  {info.insert(++it, AJALabelValuePair("Device Description", mDevice.GetDescription())); break;}
109  cerr << AJASystemInfo::ToString(info);
110  #endif // defined(_DEBUG)
111  return AJA_STATUS_SUCCESS;
112 
113 } // Init
114 
115 
117 {
118  if (mConfig.fVideoFormat == NTV2_FORMAT_UNKNOWN)
119  {
120  // User didn't specify a video format.
121  // Get the device's current video format and use it to create the test pattern...
122  bool enabled(false);
123  mDevice.IsChannelEnabled(mConfig.fOutputChannel, enabled);
124  if (!enabled)
125  if (!mDevice.GetVideoFormat (mConfig.fVideoFormat, mConfig.fOutputChannel))
126  return AJA_STATUS_FAIL;
127 
128  // Read the current VANC mode, as this can affect the NTV2FormatDescriptor and host frame buffer size...
129  if (!mDevice.GetVANCMode (mConfig.fVancMode, mConfig.fOutputChannel))
130  return AJA_STATUS_FAIL;
131  }
132 
133  if (mConfig.fVideoFormat != NTV2_FORMAT_UNKNOWN)
134  {
135  // User specified a video format -- is it legal for this device?
136  if (!mDevice.features().CanDoVideoFormat(mConfig.fVideoFormat))
137  { cerr << "## ERROR: '" << mDevice.GetDisplayName() << "' cannot do " << ::NTV2VideoFormatToString(mConfig.fVideoFormat) << endl;
138  return AJA_STATUS_UNSUPPORTED;
139  }
140 
141  // Set the video format -- is it legal for this device?
142  if (!mDevice.SetVideoFormat (mConfig.fVideoFormat, /*retail?*/false, /*keepVANC*/false, mConfig.fOutputChannel))
143  { cerr << "## ERROR: SetVideoFormat '" << ::NTV2VideoFormatToString(mConfig.fVideoFormat) << "' failed" << endl;
144  return AJA_STATUS_FAIL;
145  }
146 
147  // Set the VANC mode
149  { cerr << "## ERROR: SetEnableVANCData '" << ::NTV2VANCModeToString(mConfig.fVancMode,true) << "' failed" << endl;
150  return AJA_STATUS_FAIL;
151  }
152  }
153 
154  // SD/HD/2K only -- no 4K or 8K...
156  { cerr << "## ERROR: This demo only supports SD/HD/2K1080, not '" << ::NTV2VideoFormatToString(mConfig.fVideoFormat) << "'" << endl;
157  return AJA_STATUS_UNSUPPORTED;
158  }
159 
160  // This is a "playback" application, so set the board reference to free run...
161  if (!mDevice.SetReference(NTV2_REFERENCE_FREERUN))
162  return AJA_STATUS_FAIL;
163 
164  // Set the FrameStore's pixel format...
165  if (!mDevice.SetFrameBufferFormat (mConfig.fOutputChannel, mConfig.fPixelFormat))
166  return AJA_STATUS_FAIL;
167 
168  // Enable the FrameStore (if currently disabled)...
169  mDevice.EnableChannel(mConfig.fOutputChannel);
170 
171  // Set the FrameStore mode to "playout" (not capture)...
172  if (!mDevice.SetMode (mConfig.fOutputChannel, NTV2_MODE_DISPLAY))
173  return AJA_STATUS_FAIL;
174 
175  // Enable SDI output from the channel being used, but only if the device supports bi-directional SDI...
176  if (mDevice.features().HasBiDirectionalSDI())
177  mDevice.SetSDITransmitEnable (mConfig.fOutputChannel, true);
178 
179  return AJA_STATUS_SUCCESS;
180 
181 } // SetUpVideo
182 
183 
185 {
186  NTV2XptConnections connections;
187 
188  // Build a set of crosspoint connections (input-to-output)
189  // between the relevant signal processing widgets on the device.
190  // By default, the main output crosspoint that feeds the SDI output widgets is the FrameStore's video output:
192  if (::IsRGBFormat(mConfig.fPixelFormat))
193  { // Even though this demo defaults to using an 8-bit YUV frame buffer,
194  // this code block allows it to work with RGB frame buffers, which
195  // necessitate inserting a CSC between the FrameStore and the SDI output(s)...
196  connections.insert(NTV2Connection(::GetCSCInputXptFromChannel(mConfig.fOutputChannel), outputXpt)); // CSC video input to FrameStore output
197  outputXpt = ::GetCSCOutputXptFromChannel(mConfig.fOutputChannel); // The CSC output feeds all SDIOut inputs
198  }
199 
200  // Route all SDI outputs to the outputXpt...
201  const NTV2ChannelSet sdiOutputs (::NTV2MakeChannelSet(NTV2_CHANNEL1, mDevice.features().GetNumVideoOutputs()));
202  const NTV2Standard videoStd (::GetNTV2StandardFromVideoFormat(mConfig.fVideoFormat));
203  const NTV2ChannelList sdiOuts (::NTV2MakeChannelList(sdiOutputs));
204 
205  // Some devices have bi-directional SDI connectors...
206  if (mDevice.features().HasBiDirectionalSDI())
207  mDevice.SetSDITransmitEnable (sdiOutputs, true); // Set to "transmit"
208 
209  // For every SDI output, set video standard, and disable level A/B conversion...
210  mDevice.SetSDIOutputStandard (sdiOutputs, videoStd);
211  mDevice.SetSDIOutLevelAtoLevelBConversion(sdiOutputs, false);
212  mDevice.SetSDIOutRGBLevelAConversion(sdiOutputs, false);
213 
214  // Connect each SDI output to the main output crosspoint...
215  for (size_t ndx(0); ndx < sdiOutputs.size(); ndx++)
216  {
217  const NTV2Channel sdiOut(sdiOuts.at(ndx));
218  connections.insert(NTV2Connection(::GetSDIOutputInputXpt(sdiOut), outputXpt));
219  }
220 
221  // And connect analog video output, if the device has one...
222  if (mDevice.features().GetNumAnalogVideoOutputs())
223  connections.insert(NTV2Connection(::GetOutputDestInputXpt(NTV2_OUTPUTDESTINATION_ANALOG), outputXpt));
224 
225  // And connect HDMI video output, if the device has one...
226  if (mDevice.features().GetNumHDMIVideoOutputs())
227  connections.insert(NTV2Connection(::GetOutputDestInputXpt(NTV2_OUTPUTDESTINATION_HDMI), outputXpt));
228 
229  // Apply all the accumulated connections...
230  mDevice.ApplySignalRoute(connections, /*replaceExistingRoutes*/true);
231 
232 } // RouteOutputSignal
233 
234 
236 {
237  // Connect the FrameStore to the video output...
239 
240  // Allocate a host video buffer that will hold our test pattern raster...
241  NTV2FormatDescriptor fd (mConfig.fVideoFormat, mConfig.fPixelFormat, mConfig.fVancMode);
242  NTV2Buffer hostBuffer (fd.GetTotalBytes());
243  if (hostBuffer.IsNULL())
244  return AJA_STATUS_MEMORY;
245 
246  // Write the requested test pattern into host buffer...
247  NTV2TestPatternGen testPatternGen;
248  testPatternGen.setVANCToLegalBlack(fd.IsVANC());
249  if (!testPatternGen.DrawTestPattern (mConfig.fTestPatternName, fd, hostBuffer))
250  return AJA_STATUS_FAIL;
251 
252  // Find out which frame is currently being output from the frame store...
253  uint32_t currentOutputFrame(0);
254  if (!mDevice.GetOutputFrame (mConfig.fOutputChannel, currentOutputFrame))
255  return AJA_STATUS_FAIL; // ReadRegister failure?
256 
257  // Now simply transfer the contents of the host buffer to the device's current output frame...
258  if (!mDevice.DMAWriteFrame (currentOutputFrame, // Device frame number
259  AsULWordPtr(fd.GetRowAddress(hostBuffer.GetHostPointer(), 0)), // Host buffer address
260  hostBuffer.GetByteCount())) // # bytes to xfer
261  return AJA_STATUS_FAIL;
262 
263  return AJA_STATUS_SUCCESS;
264 
265 } // EmitPattern
NTV2TestPatternGen::DrawTestPattern
virtual bool DrawTestPattern(const std::string &inTPName, const NTV2FormatDescriptor &inFormatDesc, NTV2Buffer &inBuffer)
Renders the given test pattern or color into a host raster buffer.
CNTV2Card::GetConnections
virtual bool GetConnections(NTV2XptConnections &outConnections)
Answers with the device's current widget routing connections.
Definition: ntv2regroute.cpp:345
CNTV2Card::SetMultiFormatMode
virtual bool SetMultiFormatMode(const bool inEnable)
Enables or disables multi-format (per channel) device operation. If enabled, each device channel can ...
Definition: ntv2register.cpp:4379
GetSDIOutputInputXpt
NTV2InputXptID GetSDIOutputInputXpt(const NTV2Channel inSDIOutput, const bool inIsDS2=false)
Definition: ntv2signalrouter.cpp:942
DeviceCapabilities::CanDoVideoFormat
bool CanDoVideoFormat(const NTV2VideoFormat inVF)
Definition: ntv2devicecapabilities.h:251
NTV2_IS_VANCMODE_TALLER
#define NTV2_IS_VANCMODE_TALLER(__v__)
Definition: ntv2enums.h:3726
ntv2outputtestpattern.h
NTV2_FOURCC
#define NTV2_FOURCC(_a_, _b_, _c_, _d_)
Definition: ntv2publicinterface.h:5444
NTV2_CHANNEL2
@ NTV2_CHANNEL2
Specifies channel or Frame Store 2 (or the 2nd item).
Definition: ntv2enums.h:1308
CNTV2Card::SetVideoFormat
virtual bool SetVideoFormat(const NTV2VideoFormat inVideoFormat, const bool inIsAJARetail=(!(0)), const bool inKeepVancSettings=(0), const NTV2Channel inChannel=NTV2_CHANNEL1)
Configures the AJA device to handle a specific video format.
Definition: ntv2register.cpp:204
NTV2FormatDescriptor
Describes a video frame for a given video standard or format and pixel format, including the total nu...
Definition: ntv2formatdescriptor.h:41
NTV2FormatDescriptor::GetRowAddress
const void * GetRowAddress(const void *pInStartAddress, const ULWord inRowIndex0, const UWord inPlaneIndex0=0) const
Definition: ntv2formatdescriptor.cpp:997
NTV2Channel
NTV2Channel
These enum values are mostly used to identify a specific widget_framestore. They're also commonly use...
Definition: ntv2enums.h:1305
NTV2Buffer
A generic user-space buffer object that has an address and a length. Used most often to share an arbi...
Definition: ntv2publicinterface.h:5993
AJA_STATUS_SUCCESS
@ AJA_STATUS_SUCCESS
Definition: types.h:381
TestPatConfig
Configures an NTV2OutputTestPattern instance.
Definition: ntv2outputtestpattern.h:18
NTV2Buffer::GetByteCount
ULWord GetByteCount(void) const
Definition: ntv2publicinterface.h:6066
AJA_STATUS_BUSY
@ AJA_STATUS_BUSY
Definition: types.h:391
CNTV2DeviceScanner::GetFirstDeviceFromArgument
static bool GetFirstDeviceFromArgument(const std::string &inArgument, CNTV2Card &outDevice)
Rescans the host, and returns an open CNTV2Card instance for the AJA device that matches a command li...
Definition: ntv2devicescanner.cpp:366
NTV2MakeChannelList
NTV2ChannelList NTV2MakeChannelList(const NTV2Channel inFirstChannel, const UWord inNumChannels=1)
Definition: ntv2publicinterface.cpp:3374
ntv2testpatterngen.h
Declares the NTV2TestPatternGen class.
AsULWordPtr
#define AsULWordPtr(_p_)
Definition: ntv2outputtestpattern.cpp:15
CNTV2MacDriverInterface::ReleaseStreamForApplication
virtual bool ReleaseStreamForApplication(ULWord inApplicationType, int32_t inProcessID)
Releases exclusive use of the AJA device for the given process, permitting other processes to acquire...
Definition: ntv2macdriverinterface.cpp:516
AJA_STATUS_MEMORY
@ AJA_STATUS_MEMORY
Definition: types.h:397
PlayerConfig::fDoMultiFormat
bool fDoMultiFormat
If true, enable device-sharing; otherwise take exclusive control of device.
Definition: ntv2democommon.h:323
CNTV2Card::GetVANCMode
virtual bool GetVANCMode(NTV2VANCMode &outVancMode, const NTV2Channel inChannel=NTV2_CHANNEL1)
Retrieves the current VANC mode for the given FrameStore.
Definition: ntv2register.cpp:2728
CNTV2Card::ApplySignalRoute
virtual bool ApplySignalRoute(const CNTV2SignalRouter &inRouter, const bool inReplace=(0))
Applies the given routing table to the AJA device.
Definition: ntv2regroute.cpp:242
NTV2OutputTestPattern::NTV2OutputTestPattern
NTV2OutputTestPattern(const TestPatConfig &inConfig)
Constructs me using the given configuration settings.
Definition: ntv2outputtestpattern.cpp:37
NTV2_IS_8K_VIDEO_FORMAT
#define NTV2_IS_8K_VIDEO_FORMAT(__f__)
Definition: ntv2enums.h:852
PlayerConfig::fVancMode
NTV2VANCMode fVancMode
VANC mode to use.
Definition: ntv2democommon.h:320
NTV2_CHANNEL1
@ NTV2_CHANNEL1
Specifies channel or Frame Store 1 (or the first item).
Definition: ntv2enums.h:1307
CNTV2Card::SetFrameBufferFormat
virtual bool SetFrameBufferFormat(NTV2Channel inChannel, NTV2FrameBufferFormat inNewFormat, bool inIsAJARetail=(!(0)), NTV2HDRXferChars inXferChars=NTV2_VPID_TC_SDR_TV, NTV2HDRColorimetry inColorimetry=NTV2_VPID_Color_Rec709, NTV2HDRLuminance inLuminance=NTV2_VPID_Luminance_YCbCr)
Sets the frame buffer format for the given FrameStore on the AJA device.
Definition: ntv2register.cpp:1812
CNTV2Card::SetSDITransmitEnable
virtual bool SetSDITransmitEnable(const NTV2Channel inChannel, const bool inEnable)
Sets the specified bidirectional SDI connector to act as an input or an output.
Definition: ntv2register.cpp:3796
NTV2OutputTestPattern::RouteOutputSignal
void RouteOutputSignal(void)
Sets up board routing for playout.
Definition: ntv2outputtestpattern.cpp:184
NTV2_IS_4K_VIDEO_FORMAT
#define NTV2_IS_4K_VIDEO_FORMAT(__f__)
Definition: ntv2enums.h:746
NTV2OutputTestPattern::EmitPattern
AJAStatus EmitPattern(void)
Generates, transfers and displays the test pattern on the output.
Definition: ntv2outputtestpattern.cpp:235
GetOutputDestInputXpt
NTV2InputXptID GetOutputDestInputXpt(const NTV2OutputDestination inOutputDest, const bool inIsSDI_DS2=false, const UWord inHDMI_Quadrant=99)
Definition: ntv2signalrouter.cpp:928
CNTV2Card::features
virtual class DeviceCapabilities & features(void)
Definition: ntv2card.h:141
CNTV2Card::GetDisplayName
virtual std::string GetDisplayName(void)
Answers with this device's display name.
Definition: ntv2card.cpp:86
AJAStatus
AJAStatus
Definition: types.h:378
NTV2OutputTestPattern::~NTV2OutputTestPattern
~NTV2OutputTestPattern(void)
Definition: ntv2outputtestpattern.cpp:46
process.h
Declares the AJAProcess class.
CNTV2Card::GetOutputFrame
virtual bool GetOutputFrame(const NTV2Channel inChannel, ULWord &outValue)
Answers with the current output frame number for the given FrameStore (expressed as an NTV2Channel).
Definition: ntv2register.cpp:2200
NTV2Standard
NTV2Standard
Identifies a particular video standard.
Definition: ntv2enums.h:153
AJA_STATUS_FEATURE
@ AJA_STATUS_FEATURE
Definition: types.h:393
CNTV2Card::GetVideoFormat
virtual bool GetVideoFormat(NTV2VideoFormat &outValue, NTV2Channel inChannel=NTV2_CHANNEL1)
Definition: ntv2register.cpp:335
AJA_STATUS_FAIL
@ AJA_STATUS_FAIL
Definition: types.h:382
NTV2Buffer::IsNULL
bool IsNULL(void) const
Definition: ntv2publicinterface.h:6088
TestPatConfig::fTestPatternName
std::string fTestPatternName
Name of the test pattern to use.
Definition: ntv2outputtestpattern.h:21
AJASystemInfo::append
static AJALabelValuePairs & append(AJALabelValuePairs &inOutTable, const std::string &inLabel, const std::string &inValue=std::string())
A convenience function that appends the given label and value strings to the provided AJALabelValuePa...
Definition: info.h:168
CNTV2Card::GetDescription
virtual std::string GetDescription(void) const
Definition: ntv2card.cpp:124
ntv2devicescanner.h
Declares the CNTV2DeviceScanner class.
NTV2FormatDescriptor::GetTotalBytes
ULWord GetTotalBytes(void) const
Definition: ntv2formatdescriptor.cpp:851
CNTV2Card::SetMode
virtual bool SetMode(const NTV2Channel inChannel, const NTV2Mode inNewValue, const bool inIsRetail=(!(0)))
Determines if a given FrameStore on the AJA device will be used to capture or playout video.
Definition: ntv2register.cpp:1607
CNTV2Card::SetSDIOutRGBLevelAConversion
virtual bool SetSDIOutRGBLevelAConversion(const UWord inOutputSpigot, const bool inEnable)
Enables or disables an RGB-over-3G-level-A conversion at the SDI output widget (assuming the AJA devi...
Definition: ntv2register.cpp:4347
AJALabelValuePair
std::pair< std::string, std::string > AJALabelValuePair
A pair of strings comprising a label and a value.
Definition: info.h:68
GetCSCOutputXptFromChannel
NTV2OutputXptID GetCSCOutputXptFromChannel(const NTV2Channel inCSC, const bool inIsKey=false, const bool inIsRGB=false)
Definition: ntv2signalrouter.cpp:819
AJASystemInfo::ToString
virtual void ToString(std::string &outAllLabelsAndValues) const
Answers with a multi-line string that contains the complete host system info table.
AJAProcess::GetPid
static uint64_t GetPid()
Definition: process.cpp:35
UWord
uint16_t UWord
Definition: ajatypes.h:251
PlayerConfig::fVideoFormat
NTV2VideoFormat fVideoFormat
The video format to use.
Definition: ntv2democommon.h:319
NTV2VANCModeToString
std::string NTV2VANCModeToString(const NTV2VANCMode inValue, const bool inCompactDisplay=false)
Definition: ntv2utils.cpp:6521
NTV2_IS_VANCMODE_ON
#define NTV2_IS_VANCMODE_ON(__v__)
Definition: ntv2enums.h:3727
NTV2_REFERENCE_FREERUN
@ NTV2_REFERENCE_FREERUN
Specifies the device's internal clock.
Definition: ntv2enums.h:1404
PlayerConfig::fOutputChannel
NTV2Channel fOutputChannel
The device channel to use.
Definition: ntv2democommon.h:315
PlayerConfig::Get
AJALabelValuePairs Get(const bool inCompact=(0)) const
Renders a human-readable representation of me.
Definition: ntv2democommon.cpp:1694
NTV2VideoFormatToString
std::string NTV2VideoFormatToString(const NTV2VideoFormat inValue, const bool inUseFrameRate=false)
Definition: ntv2utils.cpp:6750
GetCSCInputXptFromChannel
NTV2InputXptID GetCSCInputXptFromChannel(const NTV2Channel inCSC, const bool inIsKeyInput=false)
Definition: ntv2signalrouter.cpp:775
NTV2Connection
std::pair< NTV2InputXptID, NTV2OutputXptID > NTV2Connection
This links an NTV2InputXptID and an NTV2OutputXptID.
Definition: ntv2signalrouter.h:38
NTV2_TASK_MODE_INVALID
@ NTV2_TASK_MODE_INVALID
Definition: ntv2publicinterface.h:4293
CNTV2DriverInterface::IsDeviceReady
virtual bool IsDeviceReady(const bool inCheckValid=(0))
Definition: ntv2driverinterface.cpp:1284
kDemoAppSignature
static const ULWord kDemoAppSignature((((uint32_t)( 'D'))<< 24)|(((uint32_t)( 'E'))<< 16)|(((uint32_t)( 'M'))<< 8)|(((uint32_t)( 'O'))<< 0))
NTV2ChannelSet
std::set< NTV2Channel > NTV2ChannelSet
A set of distinct NTV2Channel values.
Definition: ntv2publicinterface.h:3854
NTV2OutputTestPattern::Init
AJAStatus Init(void)
Initializes me and prepares me to Run.
Definition: ntv2outputtestpattern.cpp:58
CNTV2Card::SetEveryFrameServices
virtual bool SetEveryFrameServices(const NTV2EveryFrameTaskMode inMode)
Sets the device's task mode.
Definition: ntv2register.cpp:179
AJA_STATUS_UNSUPPORTED
@ AJA_STATUS_UNSUPPORTED
Definition: types.h:394
AJALabelValuePairsConstIter
AJALabelValuePairs::const_iterator AJALabelValuePairsConstIter
Definition: info.h:70
NTV2TestPatternGen
The NTV2 test pattern generator.
Definition: ntv2testpatterngen.h:69
NTV2ChannelList
std::vector< NTV2Channel > NTV2ChannelList
An ordered sequence of NTV2Channel values.
Definition: ntv2publicinterface.h:3835
NTV2Buffer::GetHostPointer
void * GetHostPointer(void) const
Definition: ntv2publicinterface.h:6049
NTV2_FORMAT_UNKNOWN
@ NTV2_FORMAT_UNKNOWN
Definition: ntv2enums.h:498
TestPatConfig::Get
AJALabelValuePairs Get(const bool inCompact=(0)) const
Definition: ntv2outputtestpattern.cpp:24
AJA_STATUS_INITIALIZE
@ AJA_STATUS_INITIALIZE
Definition: types.h:386
DEC
#define DEC(__x__)
Definition: ntv2publicinterface.h:5605
CNTV2Card::SetSDIOutputStandard
virtual bool SetSDIOutputStandard(const UWord inOutputSpigot, const NTV2Standard inValue)
Sets the SDI output spigot's video standard.
Definition: ntv2register.cpp:3200
NTV2_OUTPUTDESTINATION_HDMI
@ NTV2_OUTPUTDESTINATION_HDMI
Definition: ntv2enums.h:1279
operator<<
std::ostream & operator<<(std::ostream &ioStrm, const TestPatConfig &inObj)
Definition: ntv2outputtestpattern.cpp:31
GetFrameBufferOutputXptFromChannel
NTV2OutputXptID GetFrameBufferOutputXptFromChannel(const NTV2Channel inFrameStore, const bool inIsRGB=false, const bool inIs425=false)
Definition: ntv2signalrouter.cpp:845
PlayerConfig::fDeviceSpec
std::string fDeviceSpec
The AJA device to use.
Definition: ntv2democommon.h:313
NTV2XptConnections
std::map< NTV2InputXptID, NTV2OutputXptID > NTV2XptConnections
Definition: ntv2signalrouter.h:39
NTV2MakeChannelSet
NTV2ChannelSet NTV2MakeChannelSet(const NTV2Channel inFirstChannel, const UWord inNumChannels=1)
Definition: ntv2publicinterface.cpp:3357
std
Definition: json.hpp:5362
IsRGBFormat
bool IsRGBFormat(const NTV2FrameBufferFormat format)
Definition: ntv2utils.cpp:5442
CNTV2MacDriverInterface::AcquireStreamForApplication
virtual bool AcquireStreamForApplication(ULWord inApplicationType, int32_t inProcessID)
Reserves exclusive use of the AJA device for a given process, preventing other processes on the host ...
Definition: ntv2macdriverinterface.cpp:481
CNTV2Card::IsChannelEnabled
virtual bool IsChannelEnabled(const NTV2Channel inChannel, bool &outEnabled)
Answers whether or not the given FrameStore is enabled.
Definition: ntv2register.cpp:2122
CNTV2DriverInterface::GetDeviceID
virtual NTV2DeviceID GetDeviceID(void)
Definition: ntv2driverinterface.cpp:381
CNTV2Card::GetEveryFrameServices
virtual bool GetEveryFrameServices(NTV2EveryFrameTaskMode &outMode)
Retrieves the device's current "retail service" task mode.
Definition: ntv2register.cpp:184
CNTV2Card::DMAWriteFrame
virtual bool DMAWriteFrame(const ULWord inFrameNumber, const ULWord *pInFrameBuffer, const ULWord inByteCount)
Transfers a single frame from the host to the AJA device.
Definition: ntv2dma.cpp:65
CNTV2Card::SetEnableVANCData
virtual bool SetEnableVANCData(const bool inVANCenabled, const bool inTallerVANC, const NTV2Standard inStandard, const NTV2FrameGeometry inGeometry, const NTV2Channel inChannel=NTV2_CHANNEL1)
Definition: ntv2register.cpp:2720
kAppSignature
const uint32_t kAppSignature(((((uint32_t)( 'T'))<< 24)|(((uint32_t)( 'e'))<< 16)|(((uint32_t)( 's'))<< 8)|(((uint32_t)( 't'))<< 0)))
GetNTV2StandardFromVideoFormat
NTV2Standard GetNTV2StandardFromVideoFormat(const NTV2VideoFormat inVideoFormat)
Definition: ntv2utils.cpp:2277
PlayerConfig::fPixelFormat
NTV2PixelFormat fPixelFormat
The pixel format to use.
Definition: ntv2democommon.h:318
NTV2OutputXptID
enum NTV2OutputCrosspointID NTV2OutputXptID
CNTV2Card::SetReference
virtual bool SetReference(const NTV2ReferenceSource inRefSource, const bool inKeepFramePulseSelect=(0))
Sets the device's clock reference source. See Video Output Clocking & Synchronization for more inform...
Definition: ntv2register.cpp:1484
AJA_STATUS_OPEN
@ AJA_STATUS_OPEN
Definition: types.h:388
AJALabelValuePairs
std::vector< AJALabelValuePair > AJALabelValuePairs
An ordered sequence of label/value pairs.
Definition: info.h:69
AJA_FAILURE
#define AJA_FAILURE(_status_)
Definition: types.h:371
CNTV2Card::EnableChannel
virtual bool EnableChannel(const NTV2Channel inChannel)
Enables the given FrameStore.
Definition: ntv2register.cpp:2097
NTV2_MODE_DISPLAY
@ NTV2_MODE_DISPLAY
Playout (output) mode, which reads from device SDRAM.
Definition: ntv2enums.h:1200
NTV2_OUTPUTDESTINATION_ANALOG
@ NTV2_OUTPUTDESTINATION_ANALOG
Definition: ntv2enums.h:1278
DEVICE_ID_NOTFOUND
@ DEVICE_ID_NOTFOUND
Invalid or "not found".
Definition: ntv2enums.h:90
NTV2OutputTestPattern::SetUpVideo
AJAStatus SetUpVideo(void)
Sets up my AJA device to play video.
Definition: ntv2outputtestpattern.cpp:116
NTV2TestPatternGen::setVANCToLegalBlack
NTV2TestPatternGen & setVANCToLegalBlack(const bool inClearVANC)
Changes my "clear VANC lines to legal black" setting.
Definition: ntv2testpatterngen.h:198
CNTV2Card::SetSDIOutLevelAtoLevelBConversion
virtual bool SetSDIOutLevelAtoLevelBConversion(const UWord inOutputSpigot, const bool inEnable)
Enables or disables 3G level A to 3G level B conversion at the SDI output widget (assuming the AJA de...
Definition: ntv2register.cpp:4315
NTV2_OEM_TASKS
@ NTV2_OEM_TASKS
2: OEM: Device is configured by controlling application(s), with minimal driver involvement.
Definition: ntv2publicinterface.h:4292