diff x265/source/encoder/sei.cpp @ 0:772086c29cc7

Initial import.
author Matti Hamalainen <ccr@tnsp.org>
date Wed, 16 Nov 2016 11:16:33 +0200
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/x265/source/encoder/sei.cpp	Wed Nov 16 11:16:33 2016 +0200
@@ -0,0 +1,74 @@
+/*****************************************************************************
+* Copyright (C) 2013 x265 project
+*
+* Authors: Steve Borho <steve@borho.org>
+*
+* This program is free software; you can redistribute it and/or modify
+* it under the terms of the GNU General Public License as published by
+* the Free Software Foundation; either version 2 of the License, or
+* (at your option) any later version.
+*
+* This program is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+* GNU General Public License for more details.
+*
+* You should have received a copy of the GNU General Public License
+* along with this program; if not, write to the Free Software
+* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111, USA.
+*
+* This program is also available under a commercial proprietary license.
+* For more information, contact us at license @ x265.com.
+*****************************************************************************/
+
+#include "common.h"
+#include "bitstream.h"
+#include "slice.h"
+#include "sei.h"
+
+using namespace X265_NS;
+
+/* x265's identifying GUID */
+const uint8_t SEIuserDataUnregistered::m_uuid_iso_iec_11578[16] = {
+    0x2C, 0xA2, 0xDE, 0x09, 0xB5, 0x17, 0x47, 0xDB,
+    0xBB, 0x55, 0xA4, 0xFE, 0x7F, 0xC2, 0xFC, 0x4E
+};
+
+/* marshal a single SEI message sei, storing the marshalled representation
+ * in bitstream bs */
+void SEI::write(Bitstream& bs, const SPS& sps)
+{
+    BitCounter count;
+    m_bitIf = &count;
+
+    /* virtual writeSEI method, write to bit counter */
+    writeSEI(sps);
+
+    m_bitIf = &bs;
+    uint32_t type = payloadType();
+    for (; type >= 0xff; type -= 0xff)
+        WRITE_CODE(0xff, 8, "payload_type");
+    WRITE_CODE(type, 8, "payload_type");
+
+    X265_CHECK(0 == (count.getNumberOfWrittenBits() & 7), "payload unaligned\n");
+    uint32_t payloadSize = count.getNumberOfWrittenBits() >> 3;
+    for (; payloadSize >= 0xff; payloadSize -= 0xff)
+        WRITE_CODE(0xff, 8, "payload_size");
+    WRITE_CODE(payloadSize, 8, "payload_size");
+
+    /* virtual writeSEI method, write to bs */
+    writeSEI(sps);
+}
+
+void SEI::writeByteAlign()
+{
+    // TODO: expose bs.writeByteAlignment() as virtual function
+    if (m_bitIf->getNumberOfWrittenBits() % 8 != 0)
+    {
+        WRITE_FLAG(1, "bit_equal_to_one");
+        while (m_bitIf->getNumberOfWrittenBits() % 8 != 0)
+        {
+            WRITE_FLAG(0, "bit_equal_to_zero");
+        }
+    }
+}