multimedia_paradise 1.1.314
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of multimedia_paradise might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/README.md +2340 -0
- data/bin/audio_player +12 -0
- data/bin/auto_title +7 -0
- data/bin/convert_audio_to_mp4video_with_image +7 -0
- data/bin/cut_audio +7 -0
- data/bin/cut_multimedia +7 -0
- data/bin/extract_audio +7 -0
- data/bin/ffmpeg_merge +7 -0
- data/bin/file_duration +7 -0
- data/bin/gtk_radio +7 -0
- data/bin/loop_this_video +7 -0
- data/bin/merge_avi_files +7 -0
- data/bin/merge_mp3 +7 -0
- data/bin/missing_video_files +7 -0
- data/bin/movie_searcher +7 -0
- data/bin/mp3_to_opus +7 -0
- data/bin/mplayer_wrapper +7 -0
- data/bin/multimedia_information +11 -0
- data/bin/multimedia_paradise +9 -0
- data/bin/multimedia_paradise_sinatra +7 -0
- data/bin/play_random_simpsons_video +7 -0
- data/bin/playlist +7 -0
- data/bin/random_video +7 -0
- data/bin/remove_audio +9 -0
- data/bin/remove_last_second +7 -0
- data/bin/remove_subtitles +7 -0
- data/bin/tag_mp3_files +7 -0
- data/bin/to_aiff +10 -0
- data/bin/to_mp4 +7 -0
- data/bin/verbose_analyse_this_mp3_file_for_id3_tags +9 -0
- data/bin/video_codec +7 -0
- data/bin/video_information +8 -0
- data/bin/video_player +11 -0
- data/bin/video_to_images +7 -0
- data/bin/vp9 +9 -0
- data/bin/waveform +73 -0
- data/doc/CHANGELOG.md +44 -0
- data/doc/LINKS.md +6 -0
- data/doc/MOTIVATION_FOR_THIS_PROJECT.md +22 -0
- data/doc/MergingVideoLectures.md +12 -0
- data/doc/README.gen +2300 -0
- data/doc/Readme_for_the_cut_audio_component.md +168 -0
- data/doc/todo/todo_for_the_GUIs.md +0 -0
- data/doc/todo/todo_for_the_multimedia_paradise_project.md +111 -0
- data/lib/multimedia_paradise/audio/audio_player/audio_player.rb +83 -0
- data/lib/multimedia_paradise/audio/audio_player/constants.rb +136 -0
- data/lib/multimedia_paradise/audio/audio_player/menu.rb +164 -0
- data/lib/multimedia_paradise/audio/audio_player/misc.rb +718 -0
- data/lib/multimedia_paradise/audio/audio_player/reset.rb +77 -0
- data/lib/multimedia_paradise/audio/audio_player/tab.rb +35 -0
- data/lib/multimedia_paradise/audio/audio_tag_reader/README.md +7 -0
- data/lib/multimedia_paradise/audio/audio_tag_reader/audio_tag_reader.rb +503 -0
- data/lib/multimedia_paradise/audio/base.rb +67 -0
- data/lib/multimedia_paradise/audio/compress.rb +97 -0
- data/lib/multimedia_paradise/audio/create_m3u_playlist.rb +245 -0
- data/lib/multimedia_paradise/audio/extract_audio/constants.rb +37 -0
- data/lib/multimedia_paradise/audio/extract_audio/extract_audio.rb +417 -0
- data/lib/multimedia_paradise/audio/file_duration/constants.rb +53 -0
- data/lib/multimedia_paradise/audio/file_duration/file_duration.rb +602 -0
- data/lib/multimedia_paradise/audio/genres/boogie.rb +35 -0
- data/lib/multimedia_paradise/audio/genres/concerts.rb +35 -0
- data/lib/multimedia_paradise/audio/genres/constants.rb +53 -0
- data/lib/multimedia_paradise/audio/genres/eurodance.rb +35 -0
- data/lib/multimedia_paradise/audio/genres/genre.rb +696 -0
- data/lib/multimedia_paradise/audio/genres/hip_hop.rb +35 -0
- data/lib/multimedia_paradise/audio/genres/italian_songs.rb +35 -0
- data/lib/multimedia_paradise/audio/genres/the_1980s.rb +35 -0
- data/lib/multimedia_paradise/audio/genres/trance.rb +35 -0
- data/lib/multimedia_paradise/audio/lyrics_fetcher.rb +238 -0
- data/lib/multimedia_paradise/audio/merge_audio_files.rb +136 -0
- data/lib/multimedia_paradise/audio/modify_year_of_audio_file.rb +151 -0
- data/lib/multimedia_paradise/audio/n_audio_songs.rb +216 -0
- data/lib/multimedia_paradise/audio/play_all_audio_files.rb +122 -0
- data/lib/multimedia_paradise/audio/playlist/playlist.rb +1559 -0
- data/lib/multimedia_paradise/audio/remove_audio.rb +98 -0
- data/lib/multimedia_paradise/audio/remove_last_second.rb +83 -0
- data/lib/multimedia_paradise/audio/report_missing_id.rb +139 -0
- data/lib/multimedia_paradise/audio/streamripper/constants.rb +51 -0
- data/lib/multimedia_paradise/audio/streamripper/streamripper_wrapper.rb +279 -0
- data/lib/multimedia_paradise/audio/to_mp3.rb +138 -0
- data/lib/multimedia_paradise/audio/to_ogg.rb +104 -0
- data/lib/multimedia_paradise/audio/wav_to_mp3.rb +87 -0
- data/lib/multimedia_paradise/audio/waveform/class.rb +341 -0
- data/lib/multimedia_paradise/audio/waveform/constants.rb +38 -0
- data/lib/multimedia_paradise/audio/waveform/log.rb +101 -0
- data/lib/multimedia_paradise/autoinclude.rb +3 -0
- data/lib/multimedia_paradise/autoinclude_remove_audio.rb +6 -0
- data/lib/multimedia_paradise/base/base.rb +34 -0
- data/lib/multimedia_paradise/base/colours.rb +354 -0
- data/lib/multimedia_paradise/base/commandline_arguments.rb +52 -0
- data/lib/multimedia_paradise/base/constants.rb +19 -0
- data/lib/multimedia_paradise/base/encoding.rb +31 -0
- data/lib/multimedia_paradise/base/misc.rb +618 -0
- data/lib/multimedia_paradise/base/namespace.rb +36 -0
- data/lib/multimedia_paradise/base/time.rb +25 -0
- data/lib/multimedia_paradise/colours/colours.rb +82 -0
- data/lib/multimedia_paradise/commandline/menu.rb +498 -0
- data/lib/multimedia_paradise/configuration/play_zoomed.yml +1 -0
- data/lib/multimedia_paradise/constants/constants.rb +23 -0
- data/lib/multimedia_paradise/constants/conversions.rb +62 -0
- data/lib/multimedia_paradise/constants/directory_constants.rb +133 -0
- data/lib/multimedia_paradise/constants/encodings.rb +26 -0
- data/lib/multimedia_paradise/constants/file_constants.rb +171 -0
- data/lib/multimedia_paradise/constants/misc.rb +80 -0
- data/lib/multimedia_paradise/constants/my_video_directory.rb +30 -0
- data/lib/multimedia_paradise/constants/namespace.rb +14 -0
- data/lib/multimedia_paradise/constants/newline.rb +14 -0
- data/lib/multimedia_paradise/constants/video_filetypes.rb +27 -0
- data/lib/multimedia_paradise/constants/web_constants.rb +150 -0
- data/lib/multimedia_paradise/conversions/README.md +2 -0
- data/lib/multimedia_paradise/conversions/conversions.rb +930 -0
- data/lib/multimedia_paradise/css/project.css +15 -0
- data/lib/multimedia_paradise/data/asoundrc +12 -0
- data/lib/multimedia_paradise/ffmpeg/README.md +2 -0
- data/lib/multimedia_paradise/ffmpeg/ffmpeg.rb +620 -0
- data/lib/multimedia_paradise/gui/fox/play_from_radio_station.rb +75 -0
- data/lib/multimedia_paradise/gui/gosu/video_player/video_player.rb +109 -0
- data/lib/multimedia_paradise/gui/gtk2/lyrics/lyrics.rb +33 -0
- data/lib/multimedia_paradise/gui/gtk2/multimedia_converter/multimedia_converter.rb +33 -0
- data/lib/multimedia_paradise/gui/gtk2/notebook.rb +144 -0
- data/lib/multimedia_paradise/gui/gtk2/play_video_from_my_collection/play_video_from_my_collection.rb +43 -0
- data/lib/multimedia_paradise/gui/gtk2/simple_play_widget/README.md +12 -0
- data/lib/multimedia_paradise/gui/gtk2/simple_play_widget/simple_play_widget.rb +40 -0
- data/lib/multimedia_paradise/gui/gtk2/video_collection/video_collection.rb +56 -0
- data/lib/multimedia_paradise/gui/gtk2/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio.rb +42 -0
- data/lib/multimedia_paradise/gui/gtk2/youtube_downloader/youtube_downloader.rb +32 -0
- data/lib/multimedia_paradise/gui/gtk3/change_metadata_widget/README.md +3 -0
- data/lib/multimedia_paradise/gui/gtk3/change_metadata_widget/change_metadata_widget.rb +150 -0
- data/lib/multimedia_paradise/gui/gtk3/cut_multimedia/cut_multimedia.rb +321 -0
- data/lib/multimedia_paradise/gui/gtk3/information_about_a_mp3_file/information_about_a_mp3_file.rb +421 -0
- data/lib/multimedia_paradise/gui/gtk3/lyrics/lyrics.rb +33 -0
- data/lib/multimedia_paradise/gui/gtk3/multimedia_converter/multimedia_converter.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/multimedia_notebook/multimedia_notebook.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/play_video_from_my_collection/play_video_from_my_collection.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/playlist/playlist.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/radio/misc.rb +487 -0
- data/lib/multimedia_paradise/gui/gtk3/radio/radio.rb +698 -0
- data/lib/multimedia_paradise/gui/gtk3/simple_play_widget/simple_play_widget.rb +38 -0
- data/lib/multimedia_paradise/gui/gtk3/sound_effect_widget/sound_effect_widget.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/tag_mp3_files/connect_skeleton.rb +61 -0
- data/lib/multimedia_paradise/gui/gtk3/tag_mp3_files/create.rb +405 -0
- data/lib/multimedia_paradise/gui/gtk3/tag_mp3_files/misc.rb +1820 -0
- data/lib/multimedia_paradise/gui/gtk3/tag_mp3_files/tag_mp3_files.config +6 -0
- data/lib/multimedia_paradise/gui/gtk3/tag_mp3_files/tag_mp3_files.rb +66 -0
- data/lib/multimedia_paradise/gui/gtk3/video_collection/video_collection.rb +43 -0
- data/lib/multimedia_paradise/gui/gtk3/video_editor/video_editor.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/video_player/video_player.rb +34 -0
- data/lib/multimedia_paradise/gui/gtk3/webcam_widget/webcam_widget.rb +425 -0
- data/lib/multimedia_paradise/gui/gtk3/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio.rb +36 -0
- data/lib/multimedia_paradise/gui/gtk3/youtube_channels/youtube_channels.rb +210 -0
- data/lib/multimedia_paradise/gui/gtk3/youtube_downloader/youtube_downloader.rb +32 -0
- data/lib/multimedia_paradise/gui/gui_base.rb +92 -0
- data/lib/multimedia_paradise/gui/libui/change_metadata_widget/change_metadata_widget.rb +115 -0
- data/lib/multimedia_paradise/gui/libui/cut_multimedia/cut_multimedia.rb +119 -0
- data/lib/multimedia_paradise/gui/libui/lyrics/lyrics.rb +67 -0
- data/lib/multimedia_paradise/gui/libui/simple_play_widget/simple_play_widget.rb +119 -0
- data/lib/multimedia_paradise/gui/libui/tag_mp3_files/tag_mp3_files.rb +268 -0
- data/lib/multimedia_paradise/gui/libui/video_player/video_player.rb +81 -0
- data/lib/multimedia_paradise/gui/libui/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio.rb +126 -0
- data/lib/multimedia_paradise/gui/libui/youtube_channels/youtube_channels.rb +116 -0
- data/lib/multimedia_paradise/gui/libui/youtube_downloader/youtube_downloader.rb +107 -0
- data/lib/multimedia_paradise/gui/shared_code/change_metadata_widget/change_metadata_widget_module.rb +538 -0
- data/lib/multimedia_paradise/gui/shared_code/cut_multimedia/cut_multimedia_module.rb +268 -0
- data/lib/multimedia_paradise/gui/shared_code/information_about_a_mp3_file/information_about_a_mp3_file_module.rb +120 -0
- data/lib/multimedia_paradise/gui/shared_code/lyrics/lyrics_module.rb +141 -0
- data/lib/multimedia_paradise/gui/shared_code/multimedia_converter/multimedia_converter_module.rb +478 -0
- data/lib/multimedia_paradise/gui/shared_code/multimedia_notebook/multimedia_notebook_module.rb +171 -0
- data/lib/multimedia_paradise/gui/shared_code/play_video_from_my_collection/play_video_from_my_collection_module.rb +464 -0
- data/lib/multimedia_paradise/gui/shared_code/playlist/playlist_module.rb +151 -0
- data/lib/multimedia_paradise/gui/shared_code/simple_play_widget/simple_play_widget_module.rb +257 -0
- data/lib/multimedia_paradise/gui/shared_code/sound_effect_widget/sound_effect_widget_module.rb +173 -0
- data/lib/multimedia_paradise/gui/shared_code/tag_mp3_files/tag_mp3_files_module.rb +73 -0
- data/lib/multimedia_paradise/gui/shared_code/video_editor/video_editor_module.rb +287 -0
- data/lib/multimedia_paradise/gui/shared_code/video_player/video_player_module.rb +185 -0
- data/lib/multimedia_paradise/gui/shared_code/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio_module.rb +310 -0
- data/lib/multimedia_paradise/gui/shared_code/youtube_downloader/youtube_downloader_module.rb +339 -0
- data/lib/multimedia_paradise/gui/tk/tk_multimedia_wrapper.rb +60 -0
- data/lib/multimedia_paradise/help/help.rb +75 -0
- data/lib/multimedia_paradise/images/MULTIMEDIA.jpg +0 -0
- data/lib/multimedia_paradise/images/MULTIMEDIA_PARADISE_ID_TAG_GUI_IN_RUBY_GTK3.png +0 -0
- data/lib/multimedia_paradise/images/MULTIMEDIA_PARADISE_LOGO.png +0 -0
- data/lib/multimedia_paradise/images/UK_flag.png +0 -0
- data/lib/multimedia_paradise/images/US_flag.png +0 -0
- data/lib/multimedia_paradise/images/austrian_flag.png +0 -0
- data/lib/multimedia_paradise/images/french_flag.png +0 -0
- data/lib/multimedia_paradise/images/german_flag.png +0 -0
- data/lib/multimedia_paradise/images/radio_image.png +0 -0
- data/lib/multimedia_paradise/images/trance.png +0 -0
- data/lib/multimedia_paradise/java/AudioPlayer.class +0 -0
- data/lib/multimedia_paradise/java/AudioPlayer.java +103 -0
- data/lib/multimedia_paradise/java/README.md +3 -0
- data/lib/multimedia_paradise/misc/long_format_to_milliseconds_converter.rb +182 -0
- data/lib/multimedia_paradise/misc/milliseconds_to_long_format_converter.rb +186 -0
- data/lib/multimedia_paradise/multimedia/analyse_multimedia_file.rb +180 -0
- data/lib/multimedia_paradise/multimedia/avisynth/README.md +4 -0
- data/lib/multimedia_paradise/multimedia/avisynth/avisynth_code.avs +471 -0
- data/lib/multimedia_paradise/multimedia/base.rb +60 -0
- data/lib/multimedia_paradise/multimedia/chord.rb +174 -0
- data/lib/multimedia_paradise/multimedia/convert_audio_to_video_with_image.rb +171 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/10_minutes_chop.rb +29 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/15_minutes_chop.rb +29 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/30_minutes_chop.rb +29 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/5_minutes_chop.rb +29 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/cut_multimedia.rb +2017 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/evaluate_from_this_file.rb +79 -0
- data/lib/multimedia_paradise/multimedia/cut_multimedia/interactive_menu.rb +514 -0
- data/lib/multimedia_paradise/multimedia/interactive_shell.rb +84 -0
- data/lib/multimedia_paradise/multimedia/merge_multimedia.rb +125 -0
- data/lib/multimedia_paradise/multimedia/note.rb +500 -0
- data/lib/multimedia_paradise/multimedia/play_from_this_list.rb +163 -0
- data/lib/multimedia_paradise/multimedia/read_meta_tags.rb +173 -0
- data/lib/multimedia_paradise/multimedia/simulate_youtube_playlist.rb +209 -0
- data/lib/multimedia_paradise/multimedia/start_length_duration.rb +205 -0
- data/lib/multimedia_paradise/multimedia/video_downloader/video_downloader.rb +143 -0
- data/lib/multimedia_paradise/project/project.rb +47 -0
- data/lib/multimedia_paradise/requires/require_audio_files.rb +74 -0
- data/lib/multimedia_paradise/requires/require_cut_multimedia.rb +7 -0
- data/lib/multimedia_paradise/requires/require_extract_audio.rb +7 -0
- data/lib/multimedia_paradise/requires/require_file_duration.rb +7 -0
- data/lib/multimedia_paradise/requires/require_streamripper.rb +7 -0
- data/lib/multimedia_paradise/requires/require_the_audio_player.rb +7 -0
- data/lib/multimedia_paradise/requires/require_the_multimedia_paradise_project.rb +38 -0
- data/lib/multimedia_paradise/requires/require_the_sinatra_components.rb +7 -0
- data/lib/multimedia_paradise/requires/require_toplevel_methods_files.rb +25 -0
- data/lib/multimedia_paradise/requires/require_video_files.rb +25 -0
- data/lib/multimedia_paradise/requires/require_video_player.rb +7 -0
- data/lib/multimedia_paradise/sinatra/app.rb +311 -0
- data/lib/multimedia_paradise/sinatra/embeddable_interface.rb +379 -0
- data/lib/multimedia_paradise/sound_effects/README.md +12 -0
- data/lib/multimedia_paradise/sound_effects/cat_meow.mp3 +0 -0
- data/lib/multimedia_paradise/sound_effects/channel_opened.mp3 +0 -0
- data/lib/multimedia_paradise/sound_effects/phone_ring.mp3 +0 -0
- data/lib/multimedia_paradise/statistics/README.md +5 -0
- data/lib/multimedia_paradise/statistics/video.rb +84 -0
- data/lib/multimedia_paradise/toplevel_cut_audio.rb +16 -0
- data/lib/multimedia_paradise/toplevel_methods/analyze_audio_stream.rb +31 -0
- data/lib/multimedia_paradise/toplevel_methods/chop_into_segments_of_n_seconds_size.rb +32 -0
- data/lib/multimedia_paradise/toplevel_methods/chop_off_first_five_minutes.rb +22 -0
- data/lib/multimedia_paradise/toplevel_methods/chop_off_first_n_seconds.rb +92 -0
- data/lib/multimedia_paradise/toplevel_methods/chop_off_first_ten_minutes.rb +22 -0
- data/lib/multimedia_paradise/toplevel_methods/chop_off_first_two_minutes.rb +24 -0
- data/lib/multimedia_paradise/toplevel_methods/codecs.rb +50 -0
- data/lib/multimedia_paradise/toplevel_methods/copy_and_merge_this_video_n_times.rb +51 -0
- data/lib/multimedia_paradise/toplevel_methods/copy_file.rb +18 -0
- data/lib/multimedia_paradise/toplevel_methods/create_video_from_this_audio.rb +65 -0
- data/lib/multimedia_paradise/toplevel_methods/cut_from_to.rb +156 -0
- data/lib/multimedia_paradise/toplevel_methods/delay_audio.rb +31 -0
- data/lib/multimedia_paradise/toplevel_methods/denoise.rb +90 -0
- data/lib/multimedia_paradise/toplevel_methods/deshake.rb +43 -0
- data/lib/multimedia_paradise/toplevel_methods/e.rb +16 -0
- data/lib/multimedia_paradise/toplevel_methods/encode_this_video.rb +49 -0
- data/lib/multimedia_paradise/toplevel_methods/ensure_that_the_output_directory_exists.rb +27 -0
- data/lib/multimedia_paradise/toplevel_methods/esystem.rb +43 -0
- data/lib/multimedia_paradise/toplevel_methods/files_and_directories.rb +90 -0
- data/lib/multimedia_paradise/toplevel_methods/flip_and_rotate.rb +58 -0
- data/lib/multimedia_paradise/toplevel_methods/increase_volume_of_this_audio_file.rb +61 -0
- data/lib/multimedia_paradise/toplevel_methods/is_a_multimedia_file.rb +27 -0
- data/lib/multimedia_paradise/toplevel_methods/is_audio_file.rb +27 -0
- data/lib/multimedia_paradise/toplevel_methods/is_image_file.rb +31 -0
- data/lib/multimedia_paradise/toplevel_methods/is_on_roebe.rb +17 -0
- data/lib/multimedia_paradise/toplevel_methods/is_video_file.rb +62 -0
- data/lib/multimedia_paradise/toplevel_methods/merge_multimedia_file.rb +327 -0
- data/lib/multimedia_paradise/toplevel_methods/merge_these_videos.rb +105 -0
- data/lib/multimedia_paradise/toplevel_methods/misc.rb +885 -0
- data/lib/multimedia_paradise/toplevel_methods/n_local_videos.rb +56 -0
- data/lib/multimedia_paradise/toplevel_methods/opn.rb +24 -0
- data/lib/multimedia_paradise/toplevel_methods/output_directory.rb +59 -0
- data/lib/multimedia_paradise/toplevel_methods/player_in_use.rb +80 -0
- data/lib/multimedia_paradise/toplevel_methods/query_the_audio_codec_of_this_file.rb +24 -0
- data/lib/multimedia_paradise/toplevel_methods/radio.rb +360 -0
- data/lib/multimedia_paradise/toplevel_methods/rds.rb +24 -0
- data/lib/multimedia_paradise/toplevel_methods/return_all_video_files.rb +64 -0
- data/lib/multimedia_paradise/toplevel_methods/return_data_from_video_collection_file_for_this_entry.rb +38 -0
- data/lib/multimedia_paradise/toplevel_methods/return_duration_of_this_multimedia_file.rb +27 -0
- data/lib/multimedia_paradise/toplevel_methods/return_full_name_for_video_at_this_position.rb +54 -0
- data/lib/multimedia_paradise/toplevel_methods/return_path_to_random_simpsons_video_file.rb +43 -0
- data/lib/multimedia_paradise/toplevel_methods/return_random_video_file_from_the_video_collection.rb +73 -0
- data/lib/multimedia_paradise/toplevel_methods/return_screen_resolution.rb +24 -0
- data/lib/multimedia_paradise/toplevel_methods/run_sys_command.rb +30 -0
- data/lib/multimedia_paradise/toplevel_methods/scale_video.rb +27 -0
- data/lib/multimedia_paradise/toplevel_methods/set_title_of.rb +65 -0
- data/lib/multimedia_paradise/toplevel_methods/slow_down_this_video_file.rb +33 -0
- data/lib/multimedia_paradise/toplevel_methods/start_screencast.rb +70 -0
- data/lib/multimedia_paradise/toplevel_methods/subtitles.rb +59 -0
- data/lib/multimedia_paradise/toplevel_methods/to_flac.rb +30 -0
- data/lib/multimedia_paradise/toplevel_methods/to_mp4.rb +24 -0
- data/lib/multimedia_paradise/toplevel_methods/total_duration.rb +35 -0
- data/lib/multimedia_paradise/toplevel_methods/use_lame_codec.rb +32 -0
- data/lib/multimedia_paradise/toplevel_methods/video_dataset.rb +76 -0
- data/lib/multimedia_paradise/version/version.rb +28 -0
- data/lib/multimedia_paradise/video/all_videos.rb +101 -0
- data/lib/multimedia_paradise/video/capture_screen.rb +285 -0
- data/lib/multimedia_paradise/video/check_numbers.rb +215 -0
- data/lib/multimedia_paradise/video/columbo/columbo.rb +139 -0
- data/lib/multimedia_paradise/video/copy_missing_video_files.rb +293 -0
- data/lib/multimedia_paradise/video/copy_random_video.rb +98 -0
- data/lib/multimedia_paradise/video/correct_video_numbers.rb +278 -0
- data/lib/multimedia_paradise/video/create_dvd.rb +50 -0
- data/lib/multimedia_paradise/video/encode_video.rb +81 -0
- data/lib/multimedia_paradise/video/ffmpeg_options.rb +156 -0
- data/lib/multimedia_paradise/video/find_video/constants.rb +23 -0
- data/lib/multimedia_paradise/video/find_video/find_video.rb +493 -0
- data/lib/multimedia_paradise/video/fix_married_with_children_videos.rb +70 -0
- data/lib/multimedia_paradise/video/guess_video_name.rb +189 -0
- data/lib/multimedia_paradise/video/imdb_rating/imdb_rating.rb +141 -0
- data/lib/multimedia_paradise/video/mike_hammer/mike_hammer.rb +74 -0
- data/lib/multimedia_paradise/video/missing_video_files/missing_video_files.rb +286 -0
- data/lib/multimedia_paradise/video/movie_searcher.rb +281 -0
- data/lib/multimedia_paradise/video/mplayer_wrapper.rb +504 -0
- data/lib/multimedia_paradise/video/play_random_file.rb +91 -0
- data/lib/multimedia_paradise/video/play_random_realvideo.rb +87 -0
- data/lib/multimedia_paradise/video/prepare_video_lecture.rb +272 -0
- data/lib/multimedia_paradise/video/random_video.rb +310 -0
- data/lib/multimedia_paradise/video/registered_video_file.rb +131 -0
- data/lib/multimedia_paradise/video/remove_metadata.rb +52 -0
- data/lib/multimedia_paradise/video/rename_video_file.rb +149 -0
- data/lib/multimedia_paradise/video/report_local_videos.rb +106 -0
- data/lib/multimedia_paradise/video/report_missing_videos_in_the_yaml_file.rb +107 -0
- data/lib/multimedia_paradise/video/resolution.rb +159 -0
- data/lib/multimedia_paradise/video/simpsons.rb +129 -0
- data/lib/multimedia_paradise/video/speed_up_video.rb +135 -0
- data/lib/multimedia_paradise/video/split_this_video.rb +126 -0
- data/lib/multimedia_paradise/video/srt_regex.rb +211 -0
- data/lib/multimedia_paradise/video/store_available_video_files.rb +138 -0
- data/lib/multimedia_paradise/video/the_simpsons/README.md +9 -0
- data/lib/multimedia_paradise/video/the_simpsons/good_the_simpsons_episodes.rb +107 -0
- data/lib/multimedia_paradise/video/the_simpsons/the_simpsons.rb +82 -0
- data/lib/multimedia_paradise/video/video.rb +14 -0
- data/lib/multimedia_paradise/video/video_encoding_settings.rb +57 -0
- data/lib/multimedia_paradise/video/video_genres.rb +337 -0
- data/lib/multimedia_paradise/video/video_information.rb +443 -0
- data/lib/multimedia_paradise/video/video_metadata.rb +132 -0
- data/lib/multimedia_paradise/video/video_player.rb +581 -0
- data/lib/multimedia_paradise/video/video_renamer.rb +160 -0
- data/lib/multimedia_paradise/video/watermark.rb +290 -0
- data/lib/multimedia_paradise/video/youtube/youtube.rb +17 -0
- data/lib/multimedia_paradise/video/youtube_embedder.rb +235 -0
- data/lib/multimedia_paradise/www/GIS/GIS.cgi +147 -0
- data/lib/multimedia_paradise/www/HDMI/HDMI.cgi +34 -0
- data/lib/multimedia_paradise/www/TALES_FROM_THE_CRYPT.html +71 -0
- data/lib/multimedia_paradise/www/alsa/alsa.cgi +7 -0
- data/lib/multimedia_paradise/www/alsa/alsa.rb +309 -0
- data/lib/multimedia_paradise/www/alsa/alsa.sinatra +56 -0
- data/lib/multimedia_paradise/www/audacity.cgi +30 -0
- data/lib/multimedia_paradise/www/audio/audio.cgi +9 -0
- data/lib/multimedia_paradise/www/audio/audio.rb +2739 -0
- data/lib/multimedia_paradise/www/audio/audio.sinatra +56 -0
- data/lib/multimedia_paradise/www/avisynth/avisynth.cgi +172 -0
- data/lib/multimedia_paradise/www/best_voices/best_voices.cgi +60 -0
- data/lib/multimedia_paradise/www/cassette/cassette.cgi +723 -0
- data/lib/multimedia_paradise/www/codecs/codecs.cgi +95 -0
- data/lib/multimedia_paradise/www/componists/vivaldi.cgi +218 -0
- data/lib/multimedia_paradise/www/decibel.cgi +79 -0
- data/lib/multimedia_paradise/www/ffmpeg/ffmpeg.cgi +439 -0
- data/lib/multimedia_paradise/www/lame/lame.cgi +7 -0
- data/lib/multimedia_paradise/www/lame/lame.rb +101 -0
- data/lib/multimedia_paradise/www/lame/lame.sinatra +56 -0
- data/lib/multimedia_paradise/www/lilypond.cgi +96 -0
- data/lib/multimedia_paradise/www/lyrics/lyrics.cgi +49 -0
- data/lib/multimedia_paradise/www/midi/al_adagi.mid +0 -0
- data/lib/multimedia_paradise/www/play_songs.cgi +102 -0
- data/lib/multimedia_paradise/www/play_this_video_file.cgi +100 -0
- data/lib/multimedia_paradise/www/pulseaudio/pulseaudio.cgi +7 -0
- data/lib/multimedia_paradise/www/pulseaudio/pulseaudio.rb +168 -0
- data/lib/multimedia_paradise/www/pulseaudio/pulseaudio.sinatra +56 -0
- data/lib/multimedia_paradise/www/rhythmbox/rhythmbox.cgi +120 -0
- data/lib/multimedia_paradise/www/sound_theory.cgi +163 -0
- data/lib/multimedia_paradise/www/tv/tv.cgi +182 -0
- data/lib/multimedia_paradise/www/video/video.cgi +7 -0
- data/lib/multimedia_paradise/www/video/video.rb +7709 -0
- data/lib/multimedia_paradise/www/video/video.sinatra +52 -0
- data/lib/multimedia_paradise/www/web_streams.cgi +58 -0
- data/lib/multimedia_paradise/yaml/audio_formats.yml +14 -0
- data/lib/multimedia_paradise/yaml/best_songs_in_an_era/eurodance/top20.yml +28 -0
- data/lib/multimedia_paradise/yaml/game_shows/ruck_zuck/ruck_zuck.yml +25 -0
- data/lib/multimedia_paradise/yaml/genres/1980s.yml +198 -0
- data/lib/multimedia_paradise/yaml/genres/README.md +5 -0
- data/lib/multimedia_paradise/yaml/genres/boogie.yml +68 -0
- data/lib/multimedia_paradise/yaml/genres/concerts.yml +29 -0
- data/lib/multimedia_paradise/yaml/genres/eurodance.yml +456 -0
- data/lib/multimedia_paradise/yaml/genres/hip_hop.yml +49 -0
- data/lib/multimedia_paradise/yaml/genres/italian_songs.yml +53 -0
- data/lib/multimedia_paradise/yaml/genres/trance.yml +167 -0
- data/lib/multimedia_paradise/yaml/good_horror_movies/good_horror_movies.yml +12 -0
- data/lib/multimedia_paradise/yaml/good_movie_actors/good_movie_actors.yml +6 -0
- data/lib/multimedia_paradise/yaml/image_formats.yml +8 -0
- data/lib/multimedia_paradise/yaml/internal/README.md +2 -0
- data/lib/multimedia_paradise/yaml/internal/installed_binaries.yml +31 -0
- data/lib/multimedia_paradise/yaml/lyrics.yml +6275 -0
- data/lib/multimedia_paradise/yaml/movie_reviews/the_hateful_eight_september_2016.md +305 -0
- data/lib/multimedia_paradise/yaml/music_genres.yml +51 -0
- data/lib/multimedia_paradise/yaml/playlist.yml +127 -0
- data/lib/multimedia_paradise/yaml/radio/README.md +5 -0
- data/lib/multimedia_paradise/yaml/radio/radio_stations.yml +359 -0
- data/lib/multimedia_paradise/yaml/song_tags.yml +815 -0
- data/lib/multimedia_paradise/yaml/tales_from_the_crypt/tales_from_the_crypt.yml +418 -0
- data/lib/multimedia_paradise/yaml/tom_and_jerry/README.md +2 -0
- data/lib/multimedia_paradise/yaml/tom_and_jerry/tom_and_jerry_episodes.yml +27 -0
- data/lib/multimedia_paradise/yaml/tv_channels/tv_channels.yml +46 -0
- data/lib/multimedia_paradise/yaml/use_this_video_player.yml +1 -0
- data/lib/multimedia_paradise/yaml/video/video.yml +26 -0
- data/lib/multimedia_paradise/yaml/video_collection/video_collection.yml +1933 -0
- data/lib/multimedia_paradise/yaml/video_encoding_settings.yml +62 -0
- data/lib/multimedia_paradise/yaml/video_filter_aliases.yml +221 -0
- data/lib/multimedia_paradise/yaml/youtube/alltagsgeschichte/alltagsgeschichte.yml +172 -0
- data/lib/multimedia_paradise/yaml/youtube/songs/README.md +3 -0
- data/lib/multimedia_paradise/yaml/youtube/songs/songs.yml +6 -0
- data/lib/multimedia_paradise/yaml/youtube_playlist/youtube_playlist.yml +6 -0
- data/lib/multimedia_paradise.rb +5 -0
- data/multimedia_paradise.gemspec +76 -0
- data/test/testing_audio_player.rb +15 -0
- data/test/testing_ffmpeg_options.rb +14 -0
- data/test/testing_file_duration.rb +17 -0
- data/test/testing_modify_year_of_audio_file.rb +14 -0
- data/test/testing_multimedia_paradise_project.rb +151 -0
- metadata +581 -0
@@ -0,0 +1,38 @@
|
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# Encoding: UTF-8
|
3
|
+
# frozen_string_literal: true
|
4
|
+
# =========================================================================== #
|
5
|
+
# === MultimediaParadise::GUI::Gtk::SimplePlayWidget
|
6
|
+
# =========================================================================== #
|
7
|
+
# require 'multimedia_paradise/gui/gtk3/simple_play_widget/simple_play_widget.rb'
|
8
|
+
# MultimediaParadise::GUI::Gtk::SimplePlayWidget.run
|
9
|
+
# =========================================================================== #
|
10
|
+
require 'gtk_paradise/require_gtk3'
|
11
|
+
require 'multimedia_paradise/gui/gtk3/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio.rb'
|
12
|
+
|
13
|
+
module MultimediaParadise
|
14
|
+
|
15
|
+
module GUI
|
16
|
+
|
17
|
+
module Gtk
|
18
|
+
|
19
|
+
class SimplePlayWidget < ::Gtk::Box
|
20
|
+
|
21
|
+
require 'gtk_paradise/requires/require_the_base_module.rb'
|
22
|
+
include ::Gtk::BaseModule
|
23
|
+
|
24
|
+
require 'multimedia_paradise/gui/shared_code/simple_play_widget/simple_play_widget_module.rb'
|
25
|
+
include ::MultimediaParadise::GUI::SimplePlayWidgetModule
|
26
|
+
|
27
|
+
# ========================================================================= #
|
28
|
+
# === MultimediaParadise::GUI::Gtk::SimplePlayWidget.run
|
29
|
+
# ========================================================================= #
|
30
|
+
def self.run
|
31
|
+
::MultimediaParadise::GUI::SimplePlayWidgetModule.run
|
32
|
+
end
|
33
|
+
|
34
|
+
end; end; end; end
|
35
|
+
|
36
|
+
if __FILE__ == $PROGRAM_NAME
|
37
|
+
MultimediaParadise::GUI::Gtk::SimplePlayWidget.run
|
38
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# Encoding: UTF-8
|
3
|
+
# frozen_string_literal: true
|
4
|
+
# =========================================================================== #
|
5
|
+
# === MultimediaParadise::GUI::Gtk::SoundEffectWidget
|
6
|
+
# =========================================================================== #
|
7
|
+
# require 'multimedia_paradise/gui/gtk3/sound_effect_widget/sound_effect_widget.rb'
|
8
|
+
# MultimediaParadise::GUI::Gtk::SoundEffectWidget.run
|
9
|
+
# =========================================================================== #
|
10
|
+
require 'gtk_paradise/require_gtk3'
|
11
|
+
|
12
|
+
module MultimediaParadise
|
13
|
+
|
14
|
+
module GUI
|
15
|
+
|
16
|
+
module Gtk
|
17
|
+
|
18
|
+
class SoundEffectWidget < ::Gtk::Box
|
19
|
+
|
20
|
+
require 'multimedia_paradise/gui/shared_code/sound_effect_widget/sound_effect_widget_module.rb'
|
21
|
+
include ::MultimediaParadise::GUI::Gtk::SoundEffectWidgetModule
|
22
|
+
|
23
|
+
# ========================================================================= #
|
24
|
+
# === MultimediaParadise::GUI::Gtk::SoundEffectWidget.run
|
25
|
+
# ========================================================================= #
|
26
|
+
def self.run
|
27
|
+
::MultimediaParadise::GUI::Gtk::SoundEffectWidgetModule.run
|
28
|
+
end
|
29
|
+
|
30
|
+
end; end; end; end
|
31
|
+
|
32
|
+
if __FILE__ == $PROGRAM_NAME
|
33
|
+
MultimediaParadise::GUI::Gtk::SoundEffectWidget.run
|
34
|
+
end
|
@@ -0,0 +1,61 @@
|
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# Encoding: UTF-8
|
3
|
+
# frozen_string_literal: true
|
4
|
+
# =========================================================================== #
|
5
|
+
# require 'multimedia_paradise/gui/gtk3/tag_mp3_files/connect_skeleton.rb'
|
6
|
+
# =========================================================================== #
|
7
|
+
module MultimediaParadise
|
8
|
+
|
9
|
+
module GUI
|
10
|
+
|
11
|
+
module Gtk
|
12
|
+
|
13
|
+
class TagMp3Files < ::Gtk::Box # === MultimediaParadise::GUI::Gtk::TagMp3Files
|
14
|
+
|
15
|
+
# ========================================================================= #
|
16
|
+
# === connect_skeleton (connect skeleton, connect tag)
|
17
|
+
#
|
18
|
+
# This method should ideally reside in the file connect_skeleton.rb
|
19
|
+
# ========================================================================= #
|
20
|
+
def connect_skeleton
|
21
|
+
abort_on_exception
|
22
|
+
# ======================================================================= #
|
23
|
+
# The first dragger is the one close to the top of the main application.
|
24
|
+
# It will contain the header bar, as well as the widget that is on
|
25
|
+
# the second row.
|
26
|
+
# ======================================================================= #
|
27
|
+
first_dragger = drag_via_up_and_down_movement(
|
28
|
+
header_bar?, # The header bar on top.
|
29
|
+
widget_second_row # The main entry below the header bar.
|
30
|
+
)
|
31
|
+
first_dragger.position = header_bar_height? # This height should be the height of the header bar.
|
32
|
+
minimal(first_dragger)
|
33
|
+
# ======================================================================= #
|
34
|
+
# Next the middle box - this one will contain several widgets at the
|
35
|
+
# same time.
|
36
|
+
# ======================================================================= #
|
37
|
+
middle_box = drag_via_left_and_right_movement(
|
38
|
+
widget_left,
|
39
|
+
widget_in_the_middle
|
40
|
+
)
|
41
|
+
middle_box.set_name('fancy_separator')
|
42
|
+
middle_box.position = 880
|
43
|
+
|
44
|
+
second_dragger = drag_via_left_and_right_movement(middle_box, widget_right)
|
45
|
+
use_this_position = 1600
|
46
|
+
if use_this_position > max_width?
|
47
|
+
use_this_position = max_width? * 0.8
|
48
|
+
end
|
49
|
+
second_dragger.position = use_this_position
|
50
|
+
# ======================================================================= #
|
51
|
+
# The last dragger will add the status bar to the top.
|
52
|
+
# ======================================================================= #
|
53
|
+
third_dragger = drag_via_up_and_down_movement(
|
54
|
+
second_dragger,
|
55
|
+
@status_bar # The middle vbox contains the three main widgets.
|
56
|
+
)
|
57
|
+
third_dragger.position = 1300
|
58
|
+
minimal(third_dragger)
|
59
|
+
end
|
60
|
+
|
61
|
+
end; end; end; end
|
@@ -0,0 +1,405 @@
|
|
1
|
+
#!/usr/bin/ruby -w
|
2
|
+
# Encoding: UTF-8
|
3
|
+
# frozen_string_literal: true
|
4
|
+
# =========================================================================== #
|
5
|
+
# require 'multimedia_paradise/gui/gtk3/tag_mp3_files/create.rb'
|
6
|
+
# =========================================================================== #
|
7
|
+
module MultimediaParadise
|
8
|
+
|
9
|
+
module GUI
|
10
|
+
|
11
|
+
module Gtk
|
12
|
+
|
13
|
+
class TagMp3Files < ::Gtk::Box # === MultimediaParadise::GUI::Gtk::TagMp3Files
|
14
|
+
|
15
|
+
# ========================================================================= #
|
16
|
+
# === create_the_context_menu
|
17
|
+
# ========================================================================= #
|
18
|
+
def create_the_context_menu
|
19
|
+
# ======================================================================= #
|
20
|
+
# === @context_menu
|
21
|
+
# ======================================================================= #
|
22
|
+
@context_menu = create_context_menu(self) {{
|
23
|
+
# n_entries: 12,
|
24
|
+
actions: {
|
25
|
+
'• Play the selected audio file via mpv': :play_the_selected_audio_file,
|
26
|
+
'• Display some debug-information on the commandline': :show_debug_information
|
27
|
+
}
|
28
|
+
}}
|
29
|
+
@context_menu.use_this_font(main_font?)
|
30
|
+
@context_menu.css_class('bblack3_and_padding')
|
31
|
+
end
|
32
|
+
|
33
|
+
# ========================================================================= #
|
34
|
+
# === create_the_status_bar
|
35
|
+
# ========================================================================= #
|
36
|
+
def create_the_status_bar
|
37
|
+
# ======================================================================= #
|
38
|
+
# === @status_bar
|
39
|
+
# ======================================================================= #
|
40
|
+
@status_bar = gtk_status_bar
|
41
|
+
@status_bar.bblack1
|
42
|
+
@status_bar_context_id = @status_bar.get_context_id('tag_mp3_files')
|
43
|
+
end
|
44
|
+
|
45
|
+
# ========================================================================= #
|
46
|
+
# === create_the_labels (labels tag, label tag)
|
47
|
+
# ========================================================================= #
|
48
|
+
def create_the_labels
|
49
|
+
# ======================================================================= #
|
50
|
+
# === @label_description
|
51
|
+
#
|
52
|
+
# This is the very top-level description.
|
53
|
+
# ======================================================================= #
|
54
|
+
@label_description = bold_label(
|
55
|
+
'This widget can be used to modify the ID3 tags of .mp3 files'
|
56
|
+
)
|
57
|
+
@label_description.css_class('indigo')
|
58
|
+
@label_description.font_to_use = FONT_TO_USE_FOR_THE_MAIN_DESCRIPTION
|
59
|
+
end
|
60
|
+
|
61
|
+
# ========================================================================= #
|
62
|
+
# === create_the_settings
|
63
|
+
# ========================================================================= #
|
64
|
+
def create_the_settings
|
65
|
+
# ======================================================================= #
|
66
|
+
# === @settings_vbox
|
67
|
+
# ======================================================================= #
|
68
|
+
@settings_vbox = gtk_vbox
|
69
|
+
# ======================================================================= #
|
70
|
+
# Style this vbox a bit:
|
71
|
+
# ======================================================================= #
|
72
|
+
@settings_vbox.pad5px
|
73
|
+
@settings_vbox.set_border_width(20)
|
74
|
+
@settings_vbox.use_this_font = main_font?
|
75
|
+
_ = text("Settings\n")
|
76
|
+
_.use_this_font = main_font?
|
77
|
+
@settings_vbox.add(_)
|
78
|
+
@settings_vbox.add_hspacer
|
79
|
+
hbox = gtk_hbox
|
80
|
+
hbox.minimal(left_aligned_text('Specify the directory to the local songs here: '), 2)
|
81
|
+
hbox.minimal(@entry_use_this_as_the_directory_to_the_local_songs)
|
82
|
+
@settings_vbox << hbox
|
83
|
+
@settings_vbox.add_hspacer
|
84
|
+
@settings_vbox.use_this_font = main_font?
|
85
|
+
@settings_vbox.width_height(800, 300)
|
86
|
+
@settings_vbox.show_all
|
87
|
+
end
|
88
|
+
|
89
|
+
# ========================================================================= #
|
90
|
+
# === create_the_entries (entries tag, entry tag)
|
91
|
+
#
|
92
|
+
# This method will bundle - and create - all relevant gtk-entries
|
93
|
+
# in this application.
|
94
|
+
# ========================================================================= #
|
95
|
+
def create_the_entries
|
96
|
+
# ======================================================================= #
|
97
|
+
# === @entry_use_this_as_the_directory_to_the_local_songs
|
98
|
+
#
|
99
|
+
# This entry can be used to designate another directory for the
|
100
|
+
# local .mp3 files.
|
101
|
+
# ======================================================================= #
|
102
|
+
@entry_use_this_as_the_directory_to_the_local_songs = gtk_entry
|
103
|
+
@entry_use_this_as_the_directory_to_the_local_songs.set_text(
|
104
|
+
PATH_TO_THE_LOCAL_AUDIO_DIRECTORY
|
105
|
+
)
|
106
|
+
# ======================================================================= #
|
107
|
+
# === @entry_for_the_comment
|
108
|
+
# ======================================================================= #
|
109
|
+
@entry_for_the_comment = gtk_entry
|
110
|
+
@entry_for_the_comment.set_max_length(120)
|
111
|
+
@entry_for_the_comment.set_size_request(680, 40)
|
112
|
+
# ======================================================================= #
|
113
|
+
# === @entry_for_the_title_of_the_song
|
114
|
+
#
|
115
|
+
# The next entry contains the title of the song.
|
116
|
+
# ======================================================================= #
|
117
|
+
@entry_for_the_title_of_the_song = gtk_entry
|
118
|
+
@entry_for_the_title_of_the_song.set_max_length(150)
|
119
|
+
# ======================================================================= #
|
120
|
+
# === @entry_file_path
|
121
|
+
#
|
122
|
+
# The next entry, stored in @entry_file_path, will keep track
|
123
|
+
# of our audio-file. This is the most important entry.
|
124
|
+
# ======================================================================= #
|
125
|
+
@entry_file_path = gtk_entry
|
126
|
+
@entry_file_path.clear_background
|
127
|
+
@entry_file_path.pad5px
|
128
|
+
@entry_file_path.css_class('mar4px')
|
129
|
+
@entry_file_path.yellow_background
|
130
|
+
@entry_file_path.bblack2
|
131
|
+
@entry_file_path.make_bold
|
132
|
+
@entry_file_path.width_height(620, 42)
|
133
|
+
@entry_file_path.ghost_text('Provide the path to the .mp3 file here ...')
|
134
|
+
array = Dir['/home/x/songs/*'].map {|entry| File.basename(entry) }
|
135
|
+
@entry_file_path.simple_completion(array)
|
136
|
+
@entry_file_path.on_enter {
|
137
|
+
do_analyse_the_mp3_file
|
138
|
+
}
|
139
|
+
@entry_file_path.make_scrollable
|
140
|
+
@entry_file_path.signal_connect(:event) {|widget, event|
|
141
|
+
if scroll_up_event?(event)
|
142
|
+
do_assign_a_new_random_audio_file
|
143
|
+
elsif scroll_down_event?(event)
|
144
|
+
do_assign_a_new_random_audio_file
|
145
|
+
end
|
146
|
+
}
|
147
|
+
# ======================================================================= #
|
148
|
+
# If the user double-clicks on the file path then a new local file
|
149
|
+
# will be added.
|
150
|
+
# ======================================================================= #
|
151
|
+
@entry_file_path.on_mouse_double_click_event {|widget, event|
|
152
|
+
do_open_a_local_file_and_then_set_the_proper_entry
|
153
|
+
}
|
154
|
+
end
|
155
|
+
|
156
|
+
# ========================================================================= #
|
157
|
+
# === create_the_combo_box_entry_for_genre_select
|
158
|
+
# ========================================================================= #
|
159
|
+
def create_the_combo_box_entry_for_genre_select
|
160
|
+
if File.exist? FILE_MUSIC_GENRES
|
161
|
+
array_available_genres = YAML.load_file(FILE_MUSIC_GENRES)
|
162
|
+
else
|
163
|
+
array_available_genres = [] # Safeguard.
|
164
|
+
end
|
165
|
+
# ======================================================================= #
|
166
|
+
# === @combo_box_entry_for_genre_select
|
167
|
+
# ======================================================================= #
|
168
|
+
@combo_box_entry_for_genre_select = return_combo_box_entry(
|
169
|
+
with_these_elements: array_available_genres
|
170
|
+
)
|
171
|
+
@combo_box_entry_for_genre_select.clear_background
|
172
|
+
# @combo_box_entry_for_genre_select.bblack1
|
173
|
+
@combo_box_entry_for_genre_select.pad1px
|
174
|
+
@combo_box_entry_for_genre_select.css_class('fancy_combobox')
|
175
|
+
@combo_box_entry_for_genre_select.six_per_row
|
176
|
+
# ======================================================================= #
|
177
|
+
# Next we will unify the background for these entries here. Disabled
|
178
|
+
# in August 2021.
|
179
|
+
# ======================================================================= #
|
180
|
+
# set_a_uniform_background_for_the_entries_on_the_right_side_widget
|
181
|
+
# ======================================================================= #
|
182
|
+
# Next add the combo-box that contains all genres. We will not set
|
183
|
+
# an active entry, so that we can determine that this depends on
|
184
|
+
# the user having set it (or not, accordingly).
|
185
|
+
#
|
186
|
+
# @combo_box_entry_for_genre_select.active = 0
|
187
|
+
#
|
188
|
+
# ======================================================================= #
|
189
|
+
@combo_box_entry_for_genre_select.on_changed {
|
190
|
+
if @combo_box_entry_for_genre_select.active_iter
|
191
|
+
text = @combo_box_entry_for_genre_select.active_text
|
192
|
+
sync_this_text_onto_the_genre_entry(text)
|
193
|
+
end
|
194
|
+
}
|
195
|
+
end
|
196
|
+
|
197
|
+
# ========================================================================= #
|
198
|
+
# === create_status_icon
|
199
|
+
# ========================================================================= #
|
200
|
+
def create_status_icon(
|
201
|
+
tooltip_text = 'This text will show up upon a hover-event.'
|
202
|
+
)
|
203
|
+
@status_icon = gtk_status_icon
|
204
|
+
@status_icon.stock = ::Gtk::Stock::DIALOG_INFO
|
205
|
+
@status_icon.set_icon_name('default_status_icon_name') # We can set a name.
|
206
|
+
@status_icon.set_tooltip_text(tooltip_text)
|
207
|
+
@status_icon.signal_connect(:activate) { |icon|
|
208
|
+
if icon.respond_to? :blinking
|
209
|
+
icon.blinking = !(icon.blinking?)
|
210
|
+
end
|
211
|
+
}
|
212
|
+
# =========================================================================== #
|
213
|
+
# Add a menu and a quit-button too. These will be triggered upon a
|
214
|
+
# right-mouse-button presse vent.
|
215
|
+
# =========================================================================== #
|
216
|
+
menu = gtk_menu
|
217
|
+
|
218
|
+
play_button = ::Gtk::ImageMenuItem.new(stock: ::Gtk::Stock::MEDIA_PLAY)
|
219
|
+
play_button.signal_connect(:activate) {
|
220
|
+
do_play_the_selected_song
|
221
|
+
}
|
222
|
+
menu.append(play_button)
|
223
|
+
|
224
|
+
quit_button = ::Gtk::ImageMenuItem.new(stock: ::Gtk::Stock::QUIT)
|
225
|
+
quit_button.signal_connect(:activate) { ::Gtk.main_quit }
|
226
|
+
menu.append(quit_button)
|
227
|
+
|
228
|
+
menu.show_all
|
229
|
+
@status_icon.signal_connect(:popup_menu) { |icon, button, time|
|
230
|
+
menu.popup(nil, nil, button, time)
|
231
|
+
}
|
232
|
+
end
|
233
|
+
|
234
|
+
# ========================================================================= #
|
235
|
+
# === create_the_buttons (buttons tag, button tag)
|
236
|
+
# ========================================================================= #
|
237
|
+
def create_the_buttons
|
238
|
+
# ======================================================================= #
|
239
|
+
# === @button_analyse_the_mp3_file
|
240
|
+
# ======================================================================= #
|
241
|
+
@button_analyse_the_mp3_file = button('_Analyse the .mp3 file')
|
242
|
+
@button_analyse_the_mp3_file.on_clicked {
|
243
|
+
do_analyse_the_mp3_file
|
244
|
+
}
|
245
|
+
# ======================================================================= #
|
246
|
+
# === @box_for_the_button_analyse_the_mp3_file
|
247
|
+
# ======================================================================= #
|
248
|
+
@box_for_the_button_analyse_the_mp3_file = gtk_hbox
|
249
|
+
@box_for_the_button_analyse_the_mp3_file.maximal(@button_analyse_the_mp3_file, 2)
|
250
|
+
@spinner = gtk_spinner
|
251
|
+
@box_for_the_button_analyse_the_mp3_file.minimal(@spinner, 4)
|
252
|
+
# ======================================================================= #
|
253
|
+
# === @button_assume
|
254
|
+
# ======================================================================= #
|
255
|
+
@button_assume = button('Assume')
|
256
|
+
@button_assume.hint = 'This button can be used to assume and infer '\
|
257
|
+
'from the filename of the .mp3 file at hand '\
|
258
|
+
'the artist and the name of the song. This will '\
|
259
|
+
'only work for some songs, naturally, and you need '\
|
260
|
+
'to have a file assigned prior to being able to '\
|
261
|
+
'use this button.'
|
262
|
+
@button_assume.on_clicked {
|
263
|
+
do_assume_the_name_of_the_song_and_the_artist_from_the_filename_directly
|
264
|
+
}
|
265
|
+
# ======================================================================= #
|
266
|
+
# === @button_play
|
267
|
+
# ======================================================================= #
|
268
|
+
@button_play = return_button_play
|
269
|
+
# ======================================================================= #
|
270
|
+
# === @event_box_open_file
|
271
|
+
#
|
272
|
+
# This is a small "icon" that also makes use of an open-file functionality.
|
273
|
+
# ======================================================================= #
|
274
|
+
@event_box_open_file = return_event_box_for_opening_a_file
|
275
|
+
# ======================================================================= #
|
276
|
+
# === @button_debug
|
277
|
+
#
|
278
|
+
# The debug-button is created next.
|
279
|
+
# ======================================================================= #
|
280
|
+
@button_debug = gtk_button('_Debug')
|
281
|
+
@button_debug.on_hover(:lightgreen)
|
282
|
+
@button_debug.on_clicked {
|
283
|
+
load_the_id3_dataset_from_this_file
|
284
|
+
do_debug
|
285
|
+
}
|
286
|
+
@button_debug.hint = 'This button is just for quick debugging. '\
|
287
|
+
'Most users will not need this button.'
|
288
|
+
# ======================================================================= #
|
289
|
+
# === @button_update
|
290
|
+
#
|
291
|
+
# The update button. It will update the id3 tags at hand, once pressed.
|
292
|
+
# ======================================================================= #
|
293
|
+
@button_update = gtk_button('_Update') # update tag
|
294
|
+
use_this_icon_name = 'software-update-available-symbolic.symbolic'
|
295
|
+
icon = load_icon(use_this_icon_name, 32, 0)
|
296
|
+
@button_update.set_image(icon)
|
297
|
+
@button_update.set_always_show_image(true)
|
298
|
+
@button_update.set_border_width(1)
|
299
|
+
@button_update.set_size_request(125, 68)
|
300
|
+
@button_update.lightgreen
|
301
|
+
@button_update.hint = 'Press this button to '\
|
302
|
+
'<b>update the id3-tags</b> of the .mp3 file at hand.'
|
303
|
+
@button_update.on_clicked {
|
304
|
+
do_save_the_tags # Save the dataset upon a click-event.
|
305
|
+
}
|
306
|
+
# ======================================================================= #
|
307
|
+
# === @button_delete_the_tags
|
308
|
+
#
|
309
|
+
# The delete-the-tags-button.
|
310
|
+
# ======================================================================= #
|
311
|
+
@button_delete_the_tags = gtk_button('Delete the tags')
|
312
|
+
use_this_icon_name = 'edit-delete-symbolic.symbolic'
|
313
|
+
icon = load_icon(use_this_icon_name, 32, 0)
|
314
|
+
@button_delete_the_tags.set_image(icon)
|
315
|
+
@button_delete_the_tags.set_always_show_image(true)
|
316
|
+
@button_delete_the_tags.set_border_width(1)
|
317
|
+
@button_delete_the_tags.set_size_request(125, 68)
|
318
|
+
@button_delete_the_tags.hint =
|
319
|
+
"Click on this button to <b>remove all tags</b> "\
|
320
|
+
"from the given .mp3 file at hand. (The "\
|
321
|
+
"<b>save-button</b> works in precisely the same "\
|
322
|
+
"manner, by the way.)\n\nBe certain to use this only when you really"\
|
323
|
+
"want to remove all tags. Otherwise it may be better to ignore this "\
|
324
|
+
"button and instead modify the content, as-is, on the right-hand "\
|
325
|
+
"side."
|
326
|
+
@button_delete_the_tags.set_border_width(1)
|
327
|
+
@button_delete_the_tags.on_clicked {
|
328
|
+
do_empty_the_tags
|
329
|
+
}
|
330
|
+
@button_delete_the_tags.set_size_request(125, 68)
|
331
|
+
# ======================================================================= #
|
332
|
+
# === @button_save
|
333
|
+
#
|
334
|
+
# The save-button. It is located on the left-hand side of the main
|
335
|
+
# UI interface. This could be made inactive via a not_sensitive call.
|
336
|
+
# ======================================================================= #
|
337
|
+
@button_save = return_the_save_button(:do_not_make_use_of_a_special_CSS_class)
|
338
|
+
# ======================================================================= #
|
339
|
+
# === @button_close
|
340
|
+
# ======================================================================= #
|
341
|
+
@button_close = gtk_button_with_label(' _Close') # close tag
|
342
|
+
use_this_icon_name = 'application-exit'
|
343
|
+
icon = load_icon(use_this_icon_name, 32, 0) # Use the video-x-generic button.
|
344
|
+
@button_close.set_image(icon)
|
345
|
+
@button_close.set_always_show_image(true)
|
346
|
+
@button_close.set_border_width(1)
|
347
|
+
@button_close.set_size_request(125, 68)
|
348
|
+
@button_close.on_clicked { ::Gtk.main_quit }
|
349
|
+
@button_close.do_focus
|
350
|
+
@button_close.hint = 'Press this button to '\
|
351
|
+
'<b>exit the application</b>.'
|
352
|
+
# ======================================================================= #
|
353
|
+
# === @button_open_a_random_audio_file
|
354
|
+
# ======================================================================= #
|
355
|
+
@button_open_a_random_audio_file = return_button_open_a_random_audio_file
|
356
|
+
# ======================================================================= #
|
357
|
+
# === @button_perform_a_google_search
|
358
|
+
# ======================================================================= #
|
359
|
+
@button_perform_a_google_search = gtk_button_with_label(' _Google search')
|
360
|
+
use_this_icon_name = 'help-browser'
|
361
|
+
icon = load_icon(use_this_icon_name, 32, 0) # Use the video-x-generic button.
|
362
|
+
@button_perform_a_google_search.set_image(icon)
|
363
|
+
@button_perform_a_google_search.set_always_show_image(true)
|
364
|
+
@button_perform_a_google_search.set_border_width(1)
|
365
|
+
@button_perform_a_google_search.set_size_request(125, 68)
|
366
|
+
@button_perform_a_google_search.on_clicked {
|
367
|
+
do_perform_a_google_search
|
368
|
+
}
|
369
|
+
@button_perform_a_google_search.do_focus
|
370
|
+
@button_perform_a_google_search.hint = "Search via google "\
|
371
|
+
"for wikipedia-related entries about the assumed "\
|
372
|
+
"song and group.\n\nNote that this requires some entries to "\
|
373
|
+
"exist already, such as the name of the song, and ideally "\
|
374
|
+
"the name of the artist as well.\n\nThis functionality depends "\
|
375
|
+
"on the gem called '<b>open</b>', so install that gem before "\
|
376
|
+
"trying to use this button.\n"
|
377
|
+
end
|
378
|
+
|
379
|
+
# ========================================================================= #
|
380
|
+
# === create_the_header_bar (header tag)
|
381
|
+
# ========================================================================= #
|
382
|
+
def create_the_header_bar
|
383
|
+
# ======================================================================= #
|
384
|
+
# === @header_bar
|
385
|
+
# ======================================================================= #
|
386
|
+
@header_bar = widget_top
|
387
|
+
end
|
388
|
+
|
389
|
+
# ========================================================================= #
|
390
|
+
# === create_skeleton (create tag, skeleton tag)
|
391
|
+
#
|
392
|
+
# The order for the various create-method calls is important.
|
393
|
+
# ========================================================================= #
|
394
|
+
def create_skeleton
|
395
|
+
create_the_labels # (1) Must come before create_the_header_bar()
|
396
|
+
create_the_entries # (4) Must come before we create the header, the main grid and the buttons.
|
397
|
+
create_the_header_bar # (2)
|
398
|
+
create_the_context_menu # (3) Ok to call it here.
|
399
|
+
create_the_buttons # (5) Must come after we create_the_entries().
|
400
|
+
create_the_status_bar # (6)
|
401
|
+
create_status_icon # (7)
|
402
|
+
create_the_settings # (8)
|
403
|
+
end
|
404
|
+
|
405
|
+
end; end; end; end
|