سؤال

أنا أكتب تطبيق عميل يتدفق السلس. على جانب الخادم (IIS 7 مع امتدادات خدمات الوسائط) ، لدي مجموعة من ملفات ISMV و ISMA المشفرة باستخدام Expression Encoder Pro 4 مع "H.264 IIS Smooth Treaming WiFi". باختصار ، يستخدم برنامج ترميز الفيديو "H.264 الأساسي" ، وبرنامج ترميز الصوت AAC-LC.

ولكن على جانب العميل هو المكان الذي أواجه فيه مشاكل ، وتحديداً مع قطع الصوت. على الرغم من أنني تمكنت من فهم دفق الفيديو H.264 (إنه في الأساس سلسلة من وحدات NAL الخام المسبقة بطولها ، دون وحدة بدء "رمز البدء" 0 ، 0 ، 0 ، 1) ، ما زلت هافن تمكنت من كسر ما يوجد داخل دفق الصوت AAC LC ، أي ما يأتي في ذرة "MDAT" (مربع بيانات الوسائط). هو بالتأكيد ليس حاوية MP4 ، ولكن ما هو إذن؟

أنا ألصق أقل من 128 (رقم تم اختياره بشكل تعسفي) بايت شظية AAC-LC واحدة (جزء MDAT فقط) تم الحصول عليها من الخادم ، في حالة تمكن أي شخص من اكتشافه من هناك.

unsigned char data[128] = {
 0x21, 0x09, 0x0A, 0xBF, 0xBF, 0xFF, 0xFF, 0xD5, 0xB1, 0x8D, 0xC4, 0xA1,
 0x18, 0x0D, 0x25, 0xC9, 0x2E, 0x49, 0x2E, 0x10, 0x88, 0x91, 0x10, 0x01,
 0x13, 0x23, 0x2C, 0x36, 0x25, 0x60, 0x6B, 0x94, 0x8C, 0x74, 0xD7, 0x4A,
 0x95, 0xD3, 0x03, 0x91, 0x5B, 0x76, 0xDE, 0x27, 0xC5, 0xB2, 0x4C, 0xCF,
 0xEB, 0x3E, 0xDD, 0xFF, 0x22, 0xAF, 0xC3, 0xF8, 0x60, 0x36, 0x49, 0xBC,
 0xAE, 0x4D, 0x10, 0x31, 0xC6, 0x28, 0x2A, 0xEB, 0xCA, 0x94, 0x51, 0xD8,
 0x61, 0x1B, 0xC6, 0x2A, 0x91, 0x71, 0xE4, 0x8C, 0xF8, 0x19, 0x2C, 0xDE,
 0x71, 0xBB, 0xE3, 0xBD, 0x36, 0xB4, 0x45, 0x37, 0x02, 0x61, 0x48, 0x8E,
 0x19, 0x80, 0xD5, 0x24, 0x97, 0x24, 0x92, 0x44, 0x08, 0x89, 0x12, 0x00,
 0xB3, 0xF8, 0x1E, 0xE2, 0xBD, 0xCD, 0x4E, 0xF7, 0xA9, 0xE2, 0x0E, 0xD8,
 0xEA, 0xFA, 0xCF, 0xDB, 0x4E, 0x69, 0x6F, 0xEE
};
هل كانت مفيدة؟

المحلول

بعد بحث طويل و هذه النصيحة تلقيت في منتديات IIS ، تمكنت من معرفة ذلك. في الأساس ، هذا دفق AAC الخام ، والذي يحتاج إلى لف الرؤوس قبل أن يتم لعبه. يبدو أن أبسط وتنسيق الرأس الأكثر شيوعًا ADTS, ، الذي يتكون في إضافة أ رأس 7 بايت أمام كل عينة.

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top