欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python3視頻轉(zhuǎn)字符動畫的實例代碼

 更新時間:2019年08月29日 10:31:50   作者:挑食de豬隊友  
這篇文章主要介紹了Python3視頻轉(zhuǎn)字符動畫的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

Python3視頻轉(zhuǎn)字符動畫,具體代碼如下所示:

# -*- coding:utf-8 -*-
import json
import os
import subprocess
from pathlib import Path
from cv2 import cv2
import numpy as np
from time import time
import webbrowser
play_chars_js = '''
let i = 0;
window.setInterval(function(){
  let img = frames[i++];
  let html = ""
  for(let line of img){
    for(let char of line){
      let [[r,g,b], ch] = char;
      html += '<span style="color:rgb(' + r + ', ' + g + ', '+ b + ');">'+ ch + '</span>'
      // html += '<span style="background-color:rgb(' + r + ', ' + g + ', '+ b + ');">'+ ch + '</span>'
    }
    html += "<br>"
  }
  document.getElementsByClassName("video-panel")[0].innerHTML = html
}, 1000/fps);
document.getElementsByTagName("audio")[0].play();
'''
class VideoToHtml:
  # 像素形狀,因為顏色已經(jīng)用rgb控制了,這里的pixels其實可以隨意排
  pixels = "$#@&%ZYXWVUTSRQPONMLKJIHGFEDCBA098765432?][}{/)(><zyxwvutsrqponmlkjihgfedcba*+1-."
  def __init__(self, video_path, fps_for_html=8, time_interval=None):
    """
    :param video_path: 字符串, 視頻文件的路徑
    :param fps_for_html: 生成的html的幀率
    :param time_interval: 用于截取視頻(開始時間,結(jié)束時間)單位秒
    """
    self.video_path = Path(video_path)
    # 從指定文件創(chuàng)建一個VideoCapture對象
    self.cap = cv2.VideoCapture(video_path)
    self.width = self.cap.get(cv2.CAP_PROP_FRAME_WIDTH)
    self.height = self.cap.get(cv2.CAP_PROP_FRAME_HEIGHT)
    self.frames_count_all = self.cap.get(cv2.CAP_PROP_FRAME_COUNT)
    self.fps = self.cap.get(cv2.CAP_PROP_FPS)
    self.resize_width = None
    self.resize_height = None
    self.frames_count = 0
    self.fps_for_html = fps_for_html
    self.time_interval = time_interval
  def video2mp3(self):
    """#調(diào)用ffmpeg獲取mp3音頻文件"""
    mp3_path = self.video_path.with_suffix('.mp3')
    subprocess.call('ffmpeg -i ' + str(self.video_path) + ' -f mp3 ' + str(mp3_path), shell=True)
    return mp3_path
  def set_width(self, width):
    """只能縮小,而且始終保持長寬比"""
    if width >= self.width:
      return False
    else:
      self.resize_width = width
      self.resize_height = int(self.height * (width / self.width))
      return True
  def set_height(self, height):
    """只能縮小,而且始終保持長寬比"""
    if height >= self.height:
      return False
    else:
      self.resize_height = height
      self.resize_width = int(self.width * (height / self.height))
      return True
  def resize(self, img):
    """
    將img轉(zhuǎn)換成需要的大小
    原則:只縮小,不放大。
    """
    # 沒指定就不需resize了
    if not self.resize_width or not self.resize_height:
      return img
    else:
      size = (self.resize_width, self.resize_height)
      return cv2.resize(img, size, interpolation=cv2.INTER_CUBIC)
  def get_img_by_pos(self, pos):
    """獲取到指定位置的幀"""
    # 把指針移動到指定幀的位置
    self.cap.set(cv2.CAP_PROP_POS_FRAMES, pos)
    # cap.read() 返回值介紹:
    #  ret 布爾值,表示是否讀取到圖像
    #  frame 為圖像矩陣,類型為 numpy.ndarray.
    ret, frame = self.cap.read()
    return ret, frame
  def get_frame_pos(self):
    """生成需要獲取的幀的位置,使用了惰性求值"""
    step = self.fps / self.fps_for_html
    # 如果未指定
    if not self.time_interval:
      self.frames_count = int(self.frames_count_all / step) # 更新count
      return (int(step * i) for i in range(self.frames_count))
    # 如果指定了
    start, end = self.time_interval
    pos_start = int(self.fps * start)
    pos_end = int(self.fps * end)
    self.frames_count = int((pos_end - pos_start) / step) # 更新count
    return (pos_start + int(step * i) for i in range(self.frames_count))
  def get_imgs(self):
    assert self.cap.isOpened()
    for i in self.get_frame_pos():
      ret, frame = self.get_img_by_pos(i)
      if not ret:
        print("讀取失敗,跳出循環(huán)")
        break
      yield self.resize(frame) # 惰性求值
    # 結(jié)束時要釋放空間
    self.cap.release()
  def get_char(self, gray):
    percent = gray / 255 # 轉(zhuǎn)換到 0-1 之間
    index = int(percent * (len(self.pixels) - 1)) # 拿到index
    return self.pixels[index]
  def get_json_pic(self, img):
    """測試階段,不實用"""
    json_pic = []
    # 寬高剛好和size相反,要注意。(這是numpy的特性。。)
    height, width, channel = img.shape
    # 轉(zhuǎn)換成灰度圖,用來選擇合適的字符
    img_gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    for y in range(height):
      line = []
      for x in range(width):
        r, g, b = img[y][x]
        gray = img_gray[y][x]
        char = self.get_char(gray)
        line.append([[int(r), int(g), int(b)], char])
      json_pic.append(line)
    return json.dumps(json_pic)
  def write_html_with_json(self, file_name):
    """測試階段,不實用"""
    mp3_path = self.video2mp3()
    time_start = time()
    with open(file_name, 'w') as html:
      # 要記得設(shè)置monospace等寬字體,不然沒法玩
      html.write('<!DOCTYPE html>'
            '<html>'
            '<body style="font-family: monospace; font-size: small; font-weight: bold; text-align: center; line-height: 0.8;">'
            '<div class="video-panel"></div>'
            f'<audio src="{mp3_path.name}" autoplay controls></audio>'
            '</body>'
            '<script>'
            'var frames=[\n')
      try:
        i = 0
        for img in self.get_imgs():
          json_pic = self.get_json_pic(img)
          html.write(f"{json_pic},")
          if i % 20:
            print(f"進度:{i/self.frames_count * 100:.2f}%, 已用時:{time() - time_start:.2f}")
          i += 1
      finally:
        html.write('\n];\n'
              f'let fps={self.fps_for_html};\n'
              f'{play_chars_js}'
              '</script>\n'
              '</html>')
def main():
  # 視頻路徑,換成你自己的
  video_path = "ceshi.mp4"
  video2html = VideoToHtml(video_path, fps_for_html=8)
  video2html.set_width(120)
  html_name = Path(video_path).with_suffix(".html").name
  video2html.write_html_with_json(html_name)
if __name__ == "__main__":
  main()

總結(jié)

以上所述是小編給大家介紹的Python3視頻轉(zhuǎn)字符動畫的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • Python-while 計算100以內(nèi)奇數(shù)和的方法

    Python-while 計算100以內(nèi)奇數(shù)和的方法

    今天小編就為大家分享一篇Python-while 計算100以內(nèi)奇數(shù)和的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • 利用Python找出序列中出現(xiàn)最多的元素示例代碼

    利用Python找出序列中出現(xiàn)最多的元素示例代碼

    這篇文章主要給大家介紹了關(guān)于利用Python找出序列中出現(xiàn)最多的元素的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-12-12
  • python 實現(xiàn)Harris角點檢測算法

    python 實現(xiàn)Harris角點檢測算法

    這篇文章主要介紹了python 實現(xiàn)Harris角點檢測算法,幫助大家更好的利用python處理圖像,感興趣的朋友可以了解下
    2020-12-12
  • 快速上手基于Anaconda搭建Django環(huán)境的教程

    快速上手基于Anaconda搭建Django環(huán)境的教程

    Django具有完整的封裝,開發(fā)者可以高效率的開發(fā)項目,Django將大部分的功能進行了封裝,開發(fā)者只需要調(diào)用即可,接下來通過本文給大家介紹基于Anaconda搭建Django環(huán)境的教程,需要的朋友可以參考下
    2021-10-10
  • Python 基于wxpy庫實現(xiàn)微信添加好友功能(簡潔)

    Python 基于wxpy庫實現(xiàn)微信添加好友功能(簡潔)

    這篇文章主要介紹了Python 基于wxpy庫實現(xiàn)微信添加好友功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-11-11
  • Python爬蟲Xpath定位數(shù)據(jù)的兩種方法

    Python爬蟲Xpath定位數(shù)據(jù)的兩種方法

    這篇文章主要介紹了Python爬蟲Xpath定位數(shù)據(jù)的方法,第一種方法直接右鍵,將文章路徑復制下來點擊Copy?full?Xpath,方法二使用@制定標簽屬性,搜索指定位置,每種方法給大家介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 對pandas進行數(shù)據(jù)預處理的實例講解

    對pandas進行數(shù)據(jù)預處理的實例講解

    下面小編就為大家分享一篇對pandas進行數(shù)據(jù)預處理的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • python pyqtgraph 保存圖片到本地的實例

    python pyqtgraph 保存圖片到本地的實例

    這篇文章主要介紹了python pyqtgraph 保存圖片到本地的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • python 使用元類type創(chuàng)建類

    python 使用元類type創(chuàng)建類

    這篇文章主要介紹了Python 使用元類type創(chuàng)建類,結(jié)合實例形式詳細分析了Python元類的概念、功能及元類type創(chuàng)建類對象的常見應(yīng)用技巧,需要的朋友可以參考一下文章的具體內(nèi)容。希望對你有所幫助
    2021-10-10
  • 解決IDEA 的 plugins 搜不到任何的插件問題

    解決IDEA 的 plugins 搜不到任何的插件問題

    這篇文章主要介紹了解決IDEA 的 plugins 搜不到任何的插件問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05

最新評論