文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

线稿图视频制作补充(调整视频亮度、对比度;删除无用文件)

2023-09-06 19:00

关注

🔝🔝🔝🔝🔝🔝🔝🔝🔝🔝🔝🔝🔝🔝🔝 

🥰 博客首页:knighthood2001

😗 欢迎点赞👍评论🗨️

❤️ 热爱python,期待与大家一同进步成长!!❤️

目录

一、整合视频

二、删除无用文件(视频帧图片)

三、视频亮度调暗

四、对比度调整

五、全部代码展示

六、总结


之前内容(建议看一下) 

这年头还不来尝试线稿图视频??https://blog.csdn.net/knighthood2001/article/details/126175764?spm=1001.2014.3001.5502线稿图视频制作--从此短视频平台不缺上传视频了https://blog.csdn.net/knighthood2001/article/details/126912547?spm=1001.2014.3001.5502

一、整合视频

        目前文件夹比较清晰vedio文件夹中是经过线稿图转换前后的视频,data文件夹是代码运行过程中,线稿图制作过程中产生的相应的文件。

代码更改如下:

lj = 'vedio/'file = 'bang.mp4'filename = file.split(".")[0]mp3_file = f'{filename}.mp3'if not os.path.exists('vedio'):    os.mkdir('vedio')

  lj表示路径(/别忘了),

cap = cv2.VideoCapture(lj + file)
# 音频提取def extract_audio():    my_clip = mp.VideoFileClip(lj + file)    my_clip.audio.write_audiofile('data/' + mp3_file)
    video_merge.write_videofile(lj + 'final_' + b + '.mp4')

 读取视频、音频提取和最终视频合成的时候,需要多这个路径。

二、删除无用文件(视频帧图片)

import osdef deldir(dir):    if not os.path.exists(dir):        print('{}(路径)无内容'.format(dir))        return    if os.path.isfile(dir):        os.remove(dir)        return    for i in os.listdir(dir):        t = os.path.join(dir, i)        if os.path.isdir(t):            deldir(t)        else:            os.unlink(t)    os.removedirs(dir)    print('{}已删除'.format(dir))

构建一个这样的函数,从而把不需要的文件删除,后续只需要调用即可

deldir('data/gougou')deldir('data/gougou_newpc')deldir('data/silence_dindin.mp4')deldir('data/dindin.mp3')deldir('data/dindin')# 删除不用的图片和视频deldir(path)# deldir(new_picture_path)deldir(file_name)

三、视频亮度调暗

from moviepy.editor import *clip = VideoFileClip(r"final_gougou1.mp4")clipColorx = clip.fx(vfx.colorx, 0.5)clipColorx.write_videofile(r"gougou2.mp4")

首先传入视频,如何更改上面的参数(0.5可以换成其他的,当它小于1,表示调暗,大于1表示调亮),最后将亮度变化的视频保存即可。

四、对比度调整

import moviepy.video.fx.lum_contrastfrom moviepy.editor import *# 对比度调整clip = VideoFileClip(r"vedio/gougou.mp4")a = moviepy.video.fx.lum_contrast.lum_contrast(clip, contrast=0.3, contrast_thr=127)a.write_videofile(r"gougou13.mp4")

我们可以调整contrast参数

def lum_contrast(clip, lum = 0, contrast=0, contrast_thr=127):    """ luminosity-contrast correction of a clip """    """剪辑的亮度对比度校正"""        def fl_image(im):        im = 1.0*im # float conversion        corrected = im + lum + contrast*(im-float(contrast_thr))        corrected[corrected < 0] = 0        corrected[corrected > 255] = 255        return corrected.astype('uint8')        return clip.fl_image(fl_image)

这是lum_consrast()函数代码。

五、全部代码展示

        注意:调整视频亮度、对比度不在代码里面

import osimport cv2from PIL import Imagefrom PIL import ImageFilterimport moviepy.editor as mplj = 'vedio/'# TODO 更改文件名称file = '1.mp4'filename = file.split(".")[0]mp3_file = f'{filename}.mp3'if not os.path.exists('vedio'):    os.mkdir('vedio')if not os.path.exists('data'):    os.mkdir('data')path = os.path.join('data', filename)new_picture_path = os.path.join('data', filename + "_newpc")if not os.path.exists(path):    os.mkdir(path)if not os.path.exists(new_picture_path):    os.mkdir(new_picture_path)# 无声视频file_name = os.path.join('data', 'silence_' + file)cap = cv2.VideoCapture(lj + file)fps = int(cap.get(cv2.CAP_PROP_FPS))width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))frames = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))print('fps:', fps, '\n', 'width:', width, '\n', 'height:', height, '\n', 'frames:', frames)for i in range(0, frames):    flag, frame = cap.read()    filename = path + '/{}.jpg'.format(str(i))    print(filename)    cv2.imwrite(filename, frame)# 音频提取def extract_audio():    my_clip = mp.VideoFileClip(lj + file)    my_clip.audio.write_audiofile('data/' + mp3_file)# 原图-线稿图转换def convert():    for i in range(0, frames):        '''细节'''        square = Image.open(path + "/{}.jpg".format(i))        square1 = square.filter(ImageFilter.DETAIL)        '''轮廓'''        square2 = square1.filter(ImageFilter.CONTOUR)        square2.save(new_picture_path + "/{}.jpg".format(i))        print(new_picture_path + "/{}.jpg".format(i))# 原图-线稿图转换(边缘增强)def convert_edge():    for i in range(0, frames):        square = Image.open(path + "/{}.jpg".format(i))        square1 = square.filter(ImageFilter.EDGE_ENHANCE)        '''轮廓'''        square2 = square1.filter(ImageFilter.CONTOUR)        square2.save(new_picture_path + "/{}.jpg".format(i))        print(new_picture_path + "/{}.jpg".format(i))# 生成无声视频def picture_merge():    size = (width, height)    videowrite = cv2.VideoWriter(file_name, -1, fps, size)    for i in range(0, frames):        img = cv2.imread(new_picture_path + "/{}.jpg".format(i))        videowrite.write(img)    videowrite.release()    print('end!')# 最终合成有声视频def final_merge():    video = mp.VideoFileClip(file_name)    audio = mp.AudioFileClip('data/' + mp3_file)    video_merge = video.set_audio(audio)    # todo 最终生成的带音频的视频    b = file.split(".")[0]    video_merge.write_videofile(lj + 'final_' + b + '.mp4')# 删除不要文件def deldir(dir):    if not os.path.exists(dir):        print('{}(路径)无内容'.format(dir))        return    if os.path.isfile(dir):        os.remove(dir)        return    for i in os.listdir(dir):        t = os.path.join(dir, i)        if os.path.isdir(t):            deldir(t)        else:            os.unlink(t)    os.removedirs(dir)    print('{}已删除'.format(dir))if __name__ == '__main__':    extract_audio()    convert()    # convert_edge()    picture_merge()    final_merge()    # 删除不用的图片和视频    # deldir(path)    # # deldir(new_picture_path)    # deldir(file_name)

六、总结

        线稿图视频制作到目前应该就算完结了。感兴趣的可以去试试。

        笔者源代码也发了,希望能支持一下,给个关注!!

        👀赶紧来刷题学习,巩固基础吧👀

来源地址:https://blog.csdn.net/knighthood2001/article/details/126957085

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯