2019-06-09 00:51:00 +00:00
|
|
|
'use strict';
|
|
|
|
var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
|
if (mod && mod.__esModule) return mod;
|
|
|
|
var result = {};
|
|
|
|
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
|
|
result["default"] = mod;
|
|
|
|
return result;
|
|
|
|
};
|
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
|
const path = __importStar(require("path"));
|
2019-06-09 01:43:14 +00:00
|
|
|
const fs_extra_1 = require("fs-extra");
|
|
|
|
const exec_1 = require("exec");
|
2019-06-09 00:51:00 +00:00
|
|
|
let system = {};
|
|
|
|
let TMPDIR;
|
|
|
|
function padded_frame(i) {
|
|
|
|
let len = (i + '').length;
|
|
|
|
let str = i + '';
|
|
|
|
for (let x = 0; x < 5 - len; x++) {
|
|
|
|
str = '0' + str;
|
|
|
|
}
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
async function frame(state, light) {
|
|
|
|
let frame = state.frame;
|
|
|
|
let video = state.path;
|
|
|
|
let w = state.info.width;
|
|
|
|
let h = state.info.height;
|
|
|
|
let padded = padded_frame(frame);
|
|
|
|
let ext = 'tif';
|
|
|
|
let rgb = light.color;
|
|
|
|
let tmpoutput;
|
|
|
|
let cmd;
|
|
|
|
let output;
|
|
|
|
let cmd2;
|
|
|
|
let output2;
|
2019-06-18 17:47:55 +00:00
|
|
|
//if (system.platform !== 'nix') {
|
|
|
|
ext = 'png';
|
|
|
|
//}
|
2019-06-09 00:51:00 +00:00
|
|
|
rgb = rgb.map((e) => {
|
|
|
|
return parseInt(e);
|
|
|
|
});
|
|
|
|
tmpoutput = path.join(TMPDIR, `export-${padded}.${ext}`);
|
|
|
|
cmd = `ffmpeg -y -i "${video}" -vf "select='gte(n\\,${frame})',scale=${w}:${h}" -vframes 1 -compression_algo raw -pix_fmt rgb24 "${tmpoutput}"`;
|
|
|
|
cmd2 = `convert "${tmpoutput}" -resize ${w}x${h} -size ${w}x${h} xc:"rgb(${rgb[0]},${rgb[1]},${rgb[2]})" +swap -compose Darken -composite "${tmpoutput}"`;
|
|
|
|
//ffmpeg -i "${video}" -ss 00:00:07.000 -vframes 1 "export-${time}.jpg"
|
|
|
|
//ffmpeg -i "${video}" -compression_algo raw -pix_fmt rgb24 "export-%05d.tiff"
|
|
|
|
//-vf "select=gte(n\,${frame})" -compression_algo raw -pix_fmt rgb24 "export-${padded}.png"
|
|
|
|
try {
|
|
|
|
console.log(cmd);
|
2019-06-09 01:43:14 +00:00
|
|
|
output = await exec_1.exec(cmd);
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
if (output && output.stdout)
|
|
|
|
console.log(`"${output.stdout}"`);
|
|
|
|
if (rgb[0] !== 255 || rgb[1] !== 255 || rgb[2] !== 255) {
|
|
|
|
try {
|
|
|
|
console.log(cmd2);
|
2019-06-09 01:43:14 +00:00
|
|
|
output2 = await exec_1.exec(cmd2);
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (output2 && output2.stdout)
|
|
|
|
console.log(`"${output2.stdout}"`);
|
|
|
|
}
|
|
|
|
async function frames(video, obj) {
|
|
|
|
let tmppath = TMPDIR;
|
|
|
|
let ext = 'tif';
|
|
|
|
let tmpoutput;
|
2019-06-18 17:47:55 +00:00
|
|
|
//if (system.platform !== 'nix') {
|
|
|
|
ext = 'png';
|
|
|
|
//}
|
2019-06-09 00:51:00 +00:00
|
|
|
tmpoutput = path.join(tmppath, `export-%05d.${ext}`);
|
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
await fs_extra_1.mkdir(tmppath);
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
//ffmpeg -i "${video}" -compression_algo raw -pix_fmt rgb24 "${tmpoutput}"
|
|
|
|
}
|
|
|
|
async function clear(frame) {
|
|
|
|
let padded = padded_frame(frame);
|
|
|
|
let ext = 'tif';
|
|
|
|
let tmppath;
|
|
|
|
let tmpoutput;
|
|
|
|
let cmd;
|
2019-06-09 01:43:14 +00:00
|
|
|
let fileExists;
|
2019-06-18 17:47:55 +00:00
|
|
|
//if (system.platform !== 'nix') {
|
|
|
|
ext = 'png';
|
|
|
|
//}
|
2019-06-09 00:51:00 +00:00
|
|
|
tmppath = path.join(TMPDIR, `export-${padded}.${ext}`);
|
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
fileExists = await fs_extra_1.exists(tmppath);
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
2019-06-09 01:43:14 +00:00
|
|
|
if (!fs_extra_1.exists)
|
2019-06-09 00:51:00 +00:00
|
|
|
return false;
|
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
await fs_extra_1.unlink(tmppath);
|
2019-06-09 00:51:00 +00:00
|
|
|
console.log(`Cleared frame ${tmppath}`);
|
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
async function clearAll() {
|
|
|
|
let tmppath = TMPDIR;
|
|
|
|
let files;
|
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
files = await fs_extra_1.readdir(tmppath);
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
if (files) {
|
|
|
|
files.forEach(async (file, index) => {
|
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
await fs_extra_1.unlink(path.join(tmppath, file));
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
async function checkDir() {
|
2019-06-09 01:43:14 +00:00
|
|
|
let fileExists;
|
2019-06-09 00:51:00 +00:00
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
fileExists = await fs_extra_1.exists(TMPDIR);
|
2019-06-09 00:51:00 +00:00
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error('Error checking for tmp dir', err);
|
|
|
|
}
|
2019-06-15 15:06:57 +00:00
|
|
|
if (!fileExists) {
|
2019-06-09 00:51:00 +00:00
|
|
|
try {
|
2019-06-09 01:43:14 +00:00
|
|
|
await fs_extra_1.mkdir(TMPDIR);
|
2019-06-09 00:51:00 +00:00
|
|
|
console.log(`Created tmpdir ${TMPDIR}`);
|
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error('Error creating tmp dir', err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
await clearAll();
|
|
|
|
}
|
|
|
|
catch (err) {
|
|
|
|
console.error(err);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
module.exports = (sys) => {
|
|
|
|
system = sys;
|
|
|
|
TMPDIR = path.join(system.tmp, 'mcopy_digital');
|
|
|
|
checkDir();
|
|
|
|
return {
|
|
|
|
frames,
|
|
|
|
frame,
|
|
|
|
clear,
|
|
|
|
clearAll
|
|
|
|
};
|
|
|
|
};
|
|
|
|
//# sourceMappingURL=index.js.map
|