AJA NTV2 SDK  17.1.3.1410
NTV2 SDK 17.1.3.1410
main.cpp
Go to the documentation of this file.
1 /* SPDX-License-Identifier: MIT */
10 // Includes
11 #include "ntv2ccplayer.h"
12 #include <signal.h>
13 #if defined(MSWindows) || defined(AJAWindows)
14  #define SIGQUIT SIGBREAK
15 #endif
16 
17 
18 using namespace std;
19 
20 
21 // Globals
22 static bool gGlobalQuit (false); // Set this "true" to exit gracefully
23 static bool gQuitImmediately(false); // Set this "true" to exit ungracefully
24 
25 
26 void SignalHandler (int inSignal)
27 {
28  gQuitImmediately = (inSignal != SIG_AJA_STOP);
29  gGlobalQuit = true;
30 }
31 
32 
33 static string GetLine21ChannelNames (const string inDelimiterStr = "|")
34 {
35  static NTV2StringList gChannelNames;
36  if (gChannelNames.empty())
37  for (unsigned enumVal(0); enumVal < NTV2_CC608_XDS; )
38  gChannelNames.push_back(::NTV2Line21ChannelToStr(NTV2Line21Channel(enumVal++)));
39  return aja::join(gChannelNames, inDelimiterStr);
40 }
41 
42 
43 int main (int argc, const char ** argv)
44 {
45  char * pDeviceSpec (AJA_NULL); // Device specifier string, if any
46  char * pPixelFormat (AJA_NULL); // Pixel format argument
47  char * pFramesSpec (AJA_NULL); // AutoCirculate frames spec
48  char * pVideoFormat (AJA_NULL); // Video format to use
49  char * pCaptionChan (AJA_NULL); // Caption channel of interest (cc1, cc2 ... text1, text2, ...)
50  char * pOutputDest (AJA_NULL); // Output connector of interest (sdi1 ... sdi8)
51  char * pMode (AJA_NULL); // Kind of 608 display (roll, paint, pop)?
52  char * pTestPattern (AJA_NULL); // Test pattern to use
53  char * pEndAction (AJA_NULL); // End action (quit, repeat, idle)?
54  char * pCaptionRate (AJA_NULL); // Caption rate (chars/min)
55  int channelNumber (1); // Channel/FrameStore to use
56  int doMultiFormat (0); // MultiFormat mode?
57  int showVersion (0); // Show version?
58  int noAudio (0); // Disable audio tone?
59  int noTimecode (0); // Disable timecode?
60  int forceRTP (0); // Force RTP?
61  int bEmitStats (0); // Emit stats while running?
62  int breakNewLines (0); // Newlines break rows instead of treated as whitespace?
63  int forceVanc (0); // Force use of Vanc?
64  int noLine21 (0); // Suppress line 21 waveform (SD only)?
65  int no608 (0); // Don't transmit CEA608 packets?
66  int no708 (0); // Don't transmit CEA708 packets (HD only)?
67  int doRGBOnWire (0); // Dual-link RGB output? (YUV is default)
68  int doSquares (0); // For UHD/4K, do squares? Otherwise, default to TSI.
69  const string L21ChanNames (::GetLine21ChannelNames());
71 
72  // Command line option descriptions:
73  const CNTV2DemoCommon::PoptOpts optionsTable [] =
74  {
75  {"version", 0, POPT_ARG_NONE, &showVersion, 0, "show version & exit", AJA_NULL },
76  {"device", 'd', POPT_ARG_STRING, &pDeviceSpec, 0, "device to use", "index#, serial#, or model" },
77  {"channel", 'c', POPT_ARG_INT, &channelNumber, 0, "channel to use", "1-8" },
78  {"multiFormat", 'm', POPT_ARG_NONE, &doMultiFormat, 0, "use multi-format/channel", AJA_NULL },
79  {"pixelFormat", 'p', POPT_ARG_STRING, &pPixelFormat, 0, "pixel format to use", "'?' or 'list' to list" },
80  {"frames", 0, POPT_ARG_STRING, &pFramesSpec, 0, "frames to AutoCirculate", "num[@min] or min-max" },
81  {"videoFormat", 'v', POPT_ARG_STRING, &pVideoFormat, 0, "video format to produce", "'?' or 'list' to list" },
82  {"noaudio", 0, POPT_ARG_NONE, &noAudio, 0, "disable audio tone", AJA_NULL },
83 
84  {"output", 'o', POPT_ARG_STRING, &pOutputDest, 0, "output connector to use", "'?' or 'list' to list" },
85  {"pattern", 0, POPT_ARG_STRING, &pTestPattern, 0, "test pattern to use", "'?' or 'list' to list" },
86  {"notimecode", 0, POPT_ARG_NONE, &noTimecode, 0, "disable timecode?", AJA_NULL },
87  {"rgb", 0, POPT_ARG_NONE, &doRGBOnWire, 0, "RGB on SDI?", AJA_NULL },
88  {"squares", 0, POPT_ARG_NONE, &doSquares, 0, "use square routing?", AJA_NULL },
89 
90  {"stats", 's', POPT_ARG_NONE, &bEmitStats, 0, "show queue stats?", AJA_NULL },
91  {"vanc", 0, POPT_ARG_NONE, &forceVanc, 0, "force use of vanc", AJA_NULL },
92  {"noline21", 'n', POPT_ARG_NONE, &noLine21, 0, "disable line 21 wvfrm?", AJA_NULL },
93  {"no608", 0, POPT_ARG_NONE, &no608, 0, "don't xmit 608 packets?", AJA_NULL },
94  {"no708", 0, POPT_ARG_NONE, &no708, 0, "don't xmit 708 packets?", AJA_NULL },
95 
96  // Per-caption-channel options -- specify more than one by separating with comma (e.g., --end loop,idle,idle,loop --608chan cc1,cc2,tx3,tx4)
97  {"end", 'e', POPT_ARG_STRING, &pEndAction, 0, "end action", "exit|loop|idle,..." },
98  {"rate", 'r', POPT_ARG_STRING, &pCaptionRate, 0, "caption rate", "chars/min,..." },
99  {"608mode", 0, POPT_ARG_STRING, &pMode, 0, "608 caption mode", "roll[N]|paint|pop,..." },
100  {"608chan", 0, POPT_ARG_STRING, &pCaptionChan, 0, "608 caption channel", L21ChanNames.c_str() },
101  {"newline", 0, POPT_ARG_NONE, &breakNewLines, 0, "newlines break rows?", AJA_NULL },
104  };
105  CNTV2DemoCommon::Popt popt(argc, argv, optionsTable);
106  NTV2StringList pathList (popt.otherArgs()); // List of text files (paths) to "play"
107  if (!popt)
108  {cerr << "## ERROR: " << popt.errorStr() << endl; return 2;}
109  if (showVersion)
110  {cout << argv[0] << ", NTV2 SDK " << ::NTV2Version() << endl; return 0;}
111 
112  // Device
113  const string deviceSpec (pDeviceSpec ? pDeviceSpec : "0");
114  if (!CNTV2DemoCommon::IsValidDevice(deviceSpec))
115  return 1;
116 
117  CCPlayerConfig config(deviceSpec);
118 
119  // Channel
120  if ((channelNumber < 1) || (channelNumber > 8))
121  {cerr << "## ERROR: Invalid channel number " << channelNumber << " -- expected 1 thru 8" << endl; return 1;}
122  config.fOutputChannel = NTV2Channel(channelNumber - 1);
123 
124  // VideoFormat
125  const string videoFormatStr (pVideoFormat ? pVideoFormat : "");
126  config.fVideoFormat = videoFormatStr.empty() ? NTV2_FORMAT_1080i_5994
128  if (videoFormatStr == "?" || videoFormatStr == "list")
129  {cout << CNTV2DemoCommon::GetVideoFormatStrings(VIDEO_FORMATS_ALL, deviceSpec) << endl; return 0;}
130  else if (!videoFormatStr.empty() && !NTV2_IS_VALID_VIDEO_FORMAT(config.fVideoFormat))
131  { cerr << "## ERROR: Invalid '--videoFormat' value '" << videoFormatStr << "' -- expected values:" << endl
133  return 2;
134  }
135  if (noLine21 && !NTV2_IS_SD_VIDEO_FORMAT(config.fVideoFormat))
136  cerr << "## WARNING: '--noline21' (-n) option specified with non-SD video format '" << ::NTV2VideoFormatToString(config.fVideoFormat) << "'" << endl;
137  if (no708 && NTV2_IS_SD_VIDEO_FORMAT(config.fVideoFormat))
138  cerr << "## WARNING: '--no708' (-n) option specified with SD video format '" << ::NTV2VideoFormatToString(config.fVideoFormat) << "'" << endl;
139  if (noLine21 && no608 && NTV2_IS_SD_VIDEO_FORMAT(config.fVideoFormat))
140  cerr << "## WARNING: '--noline21' and '--no608' options will result in no captions in SD" << endl;
141  if (no608 && no708 && !NTV2_IS_SD_VIDEO_FORMAT(config.fVideoFormat))
142  cerr << "## WARNING: '--no608' and '--no708' options will result in no captions in HD" << endl;
144  no708 = true;
145  else
146  noLine21 = true;
147 
148  // Pixel Format
149  const string pixelFormatStr (pPixelFormat ? pPixelFormat : "");
150  config.fPixelFormat = pixelFormatStr.empty() ? NTV2_FBF_8BIT_YCBCR : CNTV2DemoCommon::GetPixelFormatFromString(pixelFormatStr);
151  if (pixelFormatStr == "?" || pixelFormatStr == "list")
152  {cout << CNTV2DemoCommon::GetPixelFormatStrings(PIXEL_FORMATS_ALL, deviceSpec) << endl; return 0;}
153  else if (!pixelFormatStr.empty() && !NTV2_IS_VALID_FRAME_BUFFER_FORMAT(config.fPixelFormat))
154  {
155  cerr << "## ERROR: Invalid '--pixelFormat' value '" << pixelFormatStr << "' -- expected values:" << endl
157  return 2;
158  }
159 
160  // AutoCirculate Frames
161  static const string legalFramesSpec ("{frameCount}[@{firstFrameNum}] or {firstFrameNum}-{lastFrameNum}");
162  const string framesSpec (pFramesSpec ? pFramesSpec : "");
163  if (!framesSpec.empty())
164  {
165  const string parseResult(config.fFrames.setFromString(framesSpec));
166  if (!parseResult.empty())
167  {cerr << "## ERROR: Bad 'frames' spec '" << framesSpec << "'\n## " << parseResult << endl; return 1;}
168  }
169  if (!config.fFrames.valid())
170  {cerr << "## ERROR: Bad 'frames' spec '" << framesSpec << "'\n## Expected " << legalFramesSpec << endl; return 1;}
171 
172  // Output Spigot
173  const string legalOutputs (CNTV2DemoCommon::GetOutputDestinationStrings(deviceSpec));
174  const string outputDestStr (pOutputDest ? CNTV2DemoCommon::ToLower(string(pOutputDest)) : "");
176  if (outputDestStr == "?" || outputDestStr == "list")
177  {cout << legalOutputs << endl; return 0;}
178  if (!outputDestStr.empty())
179  {
180  outputSpigot = CNTV2DemoCommon::GetOutputDestinationFromString(outputDestStr);
181  if (!NTV2_IS_VALID_OUTPUT_DEST(outputSpigot))
182  {cerr << "## ERROR: Output '" << outputDestStr << "' not of:" << endl << legalOutputs << endl; return 1;}
183  } // if output spigot specified
184 
185  if (!NTV2_IS_VALID_OUTPUT_DEST(outputSpigot) && !NTV2_IS_VALID_CHANNEL(config.fOutputChannel))
186  {
187  config.fOutputChannel = NTV2_CHANNEL1;
188  outputSpigot = ::NTV2ChannelToOutputDestination(config.fOutputChannel);
189  }
190  else if (!NTV2_IS_VALID_OUTPUT_DEST(outputSpigot) && NTV2_IS_VALID_CHANNEL(config.fOutputChannel))
191  outputSpigot = ::NTV2ChannelToOutputDestination(config.fOutputChannel);
192  else if (NTV2_IS_VALID_OUTPUT_DEST(outputSpigot) && !NTV2_IS_VALID_CHANNEL(config.fOutputChannel))
193  config.fOutputChannel = ::NTV2OutputDestinationToChannel(outputSpigot);
194 
195  // Test Pattern
196  string testPattern(pTestPattern ? pTestPattern : "");
197  if (testPattern == "?" || testPattern == "list")
198  {cout << CNTV2DemoCommon::GetTestPatternStrings() << endl; return 0;}
199  if (!testPattern.empty())
200  {
201  testPattern = CNTV2DemoCommon::GetTestPatternNameFromString(testPattern);
202  if (testPattern.empty())
203  {
204  cerr << "## ERROR: Invalid '--pattern' value '" << pTestPattern << "' -- expected values:" << endl
206  return 2;
207  }
208  }
209  else
210  testPattern = "Flat Field";
211 
212  // NOTE: From one command line invocation, you can inject different captions into separate caption channels.
213  // For example:
214  // ./bin/ntv2ccplayer --device kona4 --channel 3 --stats --608chan cc1,cc2,cc3,cc4,tx1,tx2,tx3,tx4
215  // --608mode pop,paint,roll3,roll4 --rate 1000,700,500,300,200
216  // --end idle,loop,idle,loop,idle,loop,idle,loop
217  // English.txt Spanish.txt French.txt German.txt txt1 txt2 txt3 txt4
218 
219  // Users can play one or more caption channels by specifying more than one, separating each with a comma:
220  // --608chan cc2,cc4,tx1,tx2
221  // You can vary the mode, end-action and rate for each caption channel in the same way:
222  // --608mode pop,paint,roll --rate 1500,800,300,600
223  const NTV2StringList sCaptionChannels(aja::split(CNTV2DemoCommon::ToLower(pCaptionChan ? pCaptionChan : "CC1"), ','));
224  const NTV2StringList sCaptionModes (aja::split(CNTV2DemoCommon::ToLower(pMode ? pMode : "roll4"), ','));
225  const NTV2StringList sEndActions (aja::split(CNTV2DemoCommon::ToLower(pEndAction ? pEndAction : "exit"), ','));
226  const NTV2StringList sCaptionRates (aja::split(CNTV2DemoCommon::ToLower(pCaptionRate ? pCaptionRate : "500"), ','));
227  size_t ndx (0);
228  size_t fileNdx (0);
229 
230  for (NTV2StringListConstIter iter (sCaptionChannels.begin()); iter != sCaptionChannels.end(); ++iter, ++ndx)
231  {
232  CCGenConfig generatorConfig;
233 
234  // Caption Channel
235  generatorConfig.fCaptionChannel = ::StrToNTV2Line21Channel (*iter);
236  if (!IsValidLine21Channel (generatorConfig.fCaptionChannel) || IsLine21XDSChannel (generatorConfig.fCaptionChannel))
237  {cerr << "## ERROR: Bad '608chan' value '" << pCaptionChan << "' -- expected '" << ::GetLine21ChannelNames () << "'" << endl; return 1;}
238 
239  // Caption Mode
240  const string sCaptionMode (ndx < sCaptionModes.size() ? sCaptionModes.at(ndx) : sCaptionModes.back());
241  if (sCaptionMode == "") generatorConfig.fCaptionMode = NTV2_CC608_CapModeUnknown;
242  else if (sCaptionMode == "pop") generatorConfig.fCaptionMode = NTV2_CC608_CapModePopOn;
243  else if (sCaptionMode == "paint") generatorConfig.fCaptionMode = NTV2_CC608_CapModePaintOn;
244  else if (sCaptionMode == "roll2") generatorConfig.fCaptionMode = NTV2_CC608_CapModeRollUp2;
245  else if (sCaptionMode == "roll3") generatorConfig.fCaptionMode = NTV2_CC608_CapModeRollUp3;
246  else if (sCaptionMode == "roll" || sCaptionMode == "roll4") generatorConfig.fCaptionMode = NTV2_CC608_CapModeRollUp4;
247  else {cerr << "## ERROR: Bad '608mode' parameter '" << sCaptionMode << "'" << endl; return 1;}
248 
249  if (IsLine21TextChannel (generatorConfig.fCaptionChannel))
250  generatorConfig.fCaptionMode = NTV2_CC608_CapModeUnknown; // Must use unknown caption mode for TX caption channels
251 
252  // Newline
253  generatorConfig.fNewLinesAreNewRows = breakNewLines ? true : false;
254  if (IsLine21TextChannel (generatorConfig.fCaptionChannel))
255  generatorConfig.fNewLinesAreNewRows = true; // Tx1/Tx2/Tx3/Tx4 always break rows on newLine chars
256 
257  // End Action
258  const string sEndAction (ndx < sEndActions.size() ? sEndActions.at(ndx) : sEndActions.back());
259  if (sEndAction.empty () || sEndAction == "quit" || sEndAction == "exit" || sEndAction == "terminate" || sEndAction == "end")
260  generatorConfig.fEndAction = AtEndAction_Quit;
261  else if (sEndAction == "loop" || sEndAction == "repeat")
262  generatorConfig.fEndAction = AtEndAction_Repeat;
263  else if (sEndAction == "sleep" || sEndAction == "idle" || sEndAction == "rest")
264  generatorConfig.fEndAction = AtEndAction_Idle;
265  else
266  {cerr << "## ERROR: Bad 'end' parameter '" << sEndAction << "' -- expected 'loop|repeat | rest|sleep|idle | quit|end|exit|terminate'" << endl; return 1;}
267 
268  // Caption Rate
269  const string sCaptionRate (ndx < sCaptionRates.size() ? sCaptionRates.at(ndx) : sCaptionRates.back());
270  istringstream iss(sCaptionRate);
271  uint32_t charsPerMin;
272  iss >> charsPerMin;
273  generatorConfig.fCharsPerMinute = double(charsPerMin);
274 
275  if (!pathList.empty())
276  { // Text Files to Play
277  generatorConfig.fFilesToPlay.push_back (fileNdx < pathList.size() ? pathList.at(fileNdx) : pathList.back());
278  ++fileNdx;
279  if ((ndx+1) == sCaptionChannels.size())
280  while (fileNdx < pathList.size())
281  generatorConfig.fFilesToPlay.push_back (pathList.at (fileNdx++));
282  }
283  config.fCapChanGenConfigs [generatorConfig.fCaptionChannel] = generatorConfig; // Add this generator to the player configuration
284  } // for each specified caption channel
285 
286  config.fTestPatternName = testPattern;
287  config.fOutputDest = outputSpigot;
288  config.fForceRTP = uint16_t(forceRTP);
289  config.fVancMode = forceVanc ? NTV2_VANCMODE_TALLER : NTV2_VANCMODE_OFF;
290  config.fDoMultiFormat = doMultiFormat ? true : false; // Multiformat mode?
291  config.fDoTsiRouting = doSquares ? false : true;
292  config.fDoRGBOnWire = doRGBOnWire ? true : false;
293  config.fSuppressLine21 = noLine21 ? true : false;
294  config.fSuppress608 = no608 ? true : false;
295  config.fSuppress708 = no708 ? true : false;
296  config.fSuppressAudio = noAudio ? true : false;
297  config.fSuppressTimecode = noTimecode ? true : false;
298  config.fEmitStats = bEmitStats ? true : false;
299 
300  // Instantiate and initialize the NTV2CCPlayer object...
301  NTV2CCPlayer player(config);
302  AJAStatus status = player.Init();
303  if (AJA_FAILURE(status))
304  {cout << "## ERROR: Initialization failed: " << ::AJAStatusToString(status) << endl; return 1;}
305 
306  ::signal (SIGINT, SignalHandler);
307  #if defined (AJAMac)
308  ::signal (SIGHUP, SignalHandler);
309  ::signal (SIGQUIT, SignalHandler);
310  #endif
311 
312  // Run it...
313  player.Run();
314 
315  size_t msgsQued (0), bytesQued (0), totMsgsEnq (0), totBytesEnq (0), totMsgsDeq (0), totBytesDeq (0), maxQueDepth (0), droppedFrames (0);
316  if (bEmitStats)
317  cout << " Current Current Total Total Total Total Max " << endl
318  << " Messages Bytes Messages Bytes Messages Bytes Queue Dropped" << endl
319  << " Queued Queued Enqueued Enqueued Dequeued Dequeued Depth Frames" << endl;
320 
321  // Loop until we're told to stop...
322  do
323  { // Poll the player's encoder's status until stopped...
324  player.GetStatus (msgsQued, bytesQued, totMsgsEnq, totBytesEnq, totMsgsDeq, totBytesDeq, maxQueDepth, droppedFrames);
325  if (bEmitStats)
326  cout << setw(9) << msgsQued
327  << setw(9) << bytesQued
328  << setw(9) << totMsgsEnq
329  << setw(9) << totBytesEnq
330  << setw(9) << totMsgsDeq
331  << setw(9) << totBytesDeq
332  << setw(9) << maxQueDepth
333  << setw(9) << droppedFrames << "\r" << flush;
334  } while (!gGlobalQuit); // loop til done
335 
336  // Ask the player to stop...
337  player.Quit (gQuitImmediately);
338 
339  player.GetStatus (msgsQued, bytesQued, totMsgsEnq, totBytesEnq, totMsgsDeq, totBytesDeq, maxQueDepth, droppedFrames);
340  cout << endl
341  << msgsQued << " message(s) left in queue" << endl
342  << bytesQued << " byte(s) left in queue" << endl
343  << totMsgsEnq << " total message(s) enqueued" << endl
344  << totBytesEnq << " total byte(s) enqueued" << endl
345  << totMsgsDeq << " total message(s) dequeued" << endl
346  << totBytesDeq << " total byte(s) dequeued" << endl
347  << maxQueDepth << " maximum message(s) enqueued" << endl;
348  return 0;
349 
350 } // main
NTV2CCPlayer
I am an object that can inject text captions into an SDI output of an AJA device in real time....
Definition: ntv2ccplayer.h:125
CNTV2DemoCommon::Popt::otherArgs
virtual const NTV2StringList & otherArgs(void) const
Definition: ntv2democommon.h:810
CNTV2DemoCommon::GetVideoFormatStrings
static std::string GetVideoFormatStrings(const NTV2VideoFormatKinds inKinds=VIDEO_FORMATS_NON_4KUHD, const std::string inDeviceSpecifier=std::string())
Definition: ntv2democommon.cpp:550
NTV2_IS_SD_VIDEO_FORMAT
#define NTV2_IS_SD_VIDEO_FORMAT(__f__)
Definition: ntv2enums.h:707
NTV2OutputDestination
NTV2OutputDestination
Identifies a specific video output destination.
Definition: ntv2enums.h:1276
poptOption
Definition: options_popt.h:148
gQuitImmediately
static bool gQuitImmediately((0))
CNTV2DemoCommon::GetOutputDestinationStrings
static std::string GetOutputDestinationStrings(const std::string inDeviceSpecifier=std::string())
Definition: ntv2democommon.cpp:715
NTV2Channel
NTV2Channel
These enum values are mostly used to identify a specific widget_framestore. They're also commonly use...
Definition: ntv2enums.h:1305
CCGenConfig::fNewLinesAreNewRows
bool fNewLinesAreNewRows
If true, newlines break caption rows; otherwise are treated as whitespace.
Definition: ntv2ccplayer.h:50
CCPlayerConfig::fForceRTP
uint16_t fForceRTP
BIT(0):0=normal,1=forceRTP BIT(1):0=uniPkt,1=multiPkt BIT(2):0=normal,1=patchDeviceID.
Definition: ntv2ccplayer.h:88
aja::join
std::string join(const std::vector< std::string > &parts, const std::string &delim)
Definition: common.cpp:468
aja::split
void split(const std::string &str, const char delim, std::vector< std::string > &elems)
Definition: common.cpp:350
AtEndAction_Idle
@ AtEndAction_Idle
Repeat the file list (must Ctrl-C to terminate)
Definition: ntv2ccplayer.h:31
CCPlayerConfig
Configures an NTV2CCPlayer instance.
Definition: ntv2ccplayer.h:80
CCGenConfig::fCaptionMode
NTV2Line21Mode fCaptionMode
The CEA-608 caption mode to use.
Definition: ntv2ccplayer.h:48
NTV2_CC608_CapModePaintOn
@ NTV2_CC608_CapModePaintOn
Paint-on caption mode.
Definition: ntv2caption608types.h:131
SignalHandler
void SignalHandler(int inSignal)
Definition: main.cpp:26
GetLine21ChannelNames
static string GetLine21ChannelNames(const string inDelimiterStr="|")
Definition: main.cpp:33
NTV2_FORMAT_1080i_5994
@ NTV2_FORMAT_1080i_5994
Definition: ntv2enums.h:512
CCPlayerConfig::fSuppressTimecode
bool fSuppressTimecode
If true, suppress timecode; otherwise embed VITC/LTC.
Definition: ntv2ccplayer.h:87
NTV2OutputDestinationToChannel
NTV2Channel NTV2OutputDestinationToChannel(const NTV2OutputDestination inOutputDest)
Converts a given NTV2OutputDestination to its equivalent NTV2Channel value.
Definition: ntv2utils.cpp:5213
CCGenConfig::fFilesToPlay
NTV2StringList fFilesToPlay
A list of zero or more strings containing paths to text files to be "played".
Definition: ntv2ccplayer.h:46
main
int main(int argc, const char **argv)
Definition: main.cpp:30
CCPlayerConfig::fCapChanGenConfigs
CaptionChanGenMap fCapChanGenConfigs
Caption channel generator configs.
Definition: ntv2ccplayer.h:90
CCGenConfig::fCaptionChannel
NTV2Line21Channel fCaptionChannel
The caption channel to use.
Definition: ntv2ccplayer.h:49
PlayerConfig::fDoMultiFormat
bool fDoMultiFormat
If true, enable device-sharing; otherwise take exclusive control of device.
Definition: ntv2democommon.h:323
NTV2_IS_VALID_OUTPUT_DEST
#define NTV2_IS_VALID_OUTPUT_DEST(_dest_)
Definition: ntv2enums.h:1295
NTV2ACFrameRange::setFromString
std::string setFromString(const std::string &inStr)
Definition: ntv2utils.cpp:4155
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
POPT_ARG_INT
#define POPT_ARG_INT
Definition: options_popt.h:58
CNTV2DemoCommon::GetVideoFormatFromString
static NTV2VideoFormat GetVideoFormatFromString(const std::string &inStr, const NTV2VideoFormatKinds inKinds=VIDEO_FORMATS_NON_4KUHD)
Returns the NTV2VideoFormat that matches the given string.
Definition: ntv2democommon.cpp:635
PlayerConfig::fDoTsiRouting
bool fDoTsiRouting
If true, enable TSI routing; otherwise route for square division (4K/8K)
Definition: ntv2democommon.h:329
IsLine21XDSChannel
#define IsLine21XDSChannel(_chan_)
Definition: ntv2caption608types.h:105
VIDEO_FORMATS_ALL
@ VIDEO_FORMATS_ALL
Definition: ntv2democommon.h:224
POPT_AUTOHELP
#define POPT_AUTOHELP
Definition: options_popt.h:220
NTV2CCPlayer::Init
virtual AJAStatus Init(void)
Initializes me and prepares me to Run.
Definition: ntv2ccplayer.cpp:944
CNTV2DemoCommon::IsValidDevice
static bool IsValidDevice(const std::string &inDeviceSpec)
Definition: ntv2democommon.cpp:430
AJAStatus
AJAStatus
Definition: types.h:378
NTV2ChannelToOutputDestination
NTV2OutputDestination NTV2ChannelToOutputDestination(const NTV2Channel inChannel)
Converts the given NTV2Channel value into its ordinary equivalent NTV2OutputDestination.
Definition: ntv2utils.cpp:5225
ntv2ccplayer.h
CNTV2DemoCommon::GetTestPatternStrings
static std::string GetTestPatternStrings(void)
Definition: ntv2democommon.cpp:889
PlayerConfig::fFrames
NTV2ACFrameRange fFrames
AutoCirculate frame count or range.
Definition: ntv2democommon.h:317
CCGenConfig::fEndAction
AtEndAction fEndAction
The action to take after the file list has finished playing.
Definition: ntv2ccplayer.h:47
CCPlayerConfig::fEmitStats
bool fEmitStats
If true, show stats while playing; otherwise echo caption text being played.
Definition: ntv2ccplayer.h:83
NTV2_VANCMODE_OFF
@ NTV2_VANCMODE_OFF
This identifies the mode in which there are no VANC lines in the frame buffer.
Definition: ntv2enums.h:3718
CNTV2DemoCommon::ToLower
static std::string ToLower(const std::string &inStr)
Returns the given string after converting it to lower case.
Definition: ntv2democommon.cpp:926
NTV2_CC608_CapModeUnknown
@ NTV2_CC608_CapModeUnknown
Unknown or invalid caption mode.
Definition: ntv2caption608types.h:126
PlayerConfig::fSuppressAudio
bool fSuppressAudio
If true, suppress audio; otherwise generate audio tone.
Definition: ntv2democommon.h:324
CCPlayerConfig::fSuppress608
bool fSuppress608
If true, don't transmit CEA608 packets; otherwise include 608 packets.
Definition: ntv2ccplayer.h:85
CNTV2DemoCommon::GetPixelFormatFromString
static NTV2FrameBufferFormat GetPixelFormatFromString(const std::string &inStr)
Returns the NTV2FrameBufferFormat that matches the given string.
Definition: ntv2democommon.cpp:653
CCGenConfig
This class is used to configure a caption generator for a single caption channel.
Definition: ntv2ccplayer.h:43
IsValidLine21Channel
#define IsValidLine21Channel(_chan_)
Definition: ntv2caption608types.h:102
AtEndAction_Repeat
@ AtEndAction_Repeat
Terminate.
Definition: ntv2ccplayer.h:30
PIXEL_FORMATS_ALL
@ PIXEL_FORMATS_ALL
Definition: ntv2democommon.h:240
StrToNTV2Line21Channel
NTV2Line21Channel StrToNTV2Line21Channel(const std::string &inStr)
Converts the given string into the equivalent NTV2Line21Channel value.
PlayerConfig::fVideoFormat
NTV2VideoFormat fVideoFormat
The video format to use.
Definition: ntv2democommon.h:319
NTV2_FBF_8BIT_YCBCR
@ NTV2_FBF_8BIT_YCBCR
See 8-Bit YCbCr Format.
Definition: ntv2enums.h:211
CNTV2DemoCommon::Popt
Definition: ntv2democommon.h:801
PlayerConfig::fOutputChannel
NTV2Channel fOutputChannel
The device channel to use.
Definition: ntv2democommon.h:315
CNTV2DemoCommon::Popt::errorStr
virtual const std::string & errorStr(void) const
Definition: ntv2democommon.h:809
NTV2Version
std::string NTV2Version(const bool inDetailed=false)
Definition: ntv2version.cpp:41
NTV2VideoFormatToString
std::string NTV2VideoFormatToString(const NTV2VideoFormat inValue, const bool inUseFrameRate=false)
Definition: ntv2utils.cpp:6750
CCPlayerConfig::fSuppressLine21
bool fSuppressLine21
SD output only: if true, do not encode Line 21 waveform; otherwise encode Line 21 waveform.
Definition: ntv2ccplayer.h:84
gGlobalQuit
static bool gGlobalQuit((0))
NTV2_CC608_XDS
@ NTV2_CC608_XDS
Definition: ntv2caption608types.h:95
NTV2_CC608_CapModeRollUp4
@ NTV2_CC608_CapModeRollUp4
4-row roll-up from bottom
Definition: ntv2caption608types.h:130
CNTV2DemoCommon::GetTestPatternNameFromString
static std::string GetTestPatternNameFromString(const std::string &inStr)
Definition: ntv2democommon.cpp:917
NTV2StringList
std::vector< std::string > NTV2StringList
Definition: ntv2utils.h:1134
IsLine21TextChannel
#define IsLine21TextChannel(_chan_)
Definition: ntv2caption608types.h:104
AJADebug::Open
static AJAStatus Open(bool incrementRefCount=false)
Definition: debug.cpp:44
AJA_NULL
#define AJA_NULL
Definition: ajatypes.h:197
NTV2_IS_VALID_CHANNEL
#define NTV2_IS_VALID_CHANNEL(__x__)
Definition: ntv2enums.h:1319
CNTV2DemoCommon::GetOutputDestinationFromString
static NTV2OutputDestination GetOutputDestinationFromString(const std::string &inStr)
Returns the NTV2OutputDestination that matches the given string.
Definition: ntv2democommon.cpp:743
NTV2_CC608_CapModeRollUp2
@ NTV2_CC608_CapModeRollUp2
2-row roll-up from bottom
Definition: ntv2caption608types.h:128
NTV2_VANCMODE_TALLER
@ NTV2_VANCMODE_TALLER
This identifies the mode in which there are some + extra VANC lines in the frame buffer.
Definition: ntv2enums.h:3720
PlayerConfig::fDoRGBOnWire
bool fDoRGBOnWire
If true, produce RGB on the wire; otherwise output YUV.
Definition: ntv2democommon.h:330
NTV2Line21ChannelToStr
const std::string & NTV2Line21ChannelToStr(const NTV2Line21Channel inLine21Channel, const bool inCompact=true)
Converts the given NTV2Line21Channel value into a human-readable string.
PlayerConfig::fOutputDest
NTV2OutputDest fOutputDest
The desired output connector to use.
Definition: ntv2democommon.h:316
false
#define false
Definition: ntv2devicefeatures.h:25
NTV2_OUTPUTDESTINATION_INVALID
@ NTV2_OUTPUTDESTINATION_INVALID
Definition: ntv2enums.h:1288
NTV2Line21Channel
NTV2Line21Channel
The CEA-608 caption channels: CC1 thru CC4, TX1 thru TX4, plus XDS.
Definition: ntv2caption608types.h:82
std
Definition: json.hpp:5362
CCPlayerConfig::fTestPatternName
std::string fTestPatternName
The test pattern to use.
Definition: ntv2ccplayer.h:89
AJAStatusToString
std::string AJAStatusToString(const AJAStatus inStatus, const bool inDetailed)
Definition: debug.cpp:981
POPT_TABLEEND
#define POPT_TABLEEND
Definition: options_popt.h:215
NTV2_CC608_CapModeRollUp3
@ NTV2_CC608_CapModeRollUp3
3-row roll-up from bottom
Definition: ntv2caption608types.h:129
NTV2CCPlayer::Quit
virtual void Quit(const bool inQuitImmediately=(0))
Stops me.
Definition: ntv2ccplayer.cpp:893
true
#define true
Definition: ntv2devicefeatures.h:26
NTV2CCPlayer::Run
virtual AJAStatus Run(void)
Runs me.
Definition: ntv2ccplayer.cpp:1350
CCPlayerConfig::fSuppress708
bool fSuppress708
If true, don't transmit CEA708 packets; otherwise include 708 packets.
Definition: ntv2ccplayer.h:86
CNTV2DemoCommon::GetPixelFormatStrings
static std::string GetPixelFormatStrings(const NTV2PixelFormatKinds inKinds=PIXEL_FORMATS_ALL, const std::string inDeviceSpecifier=std::string())
Definition: ntv2democommon.cpp:600
NTV2StringListConstIter
NTV2StringList::const_iterator NTV2StringListConstIter
Definition: ntv2utils.h:1136
NTV2ACFrameRange::valid
bool valid(void) const
Definition: ntv2utils.h:977
PlayerConfig::fPixelFormat
NTV2PixelFormat fPixelFormat
The pixel format to use.
Definition: ntv2democommon.h:318
CCGenConfig::fCharsPerMinute
double fCharsPerMinute
The rate at which caption characters get enqueued, in characters per minute.
Definition: ntv2ccplayer.h:51
NTV2_IS_VALID_FRAME_BUFFER_FORMAT
#define NTV2_IS_VALID_FRAME_BUFFER_FORMAT(__s__)
Definition: ntv2enums.h:251
SIG_AJA_STOP
#define SIG_AJA_STOP
Definition: ntv2ccplayer.h:21
NTV2CCPlayer::GetStatus
virtual void GetStatus(size_t &outMessagesQueued, size_t &outBytesQueued, size_t &outTotMsgsEnq, size_t &outTotBytesEnq, size_t &outTotMsgsDeq, size_t &outTotBytesDeq, size_t &outMaxQueDepth, size_t &outDroppedFrames) const
Returns status information from my caption encoder.
Definition: ntv2ccplayer.cpp:1825
AJA_FAILURE
#define AJA_FAILURE(_status_)
Definition: types.h:371
NTV2_CC608_CapModePopOn
@ NTV2_CC608_CapModePopOn
Pop-on caption mode.
Definition: ntv2caption608types.h:127
POPT_ARG_STRING
#define POPT_ARG_STRING
Definition: options_popt.h:57
POPT_ARG_NONE
#define POPT_ARG_NONE
Definition: options_popt.h:56
NTV2_IS_VALID_VIDEO_FORMAT
#define NTV2_IS_VALID_VIDEO_FORMAT(__f__)
Definition: ntv2enums.h:688
AtEndAction_Quit
@ AtEndAction_Quit
Definition: ntv2ccplayer.h:29