1分钟制作朋友圈9宫格图片,不用任何P图软件

简介: 1分钟制作朋友圈9宫格图片,不用任何P图软件

前言


我们很多人每天都有用手机刷朋友圈的习惯,可能大家也注意到了,最近微信朋友圈与微博已经掀起了9宫格图片的玩法。


可以说将单个图片,或者说单个动图亦或视频分割成9份发在朋友圈,感觉很有趣。


今天,博主就通过Python、OpenCV、pyqt5的知识,来帮助大家实现任意图像,视频,动图的9宫格原理。


文末还有配套生成9宫格的pyqt5的源代码以及exe可运行文件奉上。


生成9宫格图片


一般来说,我们生成的9宫格原图必须是正方形的,毕竟朋友圈与微博整体的9宫格就是正方形的。


但是博主为了9宫格的完备,只需要删除下面一段代码就可以完成任意图形的9宫格,只是大多数平台不支持非正方形的9宫格图片。


下面,我们直接将一张图片分割成9份,代码如下:

# 生成9宫格图片
def grid9_image(imageFileName):
    if not os.path.exists('image'):
        os.makedirs('image')
    image = cv2.imread(imageFileName, 1)
    #删除代码段头
    height, width, n = image.shape
    if width >= height:
        image = cv2.resize(image, (width, width))
        height=width
    else:
        image = cv2.resize(image, (height, height))
        width = height
    #删除代码段尾
    height = int(height / 3)
    width = int(width / 3)
    x = 1
    for i in range(0, 3):
        for j in range(0, 3):
            print(i * height, height * (i + 1), j * width, width * (j + 1))
            result = image[i * height:height * (i + 1), j * width:width * (j + 1)]
            print('image/' + str(x) + ".png")
            cv2.imwrite('image/' + str(x) + ".png", result)
            x += 1


这里,我们是横切分算法,首先i在j循环结束之前是不会变化的,那么就可以保证前面的切分一直就是三分之一。


后面的是宽度切分,第1份j=0,后面就是j+1=1为前三分之一,循环一次后j=1,也就是(width,widht*2),最后j=2时,(width*2,width*3)。(把注释中间的代码删除,得到的是任意图形的均分9份)


i与j的算法同理,原理如下图。记得这里是width,height是整体宽度高度除于3后得到的。


当然,使用画图工具分割的有点不规则该请见谅,读者可以把其想象成规整的看。同时如果i,j调换位置,那么图片就是竖切分算法。会从左到右,从上到下依次切分。



生成9宫格动图


动图可以由两种形式生成:一种是提供一个短视频转换为动图;一种是直接提供一个GIF动图,直接切分。



短视频生成动图9宫格

首先,我们来看看,提供一个短视频后切分动图,代码如下:

# 短视频生成9宫格动图
def grid9_gif(srcVideoFileName):
    if not os.path.exists('gif'):
        os.makedirs('gif')
    all_frames = []
    cap = cv2.VideoCapture(srcVideoFileName)
    fps = cap.get(cv2.CAP_PROP_FPS)
    for i in range(9):
        list = []
        all_frames.append(list)
    while (cap.isOpened()):
        ret, frame = cap.read()
        if ret:
            height, width, n = frame.shape
            if width >= height:
                frame = cv2.resize(frame, (width, width))
                height = width
            else:
                frame = cv2.resize(frame, (height, height))
                width = height
            height = int(height / 3)
            width = int(width / 3)
            frame_list = []
            for i in range(0, 3):
                for j in range(0, 3):
                    result = frame[i * height:height * (i + 1), j * width:width * (j + 1)]
                    frame_list.append(result)
            for index, image in zip(range(9), frame_list):
                all_frames[index].append(image)
        else:
            break
    for index, frames in zip(range(9), all_frames):
        imageio.mimsave("gif/" + str(index + 1) + ".gif", frames, 'GIF', duration=float(1 / fps))
    cap.release()


其实,可以看出来,中间的切分算法与图片的一模一样。因为视频本身就是由单一的图片构成的。


这里,我们只要将视频每个图片切分,然后分别存储,等到读取完成之后,将每个部分转换为GIF即可。(至于动图的每帧间隔时间,就是1/视频的FPS)


GIF直接生成动图9宫格

对于GIF,OpenCV并没有直接处理动图的函数。所以,最简单的方式,就是通过将动图转换为视频后,在通过上面的代码进行处理。


代码如下:

# GIF生成9宫格动图
def grid9_gif2(srcGIFFileName):
    clip = mp.VideoFileClip(srcGIFFileName)
    clip.write_videofile("gifVideo.mp4")
    grid9_gif('gifVideo.mp4')


这里就是使用moviepy库将GIF转换为视频后,再通过上面的grid9_gif处理。


需要注意的是,目前各大平台并不支持动图自动播放,比如微博必须点击动图才能动,如果后续支持动图自动播放,那么这种动图9宫格的切分也能完美实现。目前效果与静态图片一样,只能看到每个动图的第1帧。


生成9宫格视频


生成9宫格视频,我们就不必切分了。因为视频本身就是一个整体,没有哪个社交软件,可以同一条朋友圈或者微博发9个视频的。


所以,我们只需要将视频中间画上4条分割线,就完成了9宫格视频的生成。代码如下:

#生成9宫格视频
def gird9_Video(srcVideoFileName, outputVideoFilename):
    cap = cv2.VideoCapture(srcVideoFileName)
    fps = cap.get(cv2.CAP_PROP_FPS)
    width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
    height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
    fourcc = cv2.VideoWriter_fourcc(*'MJPG')
    videoWriter = cv2.VideoWriter(outputVideoFilename + ".avi", fourcc, fps, (width, height))
    i = 1
    while (cap.isOpened()):
        ret, frame = cap.read()
        if ret:
            cv2.line(frame, (0, int(height / 3)), (width, int(height / 3)), (255, 255, 255), 3)
            cv2.line(frame, (0, int(height / 3 * 2)), (width, int(height / 3 * 2)), (255, 255, 255), 3)
            cv2.line(frame, (int(width / 3), 0), (int(width / 3), height), (255, 255, 255), 3)
            cv2.line(frame, (int(width / 3 * 2), 0), (int(width / 3 * 2), height), (255, 255, 255), 3)
            videoWriter.write(frame)
        else:
            break
    cap.release()


代码很简单,就是对每个视频的图片画4条分割线。运行之后,效果如下:


使用pyqt5打包成exe界面


对于我们程序员来说,部署的Python环境可以直接运行上面的代码生成你想要的任何9宫格素材。但是对于不是程序员的小伙伴,提供一个可运行的程序,往往体验更加友好。

这里,博主将通过pyqt5打包上述功能成为GUI界面程序。因为代码过多,对pyqt5感兴趣的可以直接前往github网址下载。


源代码:点击下载


exe运行文件:点击下载

相关文章
|
5月前
|
前端开发 程序员
HTML+CSS+JavaScript制作动态七夕表白网页(含音乐+自定义文字)
一年一度的520情人节/七夕情人节/女朋友生日/程序员表白,是不是要给女朋友或者正在追求的妹子一点小惊喜呢,今天这篇博客就分享下前端代码如何实现HTML+CSS+JavaScript制作七夕表白网页(含音乐+自定义文字)。赶紧学会了,来制作属于我们程序员的浪漫吧!
153 0
|
6月前
仿照微信朋友圈中点击图片出现大图浏览效果
仿照微信朋友圈中点击图片出现大图浏览效果
81 0
|
8月前
微信小游戏制作工具中关于背景图的设置
微信小游戏制作工具中关于背景图的设置
236 0
|
自然语言处理 Python Windows
平面设计实验三 手机海报与选区操作
平面设计实验三 手机海报与选区操作
88 0
|
Android开发
如何用手机快速制作好看的二维码
由于二维码的出现,给我们的生活带来了很大的方便。由于工作的原因,小编经常会看到一些制作精美的二维码,很是好奇他们是怎么制作出如此好看的二维码的。为了给大家推荐真正好用的二维码制作软件,小编对比了市面上好多类似的软件,发现了一款还不错的App--二维码和条形码生成器,支持鸿蒙、安卓、苹果等各种手机。下面就让小编给大家详细介绍下如何用“二维码和条形码生成器”来制作精美的二维码吧。
|
前端开发
精美素材:10套最新出炉的免费扁平图标下载
  这里分享新鲜出炉的10套免费的扁平图标素材,可以用于网页设计和移动用户界面设计相关的项目。这些简约风格扁平化图标可用于多种用途,如:GUI 设计,印刷材料,WordPress 主题,演示,信息图表和插图等等。
952 0
|
Web App开发 iOS开发
23套新鲜出炉的网站和手机界面 PSD 素材
  Web 用户界面,移动用户界面和线框套件对设计师很有用,因为这些套件让他们使用快速和有效的方式复制用户界面。这些类型的工具包提供了一个基本的用户界面元素,用于它们需要制作的网站或软件模型。   在这篇文章中,我们展示的是自由和清新的 UI 设计素材套件。
1016 0

热门文章

最新文章