import cv2

import numpyas np

coor_x,coor_y= -1, -1 # 初始值并无意义,只是为了能够使用np.row_stack函数

# """定义视频编码器

# FourCC全称Four-Character Codes,代表四字符代码 (four character code),

# 它是一个32位的标示符,其实就是typedef unsigned int FOURCC;

# 是一种独立标示视频数据流格式的四字符代码。

# 因此cv2.VideoWriter_fourcc()函数的作用是输入四个字符代码即可得到对应的视频编码器。

# """

def video_cut_action():

fourcc= cv2.VideoWriter_fourcc(*'MPEG')#(*'XVID') # 使用XVID编码器

camera= cv2.VideoCapture('E:/test.mp4')#('细胞极体拨动合成视频.wmv') # 从文件读取视频,Todo:只需要修改成自己的视频路径即可进行测试

fps= camera.get(cv2.CAP_PROP_FPS)# 获取视频帧率

print('视频帧率:%d fps' %fps)

# 判断视频是否成功打开

if (camera.isOpened()):

print('视频已打开')

else:

print('视频打开失败!')

# # 测试用,查看视频size

size= (int(camera.get(cv2.CAP_PROP_FRAME_WIDTH)),

int(camera.get(cv2.CAP_PROP_FRAME_HEIGHT)))

print ('视频尺寸:'+repr(size))

coor= np.array([[1,1]])# Todo:初始值并无意义,只是为了能够使用np.row_stack函数

def OnMouseAction(event,x,y,flags,param):

global coor_x,coor_y,coor

if event == cv2.EVENT_LBUTTONDOWN:

print("左键点击")

print("%s" %x,y)

coor_x,coor_y= x ,y

coor_m= [coor_x,coor_y]

coor= np.row_stack((coor,coor_m))

elif event==cv2.EVENT_LBUTTONUP:

cv2.line(img, (coor_x, coor_y), (coor_x, coor_y), (255, 255, 0), 7)

elif event==cv2.EVENT_RBUTTONDOWN:

print("右键点击")

elif flags==cv2.EVENT_FLAG_LBUTTON:

print("左鍵拖曳")

elif event==cv2.EVENT_MBUTTONDOWN:

print("中键点击")

'''

创建回调函数的函数setMouseCallback();

下面把回调函数与OpenCV窗口绑定在一起

'''

grabbed, img= camera.read()# 逐帧采集视频流

cv2.namedWindow('Image')

cv2.setMouseCallback('Image',OnMouseAction)

while(1):

cv2.imshow('Image',img)

k=cv2.waitKey(1)& 0xFF

if k==ord(' '): # 空格退出操作

break

cv2.destroyAllWindows()# 关闭页面

Width_choose= coor[2,0]-coor[1,0]# 选中区域的宽

Height_choose= coor[2, 1]- coor[1, 1]# 选中区域的高

print('.......................width..................height')

# print(Width_choose)

# print(Height_choose)

print("视频选中区域的宽:%d" %Width_choose,'\n'"视频选中区域的高:%d" %Height_choose)

print("111111111111")

out= cv2.VideoWriter('E://video_test//test_new.mp4',fourcc, fps, (Width_choose,Height_choose))# 参数分别是:保存的文件名、编码器、帧率、视频宽高  avi

Video_choose = np.zeros((Width_choose, Height_choose, 3), np.uint8)

# videoWriter = cv2.VideoWriter('E://video_test//test_new.mp4', cv2.VideoWriter_fourcc('m', 'p', '4', 'v'), fps, size)

while True:

grabbed, frame= camera.read()# 逐帧采集视频流

if not grabbed:

break

gray_lwpCV= cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)# 转灰度图

frame_data= np.array(gray_lwpCV)# 每一帧循环存入数组

box_data= frame_data[coor[1,1]:coor[2,1], coor[1,0]:coor[2,0]]# 取矩形目标区域

pixel_sum= np.sum(box_data, axis=1)# 行求和q

x= range(Height_choose)

emptyImage= np.zeros((Width_choose* 10, Height_choose* 2, 3), np.uint8)

Video_choose= frame[coor[1,1]:coor[2,1],coor[1,0]:coor[2,0]]

out.write(Video_choose)

cv2.imshow('Video_choose', Video_choose)

for iin x:

cv2.rectangle(emptyImage, (i*2, (Width_choose-pixel_sum[i]//255)*10), ((i+1)*2, Width_choose*10), (255, 0, 0), 1)

emptyImage = cv2.resize(emptyImage, (320, 240))

lwpCV_box = cv2.rectangle(frame, tuple(coor[1,:]), tuple(coor[2,:]), (0, 255, 0), 2)

cv2.imshow('lwpCVWindow', frame)# 显示采集到的视频流

# videoWriter.write(lwpCV_box)  # 将截取到的画面写入“新视频”

# videoWriter = ('lwpCVWindow', frame)

# cv2.imshow('sum', emptyImage)  # 显示画出的条形图

key= cv2.waitKey(1)& 0xFF

if key== ord('q'):

break

out.release()

camera.release()

cv2.destroyAllWindows()

def select_action():

cv2.destroyAllWindows()

if __name__== "__main__":

video_cut_action()

python视频裁剪_Python MovePy 视频区域裁剪相关推荐

  1. python音视频开发_Python音视频开发:消除抖音短视频Logo的图形化工具实现

    一.引言 在<Python音视频开发:消除抖音短视频Logo和去电视台标的实现详解>节介绍了怎么通过Python+Moviepy+OpenCV实现消除视频Logo的四种方法,并提供了详细的 ...

  2. python去除视频马赛克_python 给视频添加马赛克

    用法: 1. 创建空文件夹:imgs 2. 将倒数第三行中的"222056.mov"改为你的视频路径,如:"a.mov" 3. 运行以下代码 4. 稍等片刻,鼠 ...

  3. python设置背景音乐_python给视频添加背景音乐并改变音量的具体方法

    用到给视频添加背景音乐,并改变音量.记录一下,与碰到同样问题的朋友共享. import subprocess inmp4='E:/PycharmProjects/untitled2/hecheng/1 ...

  4. 怎么把动态图从python弄下来_Python将视频或者动态图gif逐帧保存为图片的方法

    本文是基于opencv将视频和动态图gif保存为图像帧.可以根据输入视频格式的不同,修改第21行. 对动图的处理不同于视频,PIL库包含对图像序列的基本支持.当打开gif图像时,自动加载第一帧.当图像 ...

  5. python怎么去掉视频字幕_Python实现视频语音和字幕自动审查功能

    功能描述: 提取视频文件中的图像然后使用OCR技术识别静态图像中的文本,提取视频文件中的音频然后使用语音识别技术提取其中的文本,如果视频文本或音频文本中包含指定的关键词则进行提示. 代码使用tesse ...

  6. python moviepy 音量_python moviepy 视频剪辑代码

    from moviepy.editor import * from moviepy.audio.fx import all # 字体名字不能含有中文 FONT_URL = './font/heimi. ...

  7. python 获取本地视频信息_python获取视频文件信息

    技术爱好者 随笔 - 42, 文章 - 0, 评论 - 0, 引用 - 0 importos importsys importxlwt from moviepy.editor importVideoF ...

  8. python截取视频图像_python提取视频第一帧图片

    一.实现代码 # -*- coding: utf-8 -*- import cv2 from PIL import Image from io import BytesIO def tryTime(m ...

  9. python截取视频图片_python提取视频第一帧图片

    一.实现代码 # -*- coding: utf-8 -*- import cv2 from PIL import Image from io import BytesIO def tryTime(m ...

最新文章

  1. 【阿里聚安全·安全周刊】Intel芯片级安全漏洞事件|macOS存在漏洞
  2. 文件分区格式化及挂载
  3. PyTorch一年增长194%,兼容性更强,超越TensorFlow指日可待
  4. Android——Intent动作汇总(转)
  5. 计网 - 流和缓冲区:缓冲区的 flip 是怎么回事?
  6. python消息推送_Python阿里云消息推送调用API
  7. 欧拉路HDU3018
  8. 改改Python代码,运行速度还能提升6万倍,Science:先别想摩尔定律了
  9. WordPress网站迁移数据最佳解决方案
  10. 自己制作精美的App Store 软件截屏
  11. 修改notebook的默认路径_更改jupyter notebook默认存储路径
  12. win10下安装mysql5.6 zip形式步骤
  13. 计算机libeay32.dll丢失怎么办,电脑libeay32.dll丢失的解决方法
  14. 麦咖啡服务器怎么进系统,麦咖啡(McAfee)系统托盘图标不见了怎么办?
  15. 人工智能导论学习笔记
  16. 京东自动评价助手/京东评价
  17. 移动硬盘坏了数据可以恢复吗 移动硬盘坏了怎么导出数据
  18. python连接hive
  19. [转帖]三堂课,破译企业生存密码
  20. Symbian游戏编程入门 (一)(转)

热门文章

  1. 苹果库克赢得最佳CEO声誉的10个理由
  2. 泰国的IPv6功能已从约2%增至30%,部署率位于全球5名
  3. 人文地理学部分复习思考题答案
  4. android建ftp服务器,Android 快速搭建FTP服务器的方法
  5. MySQL 中 is null 和 =null 的区别
  6. 如何快速拉近与客户的关系?
  7. 计算机硬件发展的特点有哪些,简述计算机的发展历程及各代计算机的特点。
  8. Linux 常用命令——超详细(建议收藏)
  9. evaluate函数使用无效_VBA学习笔记5:函数与公式
  10. 网站安全狗V3.4版 让网站加速起来