第一种:
from moviepy.editor import *
def add_logo():
LOGO_PATH = "image.png"
video_path = r'video.mp4'
video = VideoFileClip(video_path).subclip(t_start=3, t_end=(100))
logo = (ImageClip(LOGO_PATH).set_duration(30)
.resize(height=80)
.margin(right=8, top=8,opacity=1)
.set_pos(("right", "top")))
final = CompositeVideoClip([video, logo])
final.write_videofile("./logo.mp4", codec="libx264", bitrate="10000000")
add_logo()
第二种:
import cv2
import numpy as np
#importing the main image
image = cv2.imread('0.png')
oH,oW = image.shape[:2]
image = np.dstack([image, np.ones((oH,oW), dtype="uint8") * 255])
#importing the logo image
lgo_img = cv2.imread('picture.png',cv2.IMREAD_UNCHANGED)
#Resizing the image
scl = 10
w = int(lgo_img.shape[1] * scl / 30)
h = int(lgo_img.shape[0] * scl / 30)
dim = (w,h)
lgo = cv2.resize(lgo_img, dim, interpolation = cv2.INTER_AREA)
lH,lW = lgo.shape[:2]
#Blending
ovr = np.zeros((oH,oW,4), dtype="uint8")
ovr[oH - lH - 60:oH - 60, oW - lW - 10:oW - 10] = lgo
final = image.copy()
final = cv2.addWeighted(ovr,0.5,final,1,0,final)
cv2.imshow("logo",lgo)
第三种:
def add_image(src_img,logo_image,px,py):
src_img = Image.fromarray(src_img)
watermark = Image.open(logo_image)
watermark = watermark.convert('RGBA')
lw,lh = watermark.size
watermark = watermark.resize((int(lw*scale),int(lh*scale)))
lwr,lhr = watermark.size
width, height = src_img.size
transparent = Image.new('RGBA', (width, height), (0,0,0,0))
transparent.paste(src_img, (0,0))
transparent.paste(watermark, (px-lwr,py), mask=watermark)
#transparent.show()
transparent = numpy.asarray(transparent)
return transparent