basic load video works, before splitting files

This commit is contained in:
Sanjay B 2013-03-04 13:55:54 +05:30
parent 83b4ab91be
commit c726380a55
2 changed files with 140 additions and 29 deletions

View File

@ -37,7 +37,11 @@ pandora.ui.mainMenu = function() {
'id': 'fileMenu', 'id': 'fileMenu',
'title': 'File', 'title': 'File',
'items': [ 'items': [
{ id: 'openFileMenu', title: 'Open File'}, { id: 'openLocalFileMenu', title: 'Open Local File', 'file': {
'maxFiles': 1
}
},
{ id: 'openRemoteFileMenu', title: 'Open online pan.do/ra file'},
{ id: 'saveFileMenu', title: 'Save File', keyboard: 'shift control s'} { id: 'saveFileMenu', title: 'Save File', keyboard: 'shift control s'}
] ]
} }
@ -52,8 +56,25 @@ pandora.ui.mainMenu = function() {
if (data.id == 'saveFileMenu') { if (data.id == 'saveFileMenu') {
pandora.$ui.textArea.speedtrans.save(); pandora.$ui.textArea.speedtrans.save();
// speedtrans.saveFile(); // speedtrans.saveFile();
} else if (data.id == 'openFileMenu') { } else if (data.id == 'openLocalFileMenu') {
pandora.$ui.textArea.speedtrans.load("/A/480p.webm"); var file = data.files[0];
Ox.oshash(file, function(oshash) {
console.log(oshash);
var url = window.URL.createObjectURL(file);
var options = {
'type': 'local',
'url': url,
'name': oshash
}
pandora.$ui.textArea.speedtrans.load(options);
});
//console.log(data.files[0]);
} else if (data.id == 'openRemoteFileMenu') {
pandora.$ui.openRemoteDialog = pandora.ui.openRemoteDialog().open();
} else if (data.id == 'TestMenu1') {
alert("clicked TestMenu1");
} }
}, },
key_control_shift_s: function() { key_control_shift_s: function() {
@ -83,10 +104,10 @@ pandora.ui.mainPanel = function() {
} }
pandora.ui.videoPanel = function() { pandora.ui.videoPanel = function() {
var that = Ox.SplitPanel({ var that = pandora.$ui.videoPanel = Ox.SplitPanel({
elements: [ elements: [
{ {
element: pandora.$ui.videoPlayer = pandora.ui.videoPlayer(), element: pandora.$ui.videoPlayer = Ox.Element().text("no video yet"),
size: 300 size: 300
}, },
{ {
@ -98,16 +119,20 @@ pandora.ui.videoPanel = function() {
return that; return that;
} }
pandora.ui.videoPlayer = function() {
var that = Ox.VideoPlayer({ //FIXME: should be ui.videoPlayer
video: '/A/480p.webm', pandora.ui.videoPlayer = function(options) {
controlsTop: ['play', 'fullscreen', 'scale', 'position'], var url = options.url;
controlsBottom: ['timeline'], var timeline = options.timeline || "foo.png"; //FIXME
var that = pandora.$ui.videoPlayer = Ox.VideoPlayer({
video: url,
controlsTop: ['fullscreen'],
controlsBottom: ['play', 'volume', 'scale', 'timeline', 'position'],
height: 300, height: 300,
width: 400, width: 400,
showControlsOnLoad: true, showControlsOnLoad: true,
duration: 35, duration: 35,
timeline: '/speedtrans/img/timeline16p.png', timeline: timeline,
title: 'Test Video', title: 'Test Video',
enableTimeline: true, enableTimeline: true,
enableKeyboard: true, enableKeyboard: true,
@ -116,12 +141,77 @@ pandora.ui.videoPlayer = function() {
// enableTimeline: true // enableTimeline: true
}); });
return that; return that;
} };
pandora.ui.openRemoteDialog = function() {
// var $inputs = Ox.InputGroup({
// 'inputs': [
// Ox.Input({
// 'label': 'Pan.do/ra instance URL',
// 'id': 'pandoraInstance',
// 'width': 250
// }),
// Ox.Input({
// 'label': 'Pan.do/ra Video ID',
// 'id': 'pandoraID',
// 'width': 250
// })
// ],
// 'width': 250
// });
//FIXME: convert to SelectInput
var $input1 = Ox.Input({
'label': 'Pan.do/ra instance URL',
'id': 'pandoraInstance',
'labelWidth': 250,
'width': 600
}).css({'margin': '4px'});
var $input2 = Ox.Input({
'label': 'Pan.do/ra Video ID',
'id': 'pandoraID',
'labelWidth': 250,
'width': 600
}).css({'margin': '4px'});
var $content = Ox.Element().append($input1).append($input2);
var that = Ox.Dialog({
'content': $content.css({'padding': '12px'}),
'buttons': [
Ox.Button({
'group': true,
'id': 'loadRemoteVideoButton',
'title': 'Load Video'
}).bindEvent("click", function() {
var pandoraInstance = $input1.value();
var pandoraID = $input2.value();
var base_url = pandoraInstance + "/" + pandoraID;
var options = {
'name': base_url,
'url': base_url + "/480p.webm",
'type': 'remote'
};
pandora.$ui.textArea.speedtrans.load(options);
that.close();
})
],
'closeButton': true,
'title': 'Open Remote Video',
'width': 700,
'fixedSize': true
});
return that;
};
pandora.ui.helpPanel = function() { pandora.ui.helpPanel = function() {
var that = $('<div>').text("Help Panel"); var that = Ox.Element().text("Help Panel");
return that; return that;
} };
pandora.ui.textPanel = function() { pandora.ui.textPanel = function() {
var that = Ox.SplitPanel({ var that = Ox.SplitPanel({
@ -155,7 +245,7 @@ pandora.ui.textArea = function() {
var scrollTop = eDom.scrollTop; var scrollTop = eDom.scrollTop;
var val = that.value(); var val = that.value();
var pos = eDom.selectionStart; var pos = eDom.selectionStart;
var tcNpt = ms2npt($video.options("position") * 1000); var tcNpt = ms2npt(pandora.$ui.videoPlayer.options("position") * 1000);
var newVal = val.substring(0,pos) + "\n" + tcNpt + "\n" + val.substring(pos, val.length); var newVal = val.substring(0,pos) + "\n" + tcNpt + "\n" + val.substring(pos, val.length);
that.value(newVal); that.value(newVal);
that.find("textarea").focus(); //FIXME that.find("textarea").focus(); //FIXME
@ -238,19 +328,39 @@ pandora.ui.textArea = function() {
} }
} }
this.spans = spans; this.spans = spans;
var duration = $video.options("duration"); var duration = pandora.$ui.videoPlayer.options("duration");
var srt = spansToSrt(duration, spans, fmt); var srt = spansToSrt(duration, spans, fmt);
// console.log(srt); // console.log(srt);
return srt; return srt;
}, },
save: function() { save: function() {
var filename = $video.options("video");
pandora.storage(filename, that.value); console.log(that.value());
var filename = pandora.$ui.videoPlayer.options("video");
console.log(filename);
pandora.storage(filename, {'text': that.value()});
}, },
load: function(filename) { load: function(options) {
var val = pandora.storage(filename) || ''; console.log(options);
that.value(val); // if (options.type == 'local') {
// var file = options.file;
// var name = file.name;
// var url = window.URL.createObjectURL(file);
// } else if (options.type == 'remote') {
// var url = options.url;
// var name = options.name;
// }
var val = pandora.storage(options.name) || {'text': ''};
that.value(val.text);
var videoOptions = {
'url': options.url
};
pandora.$ui.videoPlayer = pandora.ui.videoPlayer(videoOptions);
//pandora.$ui.videoPlayer = videoElem;
pandora.$ui.videoPanel.replaceElement(0, pandora.$ui.videoPlayer);
//console.log(filename);
//$video.options("video", filename);
} }
}; };
that.bindEvent({ that.bindEvent({

View File

@ -12,8 +12,8 @@
function loadSpeedtrans(browserSupported) { function loadSpeedtrans(browserSupported) {
if (!browserSupported) { alert("your browser is not supported"); return; } if (!browserSupported) { alert("your browser is not supported"); return; }
window.pandora = Ox.App({url: '/api/'}).bindEvent({ window.pandora = {
'load': function(data) { 'load': function() {
// console.log(data); // console.log(data);
Ox.extend(pandora, { Ox.extend(pandora, {
@ -36,19 +36,20 @@
'height': pandora.$ui.textPanel.height() - 40 'height': pandora.$ui.textPanel.height() - 40
}); });
} }
var prefix = "/speedtrans/js/"; var prefix = "js/";
Ox.loadFile(prefix + "pandora-ui.js", function() {
initSpeedtrans(data); Ox.getFile([prefix + "pandora-ui.js"], function() {
initSpeedtrans();
}); });
} }
}); };
pandora.load();
} }
function initSpeedtrans(data) { function initSpeedtrans(data) {
pandora.$ui.appPanel = pandora.ui.appPanel().appendTo(pandora.$ui.body); pandora.$ui.appPanel = pandora.ui.appPanel().appendTo(pandora.$ui.body);
pandora.resizeWindow(); pandora.resizeWindow();
} }