Skip to content

How to Convert h264 video to MP4

Claude Pageau edited this page Jan 8, 2017 · 42 revisions

###convid.sh Description convid.sh will automate conversion of h264 files to mp4 format. It uses the MP4Box utility that is installed as part of gpac (per pi-timolo-install.sh script). Default is to process h264 files in the /home/pi/pi-timolo/motion folder. It will convert all available h264 files except the most recent file since it may still be in progress. The h264 files can optionally (default) be deleted after conversion. This will save disk space.

###convid.sh Variable Settings Use nano to edit the convid.sh script variables to suit per github code here convid.sh

cd ~/pi-timolo
nano convid.sh

Use nano to edit convid.sh variables below as required then ctrl-x y to save and exit nano

del_h264=true   # delete=true or rename=false
source_files=/home/pi/pi-timolo/motion/*h264

You can also choose to rename or delete h264 files after processing by setting the del_h264 boolean variable to true or false per code comments. It is recommended you leave default delete option in order to save space. The mp4 files can be easily viewed using webserver.sh on the RPI and chrome browser (tested) on a local network computer. Other browsers may allow directly viewing mp4 files as well.

###How to Turn on Video Mode in pi-timolo To enable pi-timolo motion video mode edit /home/pi/pi-timolo/config.py and change the following variable(s).

cd~/pi-timolo
nano config.py

Then edit/review the following variables. ctrl-x y to save changes and exit nano editor

motionVideoOn = True     # if True then video clip is taken rather than image
motionVideoTimer = 10    # Seconds of video recorded if Motion Detected default=10
motionNumOn = False      # True=On (filenames by sequenced Number) otherwise date/time used for filenames

It is highly recommended that you keep the motionVideoTimer setting a short duration Eg 5 to 20 seconds. This will reduce browser download time and also save disk space. Normally when there motion is detected, more than one video will be generated. Motion detection is disabled while video is being recorded so setting a short duration enables motion detection faster. motionNumOn setting will create filenames with a date/time creation stamp as part of the video name.

To reduce video file sizes you can also reduce the video resolution by editing the following config.py settings (this is web cam resolution) You may need to adjust larger for better resolution.

imageWidth = 640          # Full Size Image Width in px  default=1024
imageHeight = 480         # Full Size Image Height in px default=768 

###webserver.py setting to sort Videos by filename use nano to edit webserver.py and change the variable below

show_by_datetime = False

This will sort by file name and put the files in the correct order

###Set convid.sh to automate conversion of h264 files to MP4 format

Note the most recent video will not be processed by convid.sh since it may be in the process of being written. This should not be an issue since usually if there is motion more than one incident will be recorded. When another video is created it will become the most recent and the previous one will be processed.

You can run this script in a crontab

sudo crontab -e

add the following line to the bottom of the crontab file to execute convid.sh once every minute. This can be changed if you wish eg */2 is every two minutes Etc..

To run as pi user

*/1 * * * * su pi -c "/home/pi/pi-timolo/convid.sh >/dev/null"
# Optional start sync.sh and makevideo.sh
# */5 * * * * su pi -c "/home/pi/pi-timolo/sync.sh > /dev/null"
# 0 22 * * * su pi -c "/home/pi/pi-timolo/makevideo.sh > /dev/null"

TIP - To join two compatible videos (must be same resolution and framerate) use command similar to below

MP4Box -cat file1.mp4 -cat file2.mp4 -new outfile.mp4

You will need to write a script to concatenate a series of files

###Configure sync.sh to automate upload of mp4 videos You can configure sync.sh to upload mp4 files. See sync.sh script variables to do this.
For Details See How to Configure sync.sh to Automate uploads
Note: This will require a reasonably fast internet connection. To optimize you can reduce video resolution and recording time per recommendations above

Clone this wiki locally