המרה למדיה

Derek Herman
Derek Herman
Joe Medley
Joe Medley

במאמר הזה נלמד כמה פקודות נפוצות להמרה ולמניפולציה של מאפיינים ספציפיים של קובצי מדיה. למרות שניסינו להציג פעולות מקבילות בכל הנהלים, לא כל הפעולות אפשריות בשתי האפליקציות.

במקרים רבים, יכול להיות שהפקודות שאנחנו מציגים משולבות בפעולה אחת של שורת הפקודה, ושהשימוש בהן יתבצע בפועל. לדוגמה, אין שום דבר שימנע מכם להגדיר את קצב הנתונים של קובץ הפלט באותה פעולה שבה אתם ממירים את הקובץ. במאמר הזה, אנחנו מציגים את הפעולות האלה כפקודות נפרדות לצורך הבהרה.

ההמרה מתבצעת באמצעות האפליקציות הבאות:

מאפייני המסך

אפשר להשתמש ב-Shaka Packager וב-FFmpeg כדי לבדוק את התוכן של קובץ מדיה ואז להציג את המאפיינים של הסטרימינג. עם זאת, שניהם מספקים פלט שונה לאותה מדיה.

מאפיינים של קובצי חבילת Shaka

packager input=glocken.mp4 --dump_stream_info

הפלט אמור להיראות כך:

File "glocken.mp4":
Found 2 stream(s).
Stream [0] type: Video
 codec_string: avc1.640028
 time_scale: 30000
 duration: 300300 (10.0 seconds)
 is_encrypted: false
 codec: H264
 width: 1920
 height: 1080
 pixel_aspect_ratio: 1:1
 trick_play_factor: 0
 nalu_length_size: 4

Stream [1] type: Audio
 codec_string: mp4a.40.2
 time_scale: 48000
 duration: 481280 (10.0 seconds)
 is_encrypted: false
 codec: AAC
 sample_bits: 16
 num_channels: 2
 sampling_frequency: 48000
 language: eng
 seek_preroll_ns: 20833

מאפיינים באמצעות FFmpeg

ffmpeg -i glocken.mp4

הפלט אמור להיראות כך:

Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'glocken.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf57.83.100
  Duration: 00:00:10.03, start: 0.000000, bitrate: 8063 kb/s
    Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuvj420p(pc), 1920x1080, 7939 kb/s, 29.97 fps, 29.97 tbr, 30k tbn, 59.94 tbc (default)
    Metadata:
      handler_name    : VideoHandler
    Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 127 kb/s (default)
    Metadata:
      handler_name    : SoundHandler
At least one output file must be specified

הפרדת (demux) הסטרימינג של האודיו והווידאו

כדי להמיר קבצים, נדרש ב-Shaka Packager תהליך של ביטול מניפולציה של מקור נתונים (demuxing). האפשרות הזו נדרשת גם לשימוש במסגרות מדיה.

חלוקה לפלחים (demuxing) באמצעות Shaka Packager

MP4

packager input=myvideo.mp4,stream=video,output=myvideo_video.mp4
packager input=myvideo.mp4,stream=audio,output=myvideo_audio.m4a

או:

packager \
  input=myvideo.mp4,stream=video,output=myvideo_video.mp4 \
  input=myvideo.mp4,stream=audio,output=myvideo_audio.m4a

WebM

packager \
  input=myvideo.webm,stream=video,output=myvideo_video.webm \
  input=myvideo.webm,stream=audio,output=myvideo_audio.webm

חלוקה לפלחים (demuxing) ב-FFmpeg

MP4

ffmpeg -i myvideo.mp4 -vcodec copy -an myvideo_video.mp4
ffmpeg -i myvideo.mp4 -acodec copy -vn myvideo_audio.m4a

WebM

ffmpeg -i myvideo.webm -vcodec copy -an myvideo_video.webm
ffmpeg -i myvideo.webm -acodec copy -vn myvideo_audio.webm

רמיקס (שילוב) של שידורי האודיו והווידאו

במקרים מסוימים תצטרכו לשלב שוב את האודיו והווידאו בקונטיינר אחד. במיוחד אם לא משתמשים במסגרת מדיה. FFmpeg יכול לטפל בזה די טוב, אבל בשלב הזה אין תמיכה בכך ב-Shaka Packager.

ffmpeg -i myvideo_video.webm -i myvideo_audio.webm -c copy myvideo.webm

שינוי המאפיינים

קצב העברת נתונים

עבור FFmpeg, נוכל לעשות זאת בזמן המרה ל-.mp4 או ל-.webm.

ffmpeg -i myvideo.mov -b:v 350K myvideo.mp4
ffmpeg -i myvideo.mov -vf setsar=1:1 -b:v 350K myvideo.webm

מידות (רזולוציה)

ffmpeg -i myvideo.webm -s 1920x1080 myvideo_1920x1080.webm

סוג הקובץ

אי אפשר לעבד קובצי .mov באמצעות Shaka Packager, ולכן אי אפשר להשתמש בו כדי להמיר קבצים מהפורמט הזה.

.mov אל .mp4

ffmpeg -i myvideo.mov myvideo.mp4

.mov עד .webm

ffmpeg -i myvideo.mov myvideo.webm

סנכרון של אודיו ווידאו

כדי לוודא שהאודיו והווידאו מסתנכרנים במהלך ההפעלה, מוסיפים תמונות מפתח.

ffmpeg -i myvideo.mp4 -keyint_min 150 -g 150 -f webm -vf setsar=1:1 out.webm

MP4/H.264

ffmpeg -i myvideo.mp4 -c:v libx264 -c:a copy myvideo.mp4

אודיו ל-MP4

ffmpeg -i myvideo.mp4 -c:v copy -c:a aac myvideo.mp4

WebM/VP9

ffmpeg -i myvideo.webm -v:c libvpx-vp9 -v:a copy myvideo.webm

אודיו ב-WebM

ffmpeg -i myvideo.webm -v:c copy -v:a libvorbis myvideo.webm
ffmpeg -i myvideo.webm -v:c copy -v:a libopus myvideo.webm

וידאו על פי דרישה (VOD) וסטרימינג בשידור חי

יש שני סוגים של פרוטוקולים בסטרימינג שנדגים במאמר הזה. השיטה הראשונה היא שידור דינמי שניתן להתאמה באמצעות HTTP‏ (DASH), שהיא טכניקה של שידור נתונים מותאם בקצב נתונים (ABR) ושיטה מבוססת-תקנים לאינטרנט להצגת וידאו על פי דרישה (VOD). השני הוא HTTP Live Streaming ‏ (HLS), שהוא הסטנדרט של Apple לשידור חי ולווידאו על פי דרישה באינטרנט.

DASH/MPD

בדוגמה הזו נוצר קובץ הפלט של תיאור הצגת המדיה (MPD) מהסטרים של האודיו והווידאו.

packager \
  input=myvideo.mp4,stream=audio,output=myvideo_audio.mp4 \
  input=myvideo.mp4,stream=video,output=myvideo_video.mp4 \
  --mpd_output myvideo_vod.mpd

HLS

הדוגמאות האלה יוצרות קובץ פלט מסוג M3U8 מהזרמים של האודיו והווידאו, שהוא פלייליסט מולטימדיה בקידוד UTF-8.

ffmpeg -i myvideo.mp4 -c:a copy -b:v 8M -c:v copy -f hls \
  -hls_time 10 -hls_list_size 0 myvideo.m3u8

או:

packager \
  'input=myvideo.mp4,stream=video,segment_template=output$Number$.ts,playlist_name=video_playlist.m3u8' \
  'input=myvideo.mp4,stream=audio,segment_template=output_audio$Number$.ts,playlist_name=audio_playlist.m3u8,hls_group_id=audio,hls_name=ENGLISH' \
  --hls_master_playlist_output="master_playlist.m3u8"

עכשיו, אחרי שקיבלתם הבנה טובה של אופן ההמרה של קבצים, תוכלו להמשיך מהמקום שבו הפסקנו ולעבור להצפנת מדיה.