multimedia_paradise 1.1.344 → 1.2.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (218) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +99 -77
  3. data/bin/audio_player +1 -1
  4. data/bin/extract_images_from_this_video_file +1 -1
  5. data/bin/loop_this_video +1 -1
  6. data/bin/merge_avi_files +1 -1
  7. data/bin/merge_mp3 +1 -1
  8. data/bin/mp3_to_opus +1 -1
  9. data/bin/mpg_to_mp4 +1 -1
  10. data/bin/multimedia_paradise +1 -1
  11. data/bin/to_aiff +2 -5
  12. data/bin/to_flac +7 -0
  13. data/bin/to_mp3 +8 -0
  14. data/bin/to_mp4 +1 -1
  15. data/bin/to_ogg +7 -0
  16. data/bin/verbose_analyse_this_mp3_file_for_id3_tags +1 -1
  17. data/bin/video_codec +1 -1
  18. data/bin/video_thumbnail +1 -1
  19. data/bin/video_to_images +1 -1
  20. data/doc/README.gen +88 -51
  21. data/doc/{CHANGELOG.md → changelog/changelog.md} +8 -6
  22. data/doc/{LINKS.md → links/links.md} +2 -2
  23. data/doc/{MOTIVATION_FOR_THIS_PROJECT.md → motivation_for_the_multimedia_paradise_project/motivation_for_the_multimedia_paradise_project.md} +5 -5
  24. data/doc/todo/todo_for_the_multimedia_paradise_project.md +79 -93
  25. data/lib/multimedia_paradise/actions/actions.rb +224 -0
  26. data/lib/multimedia_paradise/audio/audio_player/audio_player.rb +61 -64
  27. data/lib/multimedia_paradise/audio/audio_tag_reader/audio_tag_reader.rb +17 -8
  28. data/lib/multimedia_paradise/audio/base.rb +0 -5
  29. data/lib/multimedia_paradise/audio/compress.rb +8 -5
  30. data/lib/multimedia_paradise/audio/create_m3u_playlist.rb +7 -11
  31. data/lib/multimedia_paradise/audio/extract_audio/constants.rb +0 -37
  32. data/lib/multimedia_paradise/audio/extract_audio/extract_audio.rb +90 -68
  33. data/lib/multimedia_paradise/audio/file_duration/file_duration.rb +134 -80
  34. data/lib/multimedia_paradise/audio/genres/boogie.rb +1 -6
  35. data/lib/multimedia_paradise/audio/genres/concerts.rb +1 -6
  36. data/lib/multimedia_paradise/audio/genres/constants.rb +1 -1
  37. data/lib/multimedia_paradise/audio/genres/eurodance.rb +1 -6
  38. data/lib/multimedia_paradise/audio/genres/genre.rb +36 -33
  39. data/lib/multimedia_paradise/audio/genres/hip_hop.rb +1 -6
  40. data/lib/multimedia_paradise/audio/genres/italian_songs.rb +1 -6
  41. data/lib/multimedia_paradise/audio/genres/the_1980s.rb +1 -6
  42. data/lib/multimedia_paradise/audio/genres/trance.rb +4 -7
  43. data/lib/multimedia_paradise/audio/lyrics_fetcher.rb +27 -22
  44. data/lib/multimedia_paradise/audio/merge_audio_files.rb +18 -11
  45. data/lib/multimedia_paradise/audio/modify_year_of_audio_file.rb +23 -11
  46. data/lib/multimedia_paradise/audio/n_audio_songs.rb +3 -2
  47. data/lib/multimedia_paradise/audio/play_all_audio_files.rb +41 -16
  48. data/lib/multimedia_paradise/audio/playlist/playlist.rb +163 -123
  49. data/lib/multimedia_paradise/audio/remove_audio.rb +11 -6
  50. data/lib/multimedia_paradise/audio/remove_last_second.rb +2 -3
  51. data/lib/multimedia_paradise/audio/report_missing_id.rb +22 -12
  52. data/lib/multimedia_paradise/audio/streamripper/streamripper_wrapper.rb +7 -5
  53. data/lib/multimedia_paradise/audio/to_mp3.rb +7 -5
  54. data/lib/multimedia_paradise/audio/to_ogg.rb +3 -1
  55. data/lib/multimedia_paradise/audio/wav_to_mp3.rb +5 -5
  56. data/lib/multimedia_paradise/base/base.rb +854 -15
  57. data/lib/multimedia_paradise/base/colours.rb +28 -31
  58. data/lib/multimedia_paradise/base/{commandline_arguments.rb → commandline_arguments_module/commandline_arguments_module.rb} +12 -9
  59. data/lib/multimedia_paradise/colours/colours.rb +4 -1
  60. data/lib/multimedia_paradise/commandline/{menu.rb → commandline.rb} +19 -16
  61. data/lib/multimedia_paradise/constants/constants.rb +504 -14
  62. data/lib/multimedia_paradise/constants/web_constants.rb +2 -4
  63. data/lib/multimedia_paradise/gui/gui_base.rb +2 -2
  64. data/lib/multimedia_paradise/gui/libui/lyrics/lyrics.rb +1 -1
  65. data/lib/multimedia_paradise/gui/libui/simple_play_widget/simple_play_widget.rb +1 -1
  66. data/lib/multimedia_paradise/gui/libui/video_player/video_player.rb +1 -1
  67. data/lib/multimedia_paradise/gui/libui/youtube_channels/youtube_channels.rb +1 -1
  68. data/lib/multimedia_paradise/gui/shared_code/multimedia_converter/multimedia_converter_module.rb +0 -478
  69. data/lib/multimedia_paradise/gui/shared_code/playlist/playlist_module.rb +94 -41
  70. data/lib/multimedia_paradise/gui/shared_code/simple_play_widget/simple_play_widget_module.rb +0 -257
  71. data/lib/multimedia_paradise/gui/universal_widgets/change_metadata_widget/change_metadata_widget.rb +2 -2
  72. data/lib/multimedia_paradise/gui/universal_widgets/information_about_a_mp3_file/information_about_a_mp3_file.rb +1 -1
  73. data/lib/multimedia_paradise/gui/universal_widgets/lyrics/lyrics.rb +1 -1
  74. data/lib/multimedia_paradise/gui/universal_widgets/multimedia_converter/multimedia_converter.rb +589 -0
  75. data/lib/multimedia_paradise/gui/universal_widgets/playlist/playlist.rb +197 -0
  76. data/lib/multimedia_paradise/gui/universal_widgets/radio/radio.rb +1 -1
  77. data/lib/multimedia_paradise/gui/{gtk2 → universal_widgets}/simple_play_widget/README.md +1 -1
  78. data/lib/multimedia_paradise/gui/universal_widgets/simple_play_widget/simple_play_widget.rb +404 -0
  79. data/lib/multimedia_paradise/gui/universal_widgets/tag_mp3_files/tag_mp3_files.rb +3 -6
  80. data/lib/multimedia_paradise/java/Playlist.class +0 -0
  81. data/lib/multimedia_paradise/java/Playlist.java +198 -0
  82. data/lib/multimedia_paradise/multimedia/analyse_multimedia_file.rb +21 -19
  83. data/lib/multimedia_paradise/multimedia/avisynth/avisynth_code.avs +441 -442
  84. data/lib/multimedia_paradise/multimedia/base.rb +0 -18
  85. data/lib/multimedia_paradise/multimedia/chord.rb +1 -1
  86. data/lib/multimedia_paradise/multimedia/cut_multimedia/cut_multimedia.rb +7 -5
  87. data/lib/multimedia_paradise/multimedia/cut_multimedia/evaluate_from_this_file.rb +2 -2
  88. data/lib/multimedia_paradise/multimedia/interactive_shell.rb +22 -3
  89. data/lib/multimedia_paradise/multimedia/merge_multimedia.rb +4 -3
  90. data/lib/multimedia_paradise/multimedia/play_from_this_list.rb +4 -27
  91. data/lib/multimedia_paradise/multimedia/{read_meta_tags.rb → read_meta_tags/read_meta_tags.rb} +14 -19
  92. data/lib/multimedia_paradise/multimedia/start_length_duration.rb +3 -3
  93. data/lib/multimedia_paradise/project/project.rb +8 -4
  94. data/lib/multimedia_paradise/requires/require_the_multimedia_paradise_project.rb +5 -5
  95. data/lib/multimedia_paradise/requires/require_toplevel_methods_files.rb +1 -1
  96. data/lib/multimedia_paradise/sinatra/app.rb +3 -3
  97. data/lib/multimedia_paradise/statistics/README.md +6 -5
  98. data/lib/multimedia_paradise/statistics/video.rb +34 -14
  99. data/lib/multimedia_paradise/{misc → time}/long_format_to_milliseconds_converter.rb +4 -2
  100. data/lib/multimedia_paradise/{misc → time}/milliseconds_to_long_format_converter.rb +2 -2
  101. data/lib/multimedia_paradise/toplevel_methods/audio_related_code.rb +138 -0
  102. data/lib/multimedia_paradise/toplevel_methods/chop_into_segments_of_n_seconds_size.rb +2 -2
  103. data/lib/multimedia_paradise/{conversions → toplevel_methods}/conversions.rb +140 -48
  104. data/lib/multimedia_paradise/toplevel_methods/copy_and_merge_this_video_n_times.rb +5 -5
  105. data/lib/multimedia_paradise/toplevel_methods/create_video_from_this_audio.rb +7 -6
  106. data/lib/multimedia_paradise/toplevel_methods/cut_from_to.rb +2 -2
  107. data/lib/multimedia_paradise/toplevel_methods/denoise.rb +2 -2
  108. data/lib/multimedia_paradise/toplevel_methods/deshake.rb +3 -6
  109. data/lib/multimedia_paradise/toplevel_methods/{output_directory.rb → directory_related_code.rb} +38 -1
  110. data/lib/multimedia_paradise/toplevel_methods/encode_this_video.rb +8 -4
  111. data/lib/multimedia_paradise/toplevel_methods/esystem.rb +43 -4
  112. data/lib/multimedia_paradise/{ffmpeg → toplevel_methods}/ffmpeg.rb +200 -193
  113. data/lib/multimedia_paradise/toplevel_methods/{files_and_directories.rb → files_related_code.rb} +19 -56
  114. data/lib/multimedia_paradise/toplevel_methods/flip_and_rotate.rb +3 -3
  115. data/lib/multimedia_paradise/toplevel_methods/is_audio_file_is_video_file_is_image_file_is_multimedia_file.rb +115 -0
  116. data/lib/multimedia_paradise/toplevel_methods/is_on_roebe.rb +1 -1
  117. data/lib/multimedia_paradise/toplevel_methods/{merge_multimedia_file.rb → merge.rb} +98 -4
  118. data/lib/multimedia_paradise/toplevel_methods/opn.rb +5 -4
  119. data/lib/multimedia_paradise/toplevel_methods/player_in_use.rb +14 -7
  120. data/lib/multimedia_paradise/toplevel_methods/query_the_audio_codec_of_this_file.rb +4 -3
  121. data/lib/multimedia_paradise/toplevel_methods/radio.rb +1 -3
  122. data/lib/multimedia_paradise/toplevel_methods/return_all_video_files.rb +4 -4
  123. data/lib/multimedia_paradise/toplevel_methods/return_path_to_random_simpsons_video_file.rb +1 -1
  124. data/lib/multimedia_paradise/toplevel_methods/return_random_video_file_from_the_video_collection.rb +9 -7
  125. data/lib/multimedia_paradise/toplevel_methods/scale_video.rb +3 -4
  126. data/lib/multimedia_paradise/toplevel_methods/set_title_of.rb +6 -6
  127. data/lib/multimedia_paradise/{help/help.rb → toplevel_methods/show_help.rb} +14 -8
  128. data/lib/multimedia_paradise/toplevel_methods/slow_down_this_video_file.rb +2 -3
  129. data/lib/multimedia_paradise/toplevel_methods/start_screencast.rb +3 -2
  130. data/lib/multimedia_paradise/toplevel_methods/{misc.rb → toplevel_methods.rb} +485 -527
  131. data/lib/multimedia_paradise/toplevel_methods/total_duration.rb +4 -3
  132. data/lib/multimedia_paradise/toplevel_methods/use_lame_codec.rb +1 -2
  133. data/lib/multimedia_paradise/toplevel_methods/video_dataset.rb +1 -1
  134. data/lib/multimedia_paradise/version/version.rb +2 -2
  135. data/lib/multimedia_paradise/video/all_videos.rb +12 -19
  136. data/lib/multimedia_paradise/video/check_numbers.rb +76 -32
  137. data/lib/multimedia_paradise/video/columbo/columbo.rb +36 -14
  138. data/lib/multimedia_paradise/video/guess_video_name.rb +2 -10
  139. data/lib/multimedia_paradise/video/mike_hammer/mike_hammer.rb +2 -2
  140. data/lib/multimedia_paradise/video/missing_video_files/missing_video_files.rb +1 -9
  141. data/lib/multimedia_paradise/video/movie_searcher.rb +2 -10
  142. data/lib/multimedia_paradise/video/mplayer_wrapper.rb +1 -9
  143. data/lib/multimedia_paradise/video/random_video.rb +1 -2
  144. data/lib/multimedia_paradise/video/registered_video_file.rb +2 -10
  145. data/lib/multimedia_paradise/video/report_local_videos.rb +1 -9
  146. data/lib/multimedia_paradise/video/simpsons.rb +2 -10
  147. data/lib/multimedia_paradise/video/smart_animals/smart_animals.rb +10 -8
  148. data/lib/multimedia_paradise/video/speed_up_video.rb +28 -10
  149. data/lib/multimedia_paradise/video/store_available_video_files.rb +49 -33
  150. data/lib/multimedia_paradise/video/the_simpsons/README.md +0 -0
  151. data/lib/multimedia_paradise/video/the_simpsons/good_the_simpsons_episodes.rb +8 -8
  152. data/lib/multimedia_paradise/video/the_simpsons/the_simpsons.rb +14 -10
  153. data/lib/multimedia_paradise/video/video_information.rb +55 -49
  154. data/lib/multimedia_paradise/{configuration → yaml/configuration}/play_zoomed.yml +0 -0
  155. data/lib/multimedia_paradise/yaml/{playlist.yml → playlist/playlist.yml} +14 -15
  156. data/lib/multimedia_paradise/yaml/video/video.yml +1 -1
  157. data/lib/multimedia_paradise/yaml/video_collection/video_collection.yml +34 -32
  158. data/lib/multimedia_paradise/yaml/youtube/alltagsgeschichte/alltagsgeschichte.yml +61 -11
  159. data/lib/multimedia_paradise/yaml/youtube/songs/songs.yml +5 -3
  160. data/multimedia_paradise.gemspec +1 -1
  161. data/test/testing_audio_player.rb +3 -3
  162. data/test/testing_file_duration.rb +5 -5
  163. metadata +45 -76
  164. data/lib/multimedia_paradise/audio/file_duration/constants.rb +0 -53
  165. data/lib/multimedia_paradise/audio/waveform/class.rb +0 -341
  166. data/lib/multimedia_paradise/audio/waveform/constants.rb +0 -38
  167. data/lib/multimedia_paradise/audio/waveform/log.rb +0 -101
  168. data/lib/multimedia_paradise/base/constants.rb +0 -19
  169. data/lib/multimedia_paradise/base/encoding.rb +0 -31
  170. data/lib/multimedia_paradise/base/misc.rb +0 -665
  171. data/lib/multimedia_paradise/base/namespace.rb +0 -36
  172. data/lib/multimedia_paradise/base/time.rb +0 -25
  173. data/lib/multimedia_paradise/constants/conversions.rb +0 -62
  174. data/lib/multimedia_paradise/constants/directory_constants.rb +0 -139
  175. data/lib/multimedia_paradise/constants/encodings.rb +0 -26
  176. data/lib/multimedia_paradise/constants/file_constants.rb +0 -176
  177. data/lib/multimedia_paradise/constants/misc.rb +0 -80
  178. data/lib/multimedia_paradise/constants/my_video_directory.rb +0 -30
  179. data/lib/multimedia_paradise/constants/namespace.rb +0 -14
  180. data/lib/multimedia_paradise/constants/newline.rb +0 -14
  181. data/lib/multimedia_paradise/constants/video_filetypes.rb +0 -27
  182. data/lib/multimedia_paradise/conversions/README.md +0 -2
  183. data/lib/multimedia_paradise/ffmpeg/README.md +0 -2
  184. data/lib/multimedia_paradise/gui/gtk2/multimedia_converter/multimedia_converter.rb +0 -33
  185. data/lib/multimedia_paradise/gui/gtk2/notebook.rb +0 -144
  186. data/lib/multimedia_paradise/gui/gtk2/play_video_from_my_collection/play_video_from_my_collection.rb +0 -43
  187. data/lib/multimedia_paradise/gui/gtk2/simple_play_widget/simple_play_widget.rb +0 -40
  188. data/lib/multimedia_paradise/gui/gtk2/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio.rb +0 -42
  189. data/lib/multimedia_paradise/gui/gtk2/youtube_downloader/youtube_downloader.rb +0 -32
  190. data/lib/multimedia_paradise/gui/gtk3/lyrics/lyrics.rb +0 -0
  191. data/lib/multimedia_paradise/gui/gtk3/multimedia_converter/multimedia_converter.rb +0 -34
  192. data/lib/multimedia_paradise/gui/gtk3/playlist/playlist.rb +0 -34
  193. data/lib/multimedia_paradise/gui/gtk3/simple_play_widget/simple_play_widget.rb +0 -38
  194. data/lib/multimedia_paradise/toplevel_methods/analyze_audio_stream.rb +0 -31
  195. data/lib/multimedia_paradise/toplevel_methods/codecs.rb +0 -50
  196. data/lib/multimedia_paradise/toplevel_methods/copy_file.rb +0 -18
  197. data/lib/multimedia_paradise/toplevel_methods/delay_audio.rb +0 -31
  198. data/lib/multimedia_paradise/toplevel_methods/ensure_that_the_output_directory_exists.rb +0 -27
  199. data/lib/multimedia_paradise/toplevel_methods/has_audio.rb +0 -48
  200. data/lib/multimedia_paradise/toplevel_methods/increase_volume_of_this_audio_file.rb +0 -61
  201. data/lib/multimedia_paradise/toplevel_methods/is_a_multimedia_file.rb +0 -27
  202. data/lib/multimedia_paradise/toplevel_methods/is_audio_file.rb +0 -27
  203. data/lib/multimedia_paradise/toplevel_methods/is_image_file.rb +0 -31
  204. data/lib/multimedia_paradise/toplevel_methods/is_video_file.rb +0 -62
  205. data/lib/multimedia_paradise/toplevel_methods/merge_these_videos.rb +0 -106
  206. data/lib/multimedia_paradise/toplevel_methods/run_sys_command.rb +0 -30
  207. data/lib/multimedia_paradise/toplevel_methods/to_flac.rb +0 -30
  208. data/lib/multimedia_paradise/toplevel_methods/to_mp4.rb +0 -24
  209. /data/doc/{MergingVideoLectures.md → merging_video_lectures/merging_video_lectures.md} +0 -0
  210. /data/doc/{Readme_for_the_cut_audio_component.md → readme_for_the_cut_audio_component/Readme_for_the_cut_audio_component.md} +0 -0
  211. /data/lib/multimedia_paradise/yaml/{audio_formats.yml → audio_formats/audio_formats.yml} +0 -0
  212. /data/lib/multimedia_paradise/yaml/{image_formats.yml → image_formats/image_formats.yml} +0 -0
  213. /data/lib/multimedia_paradise/yaml/{lyrics.yml → lyrics/lyrics.yml} +0 -0
  214. /data/lib/multimedia_paradise/yaml/{music_genres.yml → music_genres/music_genres.yml} +0 -0
  215. /data/lib/multimedia_paradise/yaml/{song_tags.yml → song_tags/song_tags.yml} +0 -0
  216. /data/lib/multimedia_paradise/yaml/{use_this_video_player.yml → use_this_video_player/use_this_video_player.yml} +0 -0
  217. /data/lib/multimedia_paradise/yaml/{video_encoding_settings.yml → video_encoding_settings/video_encoding_settings.yml} +0 -0
  218. /data/lib/multimedia_paradise/yaml/{video_filter_aliases.yml → video_filter_aliases/video_filter_aliases.yml} +0 -0
@@ -5,10 +5,10 @@
5
5
  # require 'multimedia_paradise/toplevel_methods/encode_this_video.rb'
6
6
  # MultimediaParadise.encode_this_video('foobar.avi')
7
7
  # =========================================================================== #
8
- require 'multimedia_paradise/toplevel_methods/esystem.rb'
9
-
10
8
  module MultimediaParadise
11
9
 
10
+ require 'multimedia_paradise/toplevel_methods/esystem.rb'
11
+
12
12
  # ========================================================================= #
13
13
  # === MultimediaParadise.encode_this_video
14
14
  #
@@ -22,7 +22,8 @@ module MultimediaParadise
22
22
  #
23
23
  # ========================================================================= #
24
24
  def self.encode_this_video(
25
- i = ARGV, use_this_mode = :CRF
25
+ i = ARGV,
26
+ use_this_mode = :CRF
26
27
  )
27
28
  [i].flatten.compact.each {|this_video|
28
29
  if File.exist? this_video
@@ -31,13 +32,16 @@ module MultimediaParadise
31
32
  sub(/#{File.extname(this_video)}$/,'')+
32
33
  '.mkv'
33
34
  case use_this_mode
35
+ # =================================================================== #
36
+ # === :CRF
37
+ # =================================================================== #
34
38
  when :CRF, :default
35
39
  _ = 'ffmpeg -i '+this_video+' -c:v libx264 '\
36
40
  '-preset slow -crf 22 -c:a copy '+output_filename
37
41
  esystem _
38
42
  end
39
43
  else
40
- e 'No file exists at '+this_video+'.'
44
+ no_file_exists_at(this_video)
41
45
  end
42
46
  }
43
47
  end
@@ -19,23 +19,62 @@ module MultimediaParadise
19
19
  # Currently only Hashes are supported like that.
20
20
  # ========================================================================= #
21
21
  def self.esystem(
22
- i, optional_colour_to_use = nil
22
+ i,
23
+ optional_colour_to_use = nil,
24
+ use_a_newline_before_the_system_command = false
23
25
  )
26
+ case use_a_newline_before_the_system_command
27
+ # ======================================================================= #
28
+ # === :use_a_newline
29
+ # ======================================================================= #
30
+ when :use_a_newline,
31
+ :use_newline
32
+ use_a_newline_before_the_system_command = true
33
+ end
24
34
  Signal.trap('SIGINT') { exit }
25
35
  i = i.dup if i.frozen?
26
36
  i.strip!
27
37
  display_this_string = i.dup
28
38
  if optional_colour_to_use
29
- if optional_colour_to_use.is_a?(Hash) and
30
- optional_colour_to_use.has_key?(:colour)
31
- use_this_colour = optional_colour_to_use[:colour]
39
+ if (optional_colour_to_use.is_a?(Hash) and
40
+ optional_colour_to_use.has_key?(:colour)) or
41
+ optional_colour_to_use.is_a?(Symbol)
42
+ if optional_colour_to_use.is_a? Hash
43
+ use_this_colour = optional_colour_to_use[:colour]
44
+ else
45
+ use_this_colour = optional_colour_to_use
46
+ end
32
47
  display_this_string = COLOURS.send(use_this_colour, display_this_string)
33
48
  end
34
49
  end
35
50
  e display_this_string
51
+ e if use_a_newline_before_the_system_command
36
52
  system i
37
53
  end
38
54
 
55
+ # ========================================================================= #
56
+ # === MultimediaParadise.run_sys_command (sys tag, sys cmd)
57
+ #
58
+ # Echo the command before running it via ``. This is the main difference
59
+ # towards the other method called MultimediaParadise.esystem().
60
+ # ========================================================================= #
61
+ def self.run_sys_command(
62
+ cmd,
63
+ pad_the_output = true
64
+ )
65
+ cmd = cmd.strip
66
+ e if pad_the_output
67
+ e cmd
68
+ e if pad_the_output
69
+ begin
70
+ result = `#{cmd}` # Sigint event can happen here.
71
+ return result
72
+ rescue Errno::ENOENT => error
73
+ e "No such file exists. (#{error})"
74
+ return nil
75
+ end
76
+ end
77
+
39
78
  end
40
79
 
41
80
  if __FILE__ == $PROGRAM_NAME
@@ -2,7 +2,11 @@
2
2
  # Encoding: UTF-8
3
3
  # frozen_string_literal: true
4
4
  # =========================================================================== #
5
- # require 'multimedia_paradise/ffmpeg/ffmpeg.rb'
5
+ # This file will specifically include code that relates to ffmpeg. On top
6
+ # of that, most methods (or even all methods) that are listed here will
7
+ # start with the substring "ffmpeg_".
8
+ # =========================================================================== #
9
+ # require 'multimedia_paradise/toplevel_methods/ffmpeg.rb'
6
10
  # =========================================================================== #
7
11
  module MultimediaParadise
8
12
 
@@ -49,6 +53,145 @@ module MultimediaParadise
49
53
  alias return_image_from_this_video_file ffmpeg_return_image_from_this_video_file # === MultimediaParadise.return_image_from_this_video_file
50
54
  }
51
55
 
56
+ # ========================================================================= #
57
+ # === MultimediaParadise.ffmpeg_slow_down_this_video_file
58
+ #
59
+ # This method can be used to slow down a video file.
60
+ #
61
+ # FFmpeg will be doing this slow down action.
62
+ #
63
+ # This uses the "setpts" video filter of ffmpeg, for the video stream
64
+ # at hand. The video stream can be changed without tampering with
65
+ # the audio stream. This is also the default modus operandi for this
66
+ # method here.
67
+ # ========================================================================= #
68
+ def self.ffmpeg_slow_down_this_video_file(
69
+ this_video_file = ARGV,
70
+ pts_value_to_use = 2.0
71
+ )
72
+ if this_video_file.is_a? Array
73
+ this_video_file.each {|entry|
74
+ ffmpeg_slow_down_this_video_file(entry, pts_value_to_use)
75
+ }
76
+ else
77
+ # ===================================================================== #
78
+ # To slow down a video, a multiplier greater than 1 has to be used:
79
+ # ===================================================================== #
80
+ _ = "ffmpeg -i #{this_video_file} -filter:v \"setpts=#{pts_value_to_use}*PTS\" "\
81
+ "OUTPUT_SLOWED_DOWN_VIDEO_#{this_video_file}"
82
+ esystem _
83
+ end
84
+ end
85
+
86
+ # ========================================================================= #
87
+ # === MultimediaParadise.ffmpeg_flip_video_to_the_right
88
+ #
89
+ # This toplevel-method can be used to flip a video to the right,
90
+ # that is, to rotate it by +90 degrees.
91
+ # ========================================================================= #
92
+ def self.ffmpeg_flip_video_to_the_right(i)
93
+ _ = "ffmpeg -i #{i} -vf transpose=1 flipped_to_the_right_#{i}"
94
+ esystem _
95
+ end
96
+
97
+ # ========================================================================= #
98
+ # === MultimediaParadise.ffmpeg_flip_video_to_the_left
99
+ #
100
+ # This toplevel-method can be used to flip a video to the left,
101
+ # that is, to rotate it by -90 degrees.
102
+ #
103
+ # Strangely enough the number 2 denotes left-hand flipping (or,
104
+ # to remain in ffmpeg-parlance, this means "90°CounterClockwise"
105
+ # rotation).
106
+ # ========================================================================= #
107
+ def self.ffmpeg_flip_video_to_the_left(i)
108
+ _ = "ffmpeg -i #{i} -vf transpose=2 flipped_to_the_left_#{i}"
109
+ esystem _
110
+ end
111
+
112
+ # ========================================================================= #
113
+ # === MultimediaParadise.ffmpeg_extract_audio
114
+ #
115
+ # This method will specifically use ffmpeg in order to extract the
116
+ # audio from a video or audio file.
117
+ # ========================================================================= #
118
+ def self.ffmpeg_extract_audio(
119
+ i = input.mkv, # The input filename.
120
+ o = :ogg # The output filename.
121
+ )
122
+ extname = File.extname(i)
123
+ case o
124
+ # ======================================================================= #
125
+ # === :ogg
126
+ # ======================================================================= #
127
+ when :ogg
128
+ use_this_name = i.
129
+ sub(/#{extname}$/,'')
130
+ o = use_this_name+'.ogg'
131
+ end
132
+ esystem 'ffmpeg -i '+i+' -vn '+o
133
+ end
134
+
135
+ # ========================================================================= #
136
+ # === MultimediaParadise.ffmpeg_convert_this_multimedia_file
137
+ #
138
+ # This method can be used to convert a file from A to B, through
139
+ # ffmpeg.
140
+ #
141
+ # Remember that the command ffmpeg -codecs will print every codec
142
+ # FFmpeg knows about.
143
+ # ========================================================================= #
144
+ def self.ffmpeg_convert_this_multimedia_file(
145
+ input_file = 'input.mp3',
146
+ output_file = :mkv #'output.ogg'
147
+ )
148
+ yielded = nil
149
+ if block_given?
150
+ yielded = yield
151
+ end
152
+ if File.exist? input_file
153
+ case output_file
154
+ when :mkv
155
+ extname = File.extname(input_file)
156
+ use_this_name = input_file.
157
+ sub(/#{extname}$/,'')
158
+ output_file = use_this_name+'.mkv'
159
+ end
160
+ _ = "ffmpeg -i #{input_file}"
161
+ case yielded
162
+ # ===================================================================== #
163
+ # === :copy_audio
164
+ # ===================================================================== #
165
+ when :copy_audio
166
+ _ << ' -c:a copy'
167
+ # ===================================================================== #
168
+ # === :libvorbis_audiostream
169
+ # ===================================================================== #
170
+ when :libvorbis_audiostream
171
+ _ << ' -c:a libvorbis'
172
+ # ===================================================================== #
173
+ # === :vp9_codec
174
+ # ===================================================================== #
175
+ when :vp9_codec
176
+ _ << ' -c:v vp9'
177
+ else
178
+ if yielded.is_a? Hash
179
+ # ================================================================= #
180
+ # === :framerate
181
+ # ================================================================= #
182
+ if yielded.has_key? :framerate
183
+ _ << " -r #{yielded.delete(:framerate)}"
184
+ end
185
+ end
186
+ end
187
+ _ << " #{output_file}"
188
+ e _
189
+ system _
190
+ else
191
+ e 'No file exists at '+input_file+'.'
192
+ end
193
+ end
194
+
52
195
  # ========================================================================= #
53
196
  # === MultimediaParadise.ffmpeg_chroma_subsampling
54
197
  #
@@ -72,7 +215,7 @@ module MultimediaParadise
72
215
  # effect.
73
216
  #
74
217
  # Yadif ("yet another deinterlacing filter") is the name of the
75
- # filter used by ffmpeg.
218
+ # filter used by ffmpeg.
76
219
  # ========================================================================= #
77
220
  def self.ffmpeg_deinterlace_this_video(this_video)
78
221
  esystem 'ffmpeg -i '+this_video+' -vf yadif output.mp4'
@@ -181,88 +324,6 @@ module MultimediaParadise
181
324
  end; self.instance_eval { alias ffmpeg_audio_codec? ffmpeg_query_the_audio_codec_of_this_file } # === MultimediaParadise.ffmpeg_audio_codec?
182
325
  self.instance_eval { alias ffmpeg_query_the_audio_codec ffmpeg_query_the_audio_codec_of_this_file } # === MultimediaParadise.ffmpeg_query_the_audio_codec
183
326
 
184
- # ========================================================================= #
185
- # === MultimediaParadise.ffmpeg_vertical_flip
186
- #
187
- # This method will make use of the video-filter called "vflip". A
188
- # vertical flip will flip the video from head-to-bottom, so people
189
- # will suddenly appear as if they are hanging from the ceiling. :)
190
- #
191
- # Invocation example:
192
- #
193
- # MultimediaParadise.ffmpeg_vertical_flip '/Depot/Video/Reallife/O.J.Simpson_TV_News_etwa_1995.avi'
194
- #
195
- # ========================================================================= #
196
- def self.ffmpeg_vertical_flip(this_video_file)
197
- if this_video_file.is_a? Array
198
- this_video_file.each {|entry| ffmpeg_vertical_flip(entry) }
199
- else
200
- extname = File.extname(this_video_file)
201
- base_dir = File.dirname(this_video_file)
202
- filename = File.basename(this_video_file)
203
- output_name = base_dir+'/vertical_flip_'+filename.sub(/#{extname}/,'')+extname
204
- _ = 'ffmpeg -i '+this_video_file+' -vf "vflip" '+output_name
205
- esystem _
206
- output_name # <- Also return the output name here.
207
- end
208
- end; self.instance_eval { alias ffmpeg_flip_upside_down ffmpeg_vertical_flip } # === MultimediaParadise.flip_upside_down
209
-
210
- # ========================================================================= #
211
- # === MultimediaParadise.ffmpeg_horizontal_flip
212
- #
213
- # This method will make use of the video-filter called "hflip".
214
- # ========================================================================= #
215
- def self.ffmpeg_horizontal_flip(this_video_file)
216
- if this_video_file.is_a? Array
217
- this_video_file.each {|entry| horizontal_flip(entry) }
218
- else
219
- extname = File.extname(this_video_file)
220
- output_name = 'horizontal_flip_'+this_video_file.sub(/#{extname}/,'')+extname
221
- _ = 'ffmpeg -i '+this_video_file+' -vf "hflip" '+output_name
222
- esystem _
223
- output_name # <- Also return the output filename here.
224
- end
225
- end
226
-
227
- # ========================================================================= #
228
- # === MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees
229
- #
230
- # This method can be used to rotate a video file by 90°. Sometimes
231
- # smartphones create tilted videos, so this method can correct
232
- # this distortion.
233
- #
234
- # This can be fixed by using FFMPEG's transpose filter. The
235
- # transpose value will work in multiples of 90, so "1"
236
- # means 90°.
237
- #
238
- # Invocation example:
239
- #
240
- # MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees('foo.mpg')
241
- #
242
- # ========================================================================= #
243
- def self.ffmpeg_rotate_this_video_file_by_90_degrees(
244
- this_video_file
245
- )
246
- output_file = 'output_'+this_video_file+'.mp4'
247
- _ = 'ffmpeg -i '+this_video_file+' -vf transpose=1 '+output_file
248
- esystem _
249
- output_file # <- And return the output file too.
250
- end
251
-
252
- # ========================================================================= #
253
- # === MultimediaParadise.ffmpeg_increase_volume_of_this_audio_file
254
- # ========================================================================= #
255
- def self.ffmpeg_increase_volume_of_this_audio_file(
256
- input_file,
257
- modify_volume_by_this_value = '5.0' # or 3.0 or 4.0 and so forth.
258
- )
259
- [input_file].flatten.compact.each {|this_file|
260
- _ = 'ffmpeg -i '+this_file+' -vcodec copy -af "volume='+modify_volume_by_this_value.to_s+
261
- '" output_'+this_file
262
- esystem _
263
- }
264
- end
265
-
266
327
  # ========================================================================= #
267
328
  # === MultimediaParadise.ffmpeg_start_screencast
268
329
  #
@@ -478,139 +539,85 @@ module MultimediaParadise
478
539
  end
479
540
 
480
541
  # ========================================================================= #
481
- # === MultimediaParadise.ffmpeg_slow_down_this_video_file
542
+ # === MultimediaParadise.ffmpeg_vertical_flip
482
543
  #
483
- # This method can be used to slow down a video file.
544
+ # This method will make use of the video-filter called "vflip". A
545
+ # vertical flip will flip the video from head-to-bottom, so people
546
+ # will suddenly appear as if they are hanging from the ceiling. :)
484
547
  #
485
- # FFmpeg will be doing this slow down action.
548
+ # Invocation example:
549
+ #
550
+ # MultimediaParadise.ffmpeg_vertical_flip '/Depot/Video/Reallife/O.J.Simpson_TV_News_etwa_1995.avi'
486
551
  #
487
- # This uses the "setpts" video filter of ffmpeg, for the video stream
488
- # at hand. The video stream can be changed without tampering with
489
- # the audio stream. This is also the default modus operandi for this
490
- # method here.
491
552
  # ========================================================================= #
492
- def self.ffmpeg_slow_down_this_video_file(
493
- this_video_file = ARGV,
494
- pts_value_to_use = 2.0
495
- )
553
+ def self.ffmpeg_vertical_flip(this_video_file)
496
554
  if this_video_file.is_a? Array
497
- this_video_file.each {|entry|
498
- ffmpeg_slow_down_this_video_file(entry, pts_value_to_use)
499
- }
555
+ this_video_file.each {|entry| ffmpeg_vertical_flip(entry) }
500
556
  else
501
- # ===================================================================== #
502
- # To slow down a video, a multiplier greater than 1 has to be used:
503
- # ===================================================================== #
504
- _ = "ffmpeg -i #{this_video_file} -filter:v \"setpts=#{pts_value_to_use}*PTS\" "\
505
- "OUTPUT_SLOWED_DOWN_VIDEO_#{this_video_file}"
557
+ extname = File.extname(this_video_file)
558
+ base_dir = File.dirname(this_video_file)
559
+ filename = File.basename(this_video_file)
560
+ output_name = base_dir+'/vertical_flip_'+filename.sub(/#{extname}/,'')+extname
561
+ _ = 'ffmpeg -i '+this_video_file+' -vf "vflip" '+output_name
506
562
  esystem _
563
+ output_name # <- Also return the output name here.
507
564
  end
508
- end
565
+ end; self.instance_eval { alias ffmpeg_flip_upside_down ffmpeg_vertical_flip } # === MultimediaParadise.flip_upside_down
509
566
 
510
567
  # ========================================================================= #
511
- # === MultimediaParadise.ffmpeg_flip_video_to_the_right
568
+ # === MultimediaParadise.ffmpeg_horizontal_flip
512
569
  #
513
- # This toplevel-method can be used to flip a video to the right,
514
- # that is, to rotate it by +90 degrees.
570
+ # This method will make use of the video-filter called "hflip".
515
571
  # ========================================================================= #
516
- def self.ffmpeg_flip_video_to_the_right(i)
517
- _ = "ffmpeg -i #{i} -vf transpose=1 flipped_to_the_right_#{i}"
518
- esystem _
572
+ def self.ffmpeg_horizontal_flip(this_video_file)
573
+ if this_video_file.is_a? Array
574
+ this_video_file.each {|entry| horizontal_flip(entry) }
575
+ else
576
+ extname = File.extname(this_video_file)
577
+ output_name = 'horizontal_flip_'+this_video_file.sub(/#{extname}/,'')+extname
578
+ _ = 'ffmpeg -i '+this_video_file+' -vf "hflip" '+output_name
579
+ esystem _
580
+ output_name # <- Also return the output filename here.
581
+ end
519
582
  end
520
583
 
521
584
  # ========================================================================= #
522
- # === MultimediaParadise.ffmpeg_flip_video_to_the_left
585
+ # === MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees
523
586
  #
524
- # This toplevel-method can be used to flip a video to the left,
525
- # that is, to rotate it by -90 degrees.
587
+ # This method can be used to rotate a video file by 90°. Sometimes
588
+ # smartphones create tilted videos, so this method can correct
589
+ # this distortion.
526
590
  #
527
- # Strangely enough the number 2 denotes left-hand flipping (or,
528
- # to remain in ffmpeg-parlance, this means "90°CounterClockwise"
529
- # rotation).
530
- # ========================================================================= #
531
- def self.ffmpeg_flip_video_to_the_left(i)
532
- _ = "ffmpeg -i #{i} -vf transpose=2 flipped_to_the_left_#{i}"
533
- esystem _
534
- end
535
-
536
- # ========================================================================= #
537
- # === MultimediaParadise.ffmpeg_extract_audio
591
+ # This can be fixed by using FFMPEG's transpose filter. The
592
+ # transpose value will work in multiples of 90, so "1"
593
+ # means 90°.
538
594
  #
539
- # This method will specifically use ffmpeg in order to extract the
540
- # audio from a video or audio file.
541
- # ========================================================================= #
542
- def self.ffmpeg_extract_audio(
543
- i = input.mkv, # The input filename.
544
- o = :ogg # The output filename.
595
+ # Invocation example:
596
+ #
597
+ # MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees('foo.mpg')
598
+ #
599
+ # ========================================================================= #
600
+ def self.ffmpeg_rotate_this_video_file_by_90_degrees(
601
+ this_video_file
545
602
  )
546
- extname = File.extname(i)
547
- case o
548
- when :ogg
549
- use_this_name = i.
550
- sub(/#{extname}$/,'')
551
- o = use_this_name+'.ogg'
552
- end
553
- esystem 'ffmpeg -i '+i+' -vn '+o
603
+ output_file = 'output_'+this_video_file+'.mp4'
604
+ _ = 'ffmpeg -i '+this_video_file+' -vf transpose=1 '+output_file
605
+ esystem _
606
+ output_file # <- And return the output file too.
554
607
  end
555
608
 
556
609
  # ========================================================================= #
557
- # === MultimediaParadise.ffmpeg_convert_this_multimedia_file
558
- #
559
- # This method can be used to convert a file from A to B, through
560
- # ffmpeg.
561
- #
562
- # Remember that the command ffmpeg -codecs will print every codec
563
- # FFmpeg knows about.
610
+ # === MultimediaParadise.ffmpeg_increase_volume_of_this_audio_file
564
611
  # ========================================================================= #
565
- def self.ffmpeg_convert_this_multimedia_file(
566
- input_file = 'input.mp3',
567
- output_file = :mkv #'output.ogg'
612
+ def self.ffmpeg_increase_volume_of_this_audio_file(
613
+ input_file,
614
+ modify_volume_by_this_value = '5.0' # or 3.0 or 4.0 and so forth.
568
615
  )
569
- yielded = nil
570
- if block_given?
571
- yielded = yield
572
- end
573
- if File.exist? input_file
574
- case output_file
575
- when :mkv
576
- extname = File.extname(input_file)
577
- use_this_name = input_file.
578
- sub(/#{extname}$/,'')
579
- output_file = use_this_name+'.mkv'
580
- end
581
- _ = "ffmpeg -i #{input_file}"
582
- case yielded
583
- # ===================================================================== #
584
- # === :copy_audio
585
- # ===================================================================== #
586
- when :copy_audio
587
- _ << ' -c:a copy'
588
- # ===================================================================== #
589
- # === :libvorbis_audiostream
590
- # ===================================================================== #
591
- when :libvorbis_audiostream
592
- _ << ' -c:a libvorbis'
593
- # ===================================================================== #
594
- # === :vp9_codec
595
- # ===================================================================== #
596
- when :vp9_codec
597
- _ << ' -c:v vp9'
598
- else
599
- if yielded.is_a? Hash
600
- # ================================================================= #
601
- # === :framerate
602
- # ================================================================= #
603
- if yielded.has_key? :framerate
604
- _ << " -r #{yielded.delete(:framerate)}"
605
- end
606
- end
607
- end
608
- _ << " #{output_file}"
609
- e _
610
- system _
611
- else
612
- e 'No file exists at '+input_file+'.'
613
- end
616
+ [input_file].flatten.compact.each {|this_file|
617
+ _ = 'ffmpeg -i '+this_file+' -vcodec copy -af "volume='+modify_volume_by_this_value.to_s+
618
+ '" output_'+this_file
619
+ esystem _
620
+ }
614
621
  end
615
622
 
616
623
  end
@@ -2,69 +2,30 @@
2
2
  # Encoding: UTF-8
3
3
  # frozen_string_literal: true
4
4
  # =========================================================================== #
5
- # Code in this file will deal with files and directories in general, including
6
- # cd-related actions, removal of files, creation of files and so forth.
7
- # =========================================================================== #
8
- # require 'multimedia_paradise/toplevel_methods/files_and_directories.rb'
9
- # MultimediaParadise.chdir
5
+ # require 'multimedia_paradise/toplevel_methods/files_related_code.rb'
10
6
  # =========================================================================== #
11
7
  module MultimediaParadise
12
8
 
13
9
  require 'fileutils'
14
10
  require 'multimedia_paradise/toplevel_methods/e.rb'
11
+ require 'multimedia_paradise/toplevel_methods/is_on_roebe.rb'
15
12
  require 'multimedia_paradise/colours/colours.rb'
16
13
 
17
14
  # ========================================================================= #
18
- # === MultimediaParadise.move_file
19
- #
20
- # This method can be used to move a file - in other words, to rename it.
15
+ # === MultimediaParadise.copy_file
21
16
  # ========================================================================= #
22
- def self.move_file(old, new)
23
- FileUtils.mv(old, new)
24
- end; self.instance_eval { alias mv move_file } # === MultimediaParadise.mv
25
- self.instance_eval { alias rename_file move_file } # === MultimediaParadise.rename_file
26
-
27
- # ========================================================================= #
28
- # === MultimediaParadise.remove_file
29
- #
30
- # Remove a given file, without any further checks.
31
- # ========================================================================= #
32
- def self.remove_file(i)
33
- File.delete(i) if File.exist?(i)
34
- end; self.instance_eval { alias delete_file remove_file } # === MultimediaParadise.delete_file
35
-
36
- # ========================================================================= #
37
- # === remove_file
38
- # ========================================================================= #
39
- def remove_file(i)
40
- MultimediaParadise.remove_file(i)
41
- end
42
-
43
- # ========================================================================= #
44
- # === MultimediaParadise.mkdir
45
- #
46
- # This method can be used to create a directory on the local computer
47
- # system.
48
- # ========================================================================= #
49
- def self.mkdir(i)
50
- FileUtils.mkdir_p(i)
51
- end
52
-
53
- # ========================================================================= #
54
- # === mkdir
55
- # ========================================================================= #
56
- def mkdir(i)
57
- MultimediaParadise.mkdir(i)
17
+ def self.copy_file(from, to)
18
+ FileUtils.cp(from, to)
58
19
  end
59
20
 
60
21
  # ========================================================================= #
61
22
  # === MultimediaParadise.rename
62
23
  #
63
- # This perform a rename-action, using mv.
24
+ # This method will perform a rename-action, using mv.
64
25
  # ========================================================================= #
65
26
  def self.rename(from, to)
66
27
  if File.exist? from
67
- e rev+'Now renaming `'+sfile(from.to_s)+rev+'` to `'+sfile(to.to_s)+rev+'`.'
28
+ e "#{rev}Now renaming `"+sfile(from.to_s)+rev+'` to `'+sfile(to.to_s)+rev+'`.'
68
29
  FileUtils.mv(from, to)
69
30
  else
70
31
  e "#{rev}Can not rename `#{sfancy(from)}` as it does not exist."
@@ -73,20 +34,22 @@ module MultimediaParadise
73
34
  self.instance_eval { alias rename_file rename } # === MultimediaParadise.rename_file
74
35
 
75
36
  # ========================================================================= #
76
- # === chdir (cd tag)
37
+ # === MultimediaParadise.move_file
38
+ #
39
+ # This method can be used to move a file - in other words, to rename it.
77
40
  # ========================================================================= #
78
- def chdir(i)
79
- MultimediaParadise.chdir(i)
80
- end; alias cd chdir # === cd
41
+ def self.move_file(old, new)
42
+ FileUtils.mv(old, new)
43
+ end; self.instance_eval { alias mv move_file } # === MultimediaParadise.mv
44
+ self.instance_eval { alias rename_file move_file } # === MultimediaParadise.rename_file
81
45
 
82
46
  # ========================================================================= #
83
- # === MultimediaParadise.chdir
47
+ # === MultimediaParadise.remove_file
84
48
  #
85
- # Use this method if you wish to change directory to another target
86
- # directory.
49
+ # Remove a given file, without any further checks.
87
50
  # ========================================================================= #
88
- def self.chdir(i)
89
- Dir.chdir(i) if File.directory? i
90
- end; self.instance_eval { alias cd chdir } # === MultimediaParadise.cd
51
+ def self.remove_file(i)
52
+ File.delete(i) if File.exist?(i)
53
+ end; self.instance_eval { alias delete_file remove_file } # === MultimediaParadise.delete_file
91
54
 
92
55
  end