// qvideoframe.sip generated by MetaSIP on Fri Feb 10 10:37:54 2012 // // This file is part of the QtMultimedia Python extension module. // // Copyright (c) 2011 Riverbank Computing Limited // // This file is part of PyQt. // // This file may be used under the terms of the GNU General Public // License versions 2.0 or 3.0 as published by the Free Software // Foundation and appearing in the files LICENSE.GPL2 and LICENSE.GPL3 // included in the packaging of this file. Alternatively you may (at // your option) use any later version of the GNU General Public // License if such license has been publicly approved by Riverbank // Computing Limited (or its successors, if any) and the KDE Free Qt // Foundation. In addition, as a special exception, Riverbank gives you // certain additional rights. These rights are described in the Riverbank // GPL Exception version 1.1, which can be found in the file // GPL_EXCEPTION.txt in this package. // // If you are unsure which license is appropriate for your use, please // contact the sales department at sales@riverbankcomputing.com. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. %If (Qt_4_6_0 -) class QVideoFrame { %TypeHeaderCode #include %End public: enum FieldType { ProgressiveFrame, TopField, BottomField, InterlacedFrame, }; enum PixelFormat { Format_Invalid, Format_ARGB32, Format_ARGB32_Premultiplied, Format_RGB32, Format_RGB24, Format_RGB565, Format_RGB555, Format_ARGB8565_Premultiplied, Format_BGRA32, Format_BGRA32_Premultiplied, Format_BGR32, Format_BGR24, Format_BGR565, Format_BGR555, Format_BGRA5658_Premultiplied, Format_AYUV444, Format_AYUV444_Premultiplied, Format_YUV444, Format_YUV420P, Format_YV12, Format_UYVY, Format_YUYV, Format_NV12, Format_NV21, Format_IMC1, Format_IMC2, Format_IMC3, Format_IMC4, Format_Y8, Format_Y16, Format_User, }; QVideoFrame(); QVideoFrame(QAbstractVideoBuffer *buffer, const QSize &size, QVideoFrame::PixelFormat format); QVideoFrame(int bytes, const QSize &size, int bytesPerLine, QVideoFrame::PixelFormat format); QVideoFrame(const QImage &image); QVideoFrame(const QVideoFrame &other); ~QVideoFrame(); bool isValid() const; QVideoFrame::PixelFormat pixelFormat() const; QAbstractVideoBuffer::HandleType handleType() const; QSize size() const; int width() const; int height() const; QVideoFrame::FieldType fieldType() const; void setFieldType(QVideoFrame::FieldType); bool isMapped() const; bool isReadable() const; bool isWritable() const; QAbstractVideoBuffer::MapMode mapMode() const; bool map(QAbstractVideoBuffer::MapMode mode); void unmap(); int bytesPerLine() const; SIP_PYOBJECT bits() /DocType="sip.voidptr"/; %MethodCode uchar *mem; Py_BEGIN_ALLOW_THREADS mem = sipCpp->bits(); Py_END_ALLOW_THREADS if (mem) { sipRes = sipConvertFromVoidPtrAndSize(mem, sipCpp->mappedBytes()); } else { sipRes = Py_None; Py_INCREF(sipRes); } %End int mappedBytes() const; QVariant handle() const; qint64 startTime() const; void setStartTime(qint64 time); qint64 endTime() const; void setEndTime(qint64 time); static QVideoFrame::PixelFormat pixelFormatFromImageFormat(QImage::Format format); static QImage::Format imageFormatFromPixelFormat(QVideoFrame::PixelFormat format); }; %End %If (Qt_4_6_0 -) // Mapped type for QList. %MappedType QList /DocType="list-of-QVideoFrame.PixelFormat"/ { %TypeHeaderCode #include %End %ConvertFromTypeCode // Create the list. PyObject *l; if ((l = PyList_New(sipCpp->size())) == NULL) return NULL; // Set the list elements. for (int i = 0; i < sipCpp->size(); ++i) { QVideoFrame::PixelFormat e = sipCpp->at(i); PyObject *eobj; if ((eobj = sipConvertFromEnum(e, sipType_QVideoFrame_PixelFormat)) == NULL) { Py_DECREF(l); return NULL; } PyList_SET_ITEM(l, i, eobj); } return l; %End %ConvertToTypeCode // Check the type if that is all that is required. if (sipIsErr == NULL) { if (!PyList_Check(sipPy)) return 0; for (SIP_SSIZE_T i = 0; i < PyList_GET_SIZE(sipPy); ++i) if (!sipCanConvertToEnum(PyList_GET_ITEM(sipPy, i), sipType_QVideoFrame_PixelFormat)) return 0; return 1; } QList *ql = new QList; for (SIP_SSIZE_T i = 0; i < PyList_GET_SIZE(sipPy); ++i) { long l = SIPLong_AsLong(PyList_GET_ITEM(sipPy, i)); ql->append(static_cast(l)); } *sipCppPtr = ql; return sipGetState(sipTransferObj); %End }; %End