mirror of
https://github.com/gabrielkheisa/meme-generator.git
synced 2024-11-24 04:13:36 +07:00
106 lines
2.5 KiB
Python
106 lines
2.5 KiB
Python
|
#!/usr/bin/env python3
|
||
|
from moviepy.editor import *
|
||
|
import base64
|
||
|
import time
|
||
|
import textwrap
|
||
|
import mysql.connector
|
||
|
|
||
|
|
||
|
|
||
|
bendera = 0
|
||
|
|
||
|
theteks = ""
|
||
|
picture = VideoFileClip("video.mp4")
|
||
|
|
||
|
thesize = 25
|
||
|
|
||
|
|
||
|
def checkindo():
|
||
|
mycursor = mydb.cursor()
|
||
|
sql = "SELECT * FROM meme WHERE status = '0' "
|
||
|
|
||
|
mycursor.execute(sql)
|
||
|
|
||
|
myresult = mycursor.fetchall()
|
||
|
|
||
|
if not myresult:
|
||
|
print("No input video")
|
||
|
return
|
||
|
|
||
|
for x in myresult:
|
||
|
user_empty = x[1]
|
||
|
text_db = x[4] # Fetch from Teks
|
||
|
print(text_db)
|
||
|
if (len(user_empty)) <= 1:
|
||
|
print("Ok")
|
||
|
return
|
||
|
else:
|
||
|
print("User " + user_empty + " kosong, rendering " + str(user_empty))
|
||
|
|
||
|
text_dbd = str(base64.b64decode(text_db))
|
||
|
|
||
|
theteks = text_dbd[2:]
|
||
|
tp = theteks.split(",")
|
||
|
t1 = textwrap.fill(tp[0].upper(), thesize)
|
||
|
t2 = textwrap.fill(tp[1].upper(), thesize)
|
||
|
t3 = textwrap.fill(tp[2].upper(), thesize)
|
||
|
t4 = textwrap.fill(tp[3].upper(), thesize)
|
||
|
t5 = textwrap.fill(tp[4].upper(), thesize)
|
||
|
t6 = textwrap.fill(tp[5].upper(), thesize)
|
||
|
t7 = textwrap.fill(tp[6].upper(), thesize)
|
||
|
t8 = textwrap.fill(tp[7].upper(), thesize)
|
||
|
t9 = textwrap.fill(tp[8].upper(), thesize)
|
||
|
t10 = "10 KETIKA 11"
|
||
|
|
||
|
texts = [t1,t2,t3,t4,t5,t6,t7,t8,t9]
|
||
|
|
||
|
|
||
|
step = 3 #each 15 sec: 0, 15, 30
|
||
|
duration = 3
|
||
|
t = 0
|
||
|
txt_clips = []
|
||
|
|
||
|
starts = [0,3,6,9,12,15,20,23,26] # or whatever
|
||
|
durations = [3,3,3,3,3,5,3,3,3]
|
||
|
|
||
|
for text,t,duration in zip(texts, starts, durations):
|
||
|
txt_clip = TextClip(text, fontsize = 40, color='white', font="Roboto Mono", stroke_color="black")
|
||
|
txt_clip = txt_clip.set_start(t)
|
||
|
txt_clip = txt_clip.set_pos('bottom').set_duration(duration)
|
||
|
txt_clips.append(txt_clip)
|
||
|
|
||
|
final_video = CompositeVideoClip([picture,txt_clips[0],txt_clips[1],txt_clips[2],txt_clips[3],txt_clips[4],txt_clips[5],txt_clips[6],txt_clips[7],txt_clips[8]])
|
||
|
|
||
|
final_video.write_videofile(str(user_empty)+".mp4")
|
||
|
|
||
|
#with open('teks.txt', "w") as myfile:
|
||
|
#myfile.write("S0VUSUtBIDEsS0VUSUtBIDIsS0VUSUtBIDMsS0VUSUtBIDQsS0VUSUtBIDUsS0VUSUtBIDYsS0VUSUtBIDcsS0VUSUtBIDgsS0VUSUtBIDks")
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
sql = "UPDATE meme SET status = \'"+ "1" +"\' WHERE session = \'" + str(user_empty) +"\'"
|
||
|
mycursor.execute(sql)
|
||
|
# myresult = mycursor.fetchall()
|
||
|
mydb.commit()
|
||
|
return
|
||
|
|
||
|
|
||
|
while True:
|
||
|
mydb = mysql.connector.connect(
|
||
|
host="",
|
||
|
user="",
|
||
|
password="",
|
||
|
database=""
|
||
|
)
|
||
|
|
||
|
checkindo()
|
||
|
time.sleep(1)
|
||
|
|
||
|
# textwrap.fill(tp[0].upper(), thesize)
|
||
|
|
||
|
|
||
|
|
||
|
|