plask_viewer.js 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. var plask = require('plask');
  2. var fs = require('fs');
  3. var omggif = require('./omggif');
  4. if (process.argv.length < 3) throw "Usage: <filename.gif>";
  5. var buf = fs.readFileSync(process.argv[2]);
  6. var gr = new omggif.GifReader(buf);
  7. var pixels = plask.SkCanvas.create(gr.width, gr.height);
  8. plask.simpleWindow({
  9. settings: {
  10. width: 800,
  11. height: 600
  12. },
  13. init: function() {
  14. var canvas = this.canvas, paint = this.paint;
  15. canvas.clear(230, 230, 230, 255); // Draw the background, just once.
  16. },
  17. draw: function() {
  18. var canvas = this.canvas, paint = this.paint;
  19. var frame_num = this.framenum % gr.numFrames();
  20. var frame_info = gr.frameInfo(frame_num);
  21. if (frame_num === 0 || frame_info.disposal === 2 /* restore to bg */)
  22. pixels.clear(0, 0, 0, 255);
  23. var start = Date.now();
  24. gr.decodeAndBlitFrameBGRA(frame_num, pixels.pixels || pixels);
  25. console.log('Decoded and blit frame in: ' + (Date.now() - start) + 'ms');
  26. canvas.drawCanvas(paint, pixels, 0, 0, gr.width, gr.height);
  27. var this_ = this;
  28. setTimeout(function() { this_.redraw(); }, frame_info.delay * 10);
  29. }
  30. });