你好,FFMPEG 可视化

给大家看看我现在的玩具:

它有哪些功能呢?如你所见,不止于此

1. 视频录制

暂时只能录制视频,音频无法录制

FFMPEG.exe 暂时只支持视频,音频录制需要下载额外的工具

2. 视频处理

支持简单的分割,裁剪,以及压缩

简单实用

3. 视频转Gif

支持高清模式,生成文件会更大

下载与使用

1. 安装WebView2 RunTime

Webview2 - Microsoft Edge Developer



点击 下载,然后安装

2. 下载TidyView

这是WebView2的封装

百度网盘 TidyVew 密码:Tidy

TidyView不提供任何功能,具体功能需要以App形式存在

3. 下载FFMPEG Visual

这是一个 TidyView 的App

百度网盘 FFMPEG Visual 密码:Tidy

上述是 FFMPEG Visual 的目录结构

其中 main.edge 便是入口程序

4. 打开FFMPEG Visual

右键 main.edge 打开方式 选择其他应用

更多应用 在这台电脑上选择其他应用 找到TidyView.exe 打开

下次打开,勾选 始终使用此应用打开.edge文件即可

5. 第一次使用

第一次使用时,程序会自动下载ffmpeg.exe

下载完成后,会进入主页面

枯燥环节

下面便是技术环节了

1. 啥是main.edge?

其实就是一个脚本文件,TidyScript,TidyScript小组

有C#的语法,也有JavaScript的一些特征

运行速度慢,但是灵活性高

log.clear();

var Url;
var JS; void download(string url)
{
var path=Environment["ScriptDir"]+"\\ffmpeg.zip";
var downitem={};
downitem.url=url;
downitem.path=path;
downitem.file="FFMPEG.exe";
downitem.dest="用于视频操作的核心程序";
var params={};
params.download=[];
params.download.Add(downitem);
Launch("Download/download.edge",params);
} void OnLoad()
{
EvalJS($"_tool_bar_ini({file.read(locate("plugins.json"))})");
} void LoadPage(string Page)
{
Launch("frame",Page);
} if(file.exists(locate("ffmpeg.exe")))
{
Url="main.html";
JS="main.js";
}
else if(file.exists(locate("ffmpeg.zip")))
{
Url="main.html";
JS="main.js";
zip.uncompress(locate("ffmpeg.zip"),Environment["ScriptDir"] as string);
thread.sleep(1000);
file.delete(locate("ffmpeg.zip"));
}
else
{
Url="https://shareyun.lanzous.com/iyuEeok4p6j";
JS="main_download_ffmpeg.js";
}

2. 工作框架

从打包的角度,有两个东西,一个是TidyView,另一个是TidyScript写的脚本

往下面探一层,有四个东西:

  1. WebView2提供浏览器功能
  2. C#写的dll提供本地化功能
  3. Html+JS提供页面UI功能
  4. TidyScript写的脚本提供业务功能

如果把WebView2作为基础件,忽略掉,就是下面这个结构。

3. 工作流程



4. 交互方案

每个页面都会注入基本JS

var edge = window.chrome.webview.hostObjects.edge;
var _id = (id) => { return document.getElementById(id); };
var _attr = (id, name) => { return document.getElementById(id).getAttribute(name) };
var call = (name, ...args) => { edge.CallApp(app_frame_path, name, ...args) };
var _frame = (frame_path) =>
{
var paths = frame_path.split(".");
var last = null;
for (var i in paths) {
if (last == null) {
last = document.getElementById(paths[i]);
}
else {
last = last.contentDocument.getElementById(paths[i]);
}
}
return last;
};

假设一个TidyScript脚本如下

void Hello()
{
EvalJS("console.log('hello world')");
}
void Hello(string Name)
{
EvalJS($"console.log('hello world {Name}')");
}

JS中调用TidyScript中的函数就很简单

直接在JS中这样写:call("Hello")

或者这样写:call("Hello","TidyScript")

那么TidyScript如何调用JS呢?

其实上面的代码已经告诉我们答案:EvalJS("console.log('hello world')")

其核心功能是WebView2提供的

ExecuteScriptAsync(string Script)

namespace Microsoft.Web.WebView2.WinForms
{
public class WebView2 : Control, ISupportInitialize
{
public WebView2();
//....
public Uri Source { get; set; }
public CoreWebView2 CoreWebView2 { get; }
public CoreWebView2CreationProperties CreationProperties { get; set; }
protected override CreateParams CreateParams { get; }
//下面这个方法提供运行JS脚本功能
public Task<string> ExecuteScriptAsync(string script);
public void GoBack();
//.....
}
}

FFMPEG Visual 结构

最后

这个玩具很不错,既能我自己玩,也能给大家玩。

但是它还是有点简陋,下面会把它慢慢完善

下一个玩具呢?

暂时还不知道,确定好了,再说。

你好,FFMPEG 可视化的更多相关文章

  1. [译]学习IPython进行交互式计算和数据可视化(五)

    第四章:交互式绘图接口 本章我们将展示Python的绘图功能以及如何在IPython中交互式地使用它们. NumPy为处理大量的多维数组结构的数据提供了高效的方法.但是看行行列列的数字总不如直接看曲线 ...

  2. FFMpeg ver 20160219-git-98a0053 滤镜中英文对照 2016.02.21 by 1CM

    FFMpeg ver 20160219-git-98a0053 滤镜中英文对照 2016.02.21 by 1CM T.. = Timeline support 支持时间轴 .S. = Slice t ...

  3. FFMpeg ver 20160213-git-588e2e3 滤镜中英文对照

    1 FFMpeg ver 20160213-git-588e2e3 滤镜中英文对照 2016.02.18 by 1CM 2 T.. = Timeline support 3 支持时间轴 4 .S. = ...

  4. FFMpeg 滤镜中英文对照

    FFMpeg ver 20160213-git-588e2e3 滤镜中英文对照 2016.02.17 by 1CM T.. = Timeline support 支持时间轴 .S. = Slice t ...

  5. pytorch visdom可视化工具学习—1—详细使用-1—基本使用函数

    使用教程,参考: https://github.com/facebookresearch/visdom https://www.pytorchtutorial.com/using-visdom-for ...

  6. Bootstrap 可视化HTML编辑器,summernote

    Bootstrap 可视化HTML编辑器之summernote,用其官网上的介绍就是"Super Simple WYSIWYG editor",不过在我看来,与bootstrap中 ...

  7. 第二章 FFmpeg常用命令

    2.1 FFmpeg常见的命令大概分为6个部分 ffmpeg信息查询部分 公共操作参数部分 文件主要操作参数部分 视频操作参数部分 字幕操作参数部分 2.1.1 FFmpeg的封装转换 FFmpeg ...

  8. Gource 方便的软件版本可视化录制工具

    Gource 是一个特别棒的软件变更可视化录制工具,我们可以使用此工具,方便的将软件的版本变动,录制 为视频 安装 brew install gource brew install ffmpeg   ...

  9. python可视化基础

    常用的python可视化工具包是matplotlib,seaborn是在matplotlib基础上做的进一步封装.入坑python可视化,对有些人来说如同望山跑死马,心气上早输了一节.其实学习一门新知 ...

随机推荐

  1. Ajax的基本用法

    1.介绍 2.基本用法 2.1原生写法 $.ajax({ url: url, //是否是异步请求,默认是 // async: false, //请求方式,默认是get //type:'get', // ...

  2. (数据科学学习手札109)Python+Dash快速web应用开发——静态部件篇(中)

    本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 这是我的系列教程Python+Dash快速web ...

  3. Newbe.Claptrap 框架入门,第二步 —— 创建项目

    接上一篇 Newbe.Claptrap 框架入门,第一步 -- 开发环境准备 ,我们继续了解如何创建一个 Newbe.Claptrap 项目. Newbe.Claptrap 是一个用于轻松应对并发问题 ...

  4. 如何系统的了解Kafka

    1.概述 在大数据的浪潮下,时时刻刻都会产生大量的数据.比如社交媒体.博客.电子商务等等,这些数据会以不同的类型存储在不同的平台里面.为了执行ETL(提取.转换.加载)操作,需要一个消息中间件系统,该 ...

  5. java 基础语法学习

    kuangstudy 注释 单行注释 多行注释 文档注释 public class HelloWorld { public static void main(String[] args) { //单行 ...

  6. Vue.js 实现的 3D Tab菜单

    今天给大家带来一款基于VueJS的3D Tab菜单,它跟我们之前分享的许多CSS3 Tab菜单不同的是,它可以随着鼠标移动呈现出3D立体的视觉效果,每个tab页面还可以通过CSS自定义封面照片.它的核 ...

  7. sanic-jwt 的使用

    Sanic 是基于 Python 的一个支持高并发的异步 web 框架,sanic-jwt 则是针对Sanic 开发的一个基于 PyJWT 封装的 JWT 授权认证模块. sanic-jwt 项目主页 ...

  8. python3中post请求 json 数据

    post请求 #!/usr/bin/env python # -*- coding:utf-8 -*- import requests import json headers = { "Us ...

  9. Qt update刷新之源码分析总结

    大家好,我是IT文艺男,来自一线大厂的一线程序员 经过前面几次的Qt源码讲解,我相信大家对Qt update刷新机制从底层原理上有了一个深刻的理解:这次做一个收尾总结,来复盘前面几次所讲解的内容: 分 ...

  10. Lzzy高级语言程序设计之for循环

    public class Mq { public static void main(String[]args){ int a = 3 ; a++;// do{ System.out.println(& ...