This commit is contained in:
Egor Deev 2024-02-28 18:32:04 +07:00 committed by GitHub
parent 53ecbf7fb5
commit 65bf7b0a06
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 186 additions and 0 deletions

58
code/main.py Normal file
View file

@ -0,0 +1,58 @@
from scripts import Movie, Frame
import os, shutil
def edit_circle(nearly):
video_file = str(input("Напишите название видео: "))
video_name = video_file[:-4]
path = f"../videos/{video_name}"
os.mkdir(path)
path_video = path + "/" + video_file
os.replace("../" + video_file, path_video)
path_frames = path + f"/frames"
os.mkdir(path_frames)
path_background = path + f"/background"
os.mkdir(path_background)
print("\n1. Обработка видео.")
video = Movie(path_video, video_name, path)
procces = video.split_into_frames()
if not procces:
print("\nВозникла ошибка!")
shutil.rmtree(path)
return 0
print("2. Обработка кадров.")
var = int(input("Какой тип фона? Градиент или блюр: "))
frames = list(sorted(os.listdir(path_frames)))
for frame in frames:
img = Frame(path_frames + "/" + frame, path_background + "/" + f'{frame[:-5]}-g.jpeg')
width, height = img.size()
if var:
img.blur(width, height)
else:
r, g, b = img.medium_color()
img.gradient(width, height, (r - nearly, g - nearly, b - nearly),
(r + nearly, g + nearly, b + nearly), (True, False, False))
img.unity_image()
print("\n3. Объединение кадров.")
video.unity_into_video(frames)
print("4. Очищение памяти.")
os.replace(path + "/acs-" + video_file, "../acs-" + video_file)
shutil.rmtree(path)
print("5. Готово!")
edit_circle(10)

128
code/scripts.py Normal file
View file

@ -0,0 +1,128 @@
from PIL import Image, ImageDraw, ImageFilter
from moviepy.editor import *
import numpy, os
class Movie:
def __init__(self, video_file, video_name, path):
self.video_file = video_file
self.video_name = video_name
self.path = path
self.path_frames = ""
def split_into_frames(self):
video_clip = VideoFileClip(self.video_file)
video_clip.audio.write_audiofile(self.path + f"/{self.video_name}-audio.mp3", verbose=False, logger=None)
self.path_frames = self.path + "/frames"
step = 1 / 30.0 if video_clip.fps > 60.0 else 1 / video_clip.fps
count = 0
for current_duration in numpy.arange(0, video_clip.duration, step):
count += 1
str_c = str(count)
num = "00000"[:(len(str_c) * -1)] + str_c
frame_filename = os.path.join(self.path_frames, f"frame-{num}.jpeg")
try: video_clip.save_frame(frame_filename, current_duration)
except Exception: return False
video_clip.close()
return True
def unity_into_video(self, frames):
video_clip = VideoFileClip(self.video_file)
fps = 30.0 if video_clip.fps > 60.0 else video_clip.fps
video_clip.close()
os.remove(self.video_file)
clip = ImageSequenceClip(list(map(lambda x: self.path_frames + "/" + x, frames)), fps=fps)
clip.write_videofile(self.video_file, verbose=False, logger=None)
clip.close()
video_clip = VideoFileClip(self.video_file)
audio_clip = AudioFileClip(self.path + f"/{self.video_name}-audio.mp3")
video_clip_with_audio = video_clip.set_audio(audio_clip)
video_clip_with_audio.write_videofile(self.path + "/acs-" + self.video_name + ".mp4", verbose=False, logger=None)
video_clip.close()
audio_clip.close()
class Frame:
def __init__(self, filename, background):
self.filename = filename
self.background = background
def size(self):
image = Image.open(self.filename)
width, height = image.size
image.close()
return width, height
def medium_color(self):
img = Image.open(self.filename)
width, height = img.size
pixels = img.load()
r, g, b = [], [], []
for y in range(width):
for x in range(height):
p = pixels[x, y]
r.append(p[0])
g.append(p[1])
b.append(p[2])
r = sum(r) // len(r)
g = sum(g) // len(g)
b = sum(b) // len(b)
img.close()
return r, g, b
def gradient(self, width, height, start_list, stop_list, is_horizontal_list):
def get_gradient(start, stop, width, height, is_horizontal):
if is_horizontal:
return numpy.tile(numpy.linspace(start, stop, width), (height, 1))
else:
return numpy.tile(numpy.linspace(start, stop, height), (width, 1)).T
result = numpy.zeros((height, width, len(start_list)))
for i, (start, stop, is_horizontal) in enumerate(zip(start_list, stop_list, is_horizontal_list)):
result[:, :, i] = get_gradient(start, stop, width, height, is_horizontal)
Image.fromarray(numpy.uint8(result)).save(self.background, quality=95)
def blur(self, width, height):
image = Image.open(self.filename)
image = image.filter(ImageFilter.GaussianBlur(6))
part_width = width // 64
part_height = height // 64
image = image.crop((part_width * 10, part_height * 10, part_width * 54, part_height * 54))
image = image.resize((width, height))
image.save(self.background, quality=95)
image.close()
def unity_image(self):
im1 = Image.open(self.background)
im2 = Image.open(self.filename)
mask = Image.new("L", im2.size, 0)
draw = ImageDraw.Draw(mask)
draw.ellipse(((1, 1), (im2.size[0] - 1, im2.size[1] - 1)), fill=255)
mask_blur = mask.filter(ImageFilter.GaussianBlur(1))
im1.paste(im2, (0, 0), mask_blur)
im1.save(self.filename)
im1.close()
im2.close()
mask.close()