Added animationDone event to Metamaps.JIT.js, tried to hook into it from phantomjs, failed
still have debugging stuff in this commit. it's currently rendering the image so I can check output It doesn't seem to be responding to the event, and it's stopped hiding the UI elements around the edge
This commit is contained in:
parent
c6c05085ad
commit
68e1a8042a
3 changed files with 26 additions and 24 deletions
|
@ -3,6 +3,7 @@ Metamaps.JIT = {
|
|||
mouseMove: 'Metamaps:JIT:events:mouseMove',
|
||||
pan: 'Metamaps:JIT:events:pan',
|
||||
zoom: 'Metamaps:JIT:events:zoom'
|
||||
animationDone: 'Metamaps:JIT:events:animationDone',
|
||||
},
|
||||
vizData: [], // contains the visualization-compatible graph
|
||||
/**
|
||||
|
@ -211,6 +212,7 @@ Metamaps.JIT = {
|
|||
duration: 800,
|
||||
onComplete: function () {
|
||||
Metamaps.Visualize.mGraph.busy = false;
|
||||
$(document).trigger(Metamaps.JIT.events.animationDone, [event]);
|
||||
}
|
||||
},
|
||||
animateFDLayout: {
|
||||
|
@ -1675,4 +1677,4 @@ Metamaps.JIT = {
|
|||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
};
|
||||
|
|
|
@ -3,8 +3,15 @@ class GrabMapScreenshotWorker
|
|||
include Sidekiq::Worker
|
||||
|
||||
def perform(map_id)
|
||||
imgBase64 = ''
|
||||
Phantomjs.run('./script/phantomjs-save-screenshot.js', map_id.to_s) { |line|
|
||||
imgBase64 << line
|
||||
puts line
|
||||
}
|
||||
|
||||
#this doesn't work yet
|
||||
#map = Map.find(map_id)
|
||||
#map.add_attachment(imgBase64)
|
||||
#map.save!
|
||||
end
|
||||
end
|
||||
|
|
|
@ -9,16 +9,8 @@ if (args.length <= 1) {
|
|||
//configurable variables - CHANGE ME
|
||||
var mapID = args[1];
|
||||
var url = 'http://localhost:3000/maps/' + mapID;
|
||||
var width = 400;
|
||||
var height = 400;
|
||||
var thumbsDirRelative = 'app/assets/images/map_thumbnails';
|
||||
|
||||
//set up writing to filesystem
|
||||
var fs = require('fs');
|
||||
var thumbsDirectory = fs.workingDirectory + '/' + thumbsDirRelative;
|
||||
if (!fs.isDirectory(thumbsDirectory)) {
|
||||
fs.makeDirectory(thumbsDirectory);
|
||||
}//if
|
||||
var width = 188;
|
||||
var height = 126;
|
||||
|
||||
//set up page and the area we'll render as a PNG
|
||||
var page = require('webpage').create();
|
||||
|
@ -26,29 +18,30 @@ page.viewportSize = {
|
|||
width: width,
|
||||
height: height
|
||||
};
|
||||
page.clipRect = {
|
||||
top: 32,
|
||||
left: 32,
|
||||
width: width - 32,
|
||||
height: height - 32
|
||||
};
|
||||
|
||||
page.open(url, function (status) {
|
||||
if (status === 'success') {
|
||||
//since this isn't evaluateAsync, it should also ensure the asynchronous
|
||||
//js stuff is loaded too, hopefully?
|
||||
page.evaluate(function() {
|
||||
$(document).ready(function(){
|
||||
$('.upperLeftUI, .upperRightUI, .mapControls, .infoAndHelp, #barometer_tab, .footer').hide();
|
||||
});//document.ready
|
||||
$(document).on(Metamaps.JIT.events.animationDone, function(){
|
||||
$('.upperLeftUI, .upperRightUI, .mapControls, .infoAndHelp, #barometer_tab').hide();
|
||||
Metamaps.Famous.logo.hide()
|
||||
Metamaps.JIT.zoomExtents();
|
||||
console.log('got here');
|
||||
});//document.on animationDone
|
||||
});//page.evaluate
|
||||
|
||||
//render page into map_thumbnails directory
|
||||
var filename = thumbsDirectory + '/map' + mapID + '.png';
|
||||
page.render(filename, 'PNG');
|
||||
//pass to ruby
|
||||
//console.log(page.renderBase64('PNG'));
|
||||
|
||||
//render to the metamaps_gen002 directory for debug
|
||||
page.render('map1.png', 'PNG');
|
||||
|
||||
} else {
|
||||
//failed to load
|
||||
}//if
|
||||
|
||||
phantom.exit();
|
||||
setTimeout(phantom.exit,5000);
|
||||
//phantom.exit();
|
||||
});
|
||||
|
|
Loading…
Reference in a new issue