|
AJA NTV2 SDK
17.5.0.1492
NTV2 SDK 17.5.0.1492
|
Go to the documentation of this file.
28 int main (
int argc,
const char ** argv)
35 int channelNumber (1);
36 int doMultiFormat (0);
45 {
"device",
'd',
POPT_ARG_STRING, &pDeviceSpec, 0,
"device to use",
"index#, serial#, or model" },
46 {
"channel",
'c',
POPT_ARG_INT, &channelNumber, 0,
"channel to use",
"1-8" },
48 {
"pixelFormat",
'p',
POPT_ARG_STRING, &pPixelFormat, 0,
"pixel format to use",
"'?' or 'list' to list" },
49 {
"frames", 0,
POPT_ARG_STRING, &pFramesSpec, 0,
"frames to Stream",
"num[@min] or min-max" },
50 {
"videoFormat",
'v',
POPT_ARG_STRING, &pVideoFormat, 0,
"video format to produce",
"'?' or 'list' to list" },
51 {
"hdrType",
't',
POPT_ARG_INT, &hdrType, 0,
"HDR pkt to send",
"0=none 1=SDR 2=HDR10 3=HLG"},
57 {cerr <<
"## ERROR: " << popt.
errorStr() << endl;
return 2;}
59 {cout << argv[0] <<
", NTV2 SDK " <<
::NTV2Version() << endl;
return 0;}
62 const string deviceSpec (pDeviceSpec ? pDeviceSpec :
"0");
69 if ((channelNumber < 1) || (channelNumber > 8))
70 {cerr <<
"## ERROR: Invalid channel number " << channelNumber <<
" -- expected 1 thru 8" << endl;
return 1;}
74 const string videoFormatStr (pVideoFormat ? pVideoFormat :
"");
77 if (videoFormatStr ==
"?" || videoFormatStr ==
"list")
80 { cerr <<
"## ERROR: Invalid '--videoFormat' value '" << videoFormatStr <<
"' -- expected values:" << endl
86 const string pixelFormatStr (pPixelFormat ? pPixelFormat :
"");
88 if (pixelFormatStr ==
"?" || pixelFormatStr ==
"list")
92 cerr <<
"## ERROR: Invalid '--pixelFormat' value '" << pixelFormatStr <<
"' -- expected values:" << endl
98 static const string legalFramesSpec (
"{frameCount}[@{firstFrameNum}] or {firstFrameNum}-{lastFrameNum}");
99 const string framesSpec (pFramesSpec ? pFramesSpec :
"");
100 if (!framesSpec.empty())
103 if (!parseResult.empty())
104 {cerr <<
"## ERROR: Bad 'frames' spec '" << framesSpec <<
"'\n## " << parseResult << endl;
return 1;}
107 {cerr <<
"## ERROR: Bad 'frames' spec '" << framesSpec <<
"'\n## Expected " << legalFramesSpec << endl;
return 1;}
110 string ancFilePath (pAncFilePath ? pAncFilePath :
"");
117 {cerr <<
"## ERROR: conflicting options '--hdrType' and '--anc'" << endl;
return 2;}
130 {cout <<
"## ERROR: Initialization failed: " <<
::AJAStatusToString(status) << endl;
return 1;}
141 cout <<
" Active Repeat Queue" << endl
142 <<
" Count Count Depth" << endl;
static NTV2VideoFormat GetVideoFormatFromString(const std::string &inStr, const NTV2VideoFormatKinds inKinds=VIDEO_FORMATS_SDHD, const std::string &inDevSpec=std::string())
Returns the NTV2VideoFormat that matches the given string.
static NTV2PixelFormat GetPixelFormatFromString(const std::string &inStr, const NTV2PixelFormatKinds inKinds=PIXEL_FORMATS_ALL, const std::string inDevSpec=std::string())
Returns the NTV2PixelFormat that matches the given string.
@ AJAAncDataType_Unknown
Includes data that is valid, but we don't recognize.
std::string & strip(std::string &str, const std::string &ws)
NTV2Channel
These enum values are mostly used to identify a specific widget_framestore. They're also commonly use...
static bool gGlobalQuit((0))
void SignalHandler(int inSignal)
ULWord GetQueueDepth(void)
Gets the queue depth.
virtual AJAStatus Init(void)
Initializes me and prepares me to Run.
int main(int argc, const char **argv)
bool fDoMultiFormat
If true, enable device-sharing; otherwise take exclusive control of device.
I play out SD or HD test pattern (with timecode) to an output of an AJA device with or without audio ...
std::string setFromString(const std::string &inStr)
NTV2OutputDestination NTV2ChannelToOutputDestination(const NTV2Channel inChannel, const NTV2IOKinds inKinds=NTV2_IOKINDS_SDI)
Converts the given NTV2Channel value into its ordinary equivalent NTV2OutputDestination.
AJAAncDataType fTransmitHDRType
Specifies the HDR anc data packet to transmit, if any.
static bool IsValidDevice(const std::string &inDeviceSpec)
NTV2ACFrameRange fFrames
AutoCirculate frame count or range.
static void Sleep(const int32_t inMilliseconds)
Suspends execution of the current thread for a given number of milliseconds.
bool fSuppressAudio
If true, suppress audio; otherwise generate & xfer audio tone.
bool fSuppressVideo
If true, suppress video; otherwise generate & xfer test patterns.
static std::string GetPixelFormatStrings(const NTV2PixelFormatKinds inKinds=PIXEL_FORMATS_ALL, const std::string inDevSpec=std::string())
NTV2VideoFormat fVideoFormat
The video format to use.
@ NTV2_FBF_8BIT_YCBCR
See 8-Bit YCbCr Format.
NTV2Channel fOutputChannel
The device channel to use.
virtual const std::string & errorStr(void) const
std::string NTV2Version(const bool inDetailed=false)
std::string fAncDataFilePath
Optional path to Anc binary data file to playout.
static std::string GetVideoFormatStrings(const NTV2VideoFormatKinds inKinds=VIDEO_FORMATS_SDHD, const std::string inDevSpec=std::string())
static AJAStatus Open(bool incrementRefCount=false)
virtual AJAStatus Run(void)
Runs me.
bool fTransmitLTC
If true, embed LTC; otherwise embed VITC.
NTV2OutputDest fOutputDest
The desired output connector to use.
std::string AJAStatusToString(const AJAStatus inStatus, const bool inDetailed)
ULWord64 mActiveCount
Number of active transfers.
Configures an NTV2Player instance.
NTV2PixelFormat fPixelFormat
The pixel format to use.
#define NTV2_IS_VALID_FRAME_BUFFER_FORMAT(__s__)
#define AJA_FAILURE(_status_)
ULWord64 mRepeatCount
Number of repeated transfers.
virtual void GetStreamStatus(NTV2StreamChannel &outStatus)
Provides status information about my output (playout) process.
@ AJAAncDataType_HDR_HDR10