diff --git a/app/angular/controller.js b/app/angular/controller.js
index f34f49b..511f635 100644
--- a/app/angular/controller.js
+++ b/app/angular/controller.js
@@ -5,8 +5,9 @@
     /* jshint validthis: true */
     var vm = this;
     vm.config = {
-      delay: 2,
+      delay: 1,
       shots: 3,
+      countdown : 3,
       flashFallbackUrl: 'vendors/webcamjs/webcam.swf',
       shutterUrl: 'shutter.mp3',
       flashNotDetectedText: 'Seu browser não atende os requisitos mínimos para utilização da camera. ' +
diff --git a/dist/ng-webcam.js b/dist/ng-webcam.js
index 91c9f35..49e02fe 100644
--- a/dist/ng-webcam.js
+++ b/dist/ng-webcam.js
@@ -40,9 +40,9 @@
     };
 
     function template(element, attrs) {
-      return ['<div class="ng-webcam no-overlay" ng-class="{\'no-overlay\' : vm.counter === 0 || vm.config.countdown === 0}">',
-        '<span ng-show="vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0" id="ng-webcam-counter">{{vm.counter}}</span>',
-        '<img ng-show="vm.webcamLive === true" id="ng-webcam-overlay" src="{{vm.config.overlay}}" />',
+      return ['<div class="ng-webcam" ng-class="{\'no-overlay\' : vm.counter === 0 || vm.config.countdown === 0}">',
+        '<span ng-show="vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0" id="counter">{{vm.counter}}</span>',
+        '<img ng-show="vm.webcamLive === true" id="ng-webcam-overlay" ng-src="{{vm.config.overlay}}" />',
         '<div id="ng-webcam-container"></div>',
         '</div>'].join('');
     }
@@ -63,7 +63,7 @@
       var images = [];
       vm.webcamLoaded = false;
       vm.webcamLive = false;
-      vm.counter = 3;
+      vm.counter = 0;
       vm.init = init;
       vm.destroy = destroy;
       /**
@@ -103,13 +103,13 @@
       function init() {
         vm.config = vm.config || {};
         if(window.localStorage) window.localStorage.setItem('visited', '1');
-        if(angular.isUndefined(vm.config.viewerWidth)) vm.config.viewerWidth = 'auto';
-        if(angular.isUndefined(vm.config.viewerHeight)) vm.config.viewerHeight = 'auto';
+        if(angular.isUndefined(vm.config.viewerWidth)) vm.config.viewerWidth = 320;
+        if(angular.isUndefined(vm.config.viewerHeight)) vm.config.viewerHeight = 240;
         if(angular.isUndefined(vm.config.outputWidth)) vm.config.outputWidth = 320;
         if(angular.isUndefined(vm.config.outputHeight)) vm.config.outputHeight = 240;
         if(angular.isUndefined(vm.config.delay)) vm.config.delay = 0;
         if(angular.isUndefined(vm.config.shots)) vm.config.shots = 1;
-        if(angular.isUndefined(vm.config.countdown)) vm.config.countdown = 0;
+	    if(angular.isUndefined(vm.config.countdown)){ vm.config.countdown = 0; } else {vm.counter = vm.config.countdown; }
         configureListeners();
         configure();
       }
@@ -126,7 +126,7 @@
           $interval.cancel(countdownTimer);
           countdownTimer = undefined;
         }
-        vm.counter = 3;
+        vm.counter = 0;
 
       }
 
@@ -203,7 +203,7 @@
       }
 
       function onWebcamCapture() {
-        if(angular.isUndefined(vm.config.countdown)) {
+        if(!vm.config.countdown) {
           var count = 0;
           snapshotTimer = $interval(function() {
             capture(count);
@@ -211,20 +211,23 @@
           }, (vm.config.delay * 1000), vm.config.shots);
         } else {
           if(countdownTimer !== undefined) return;
-          vm.counter = 3;
+          vm.counter = vm.config.countdown;
           countdownTimer = $interval(function() {
             vm.counter = vm.counter - 1;
             if(vm.counter === 0) {
               if(countdownTimer) {
                 $interval.cancel(countdownTimer);
               }
-              var count = 0;
+              
+              //snap first
+	          capture(0);
+              var count = 1;
               snapshotTimer = $interval(function() {
-                capture(count);
-                count++;
-              }, (vm.config.delay * 1000), vm.config.shots);
+	              capture(count);
+                  count++;
+              }, (vm.config.delay * 1000), vm.config.shots - 1);
             }
-          }, 1000, 3);
+          }, 1000, vm.config.countdown);
         }
       }
 
diff --git a/dist/ng-webcam.min.js b/dist/ng-webcam.min.js
index 964ceb8..6558a85 100644
--- a/dist/ng-webcam.min.js
+++ b/dist/ng-webcam.min.js
@@ -1,2 +1,2 @@
-!function(){"use strict";function n(){function n(n,e){return['<div class="ng-webcam no-overlay" ng-class="{\'no-overlay\' : vm.counter === 0 || vm.config.countdown === 0}">','<span ng-show="vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0" id="ng-webcam-counter">{{vm.counter}}</span>','<img ng-show="vm.webcamLive === true" id="ng-webcam-overlay" src="{{vm.config.overlay}}" />','<div id="ng-webcam-container"></div>',"</div>"].join("")}function e(n,e,o,i){i.init(),n.$on("$destroy",function(){i.destroy()})}function o(n,e){function o(){l.config=l.config||{},window.localStorage&&window.localStorage.setItem("visited","1"),angular.isUndefined(l.config.viewerWidth)&&(l.config.viewerWidth="auto"),angular.isUndefined(l.config.viewerHeight)&&(l.config.viewerHeight="auto"),angular.isUndefined(l.config.outputWidth)&&(l.config.outputWidth=320),angular.isUndefined(l.config.outputHeight)&&(l.config.outputHeight=240),angular.isUndefined(l.config.delay)&&(l.config.delay=0),angular.isUndefined(l.config.shots)&&(l.config.shots=1),angular.isUndefined(l.config.countdown)&&(l.config.countdown=0),c(),t()}function i(){l.webcamLive&&Webcam.reset(),l.webcamLive=!1,l.webcamLoaded=!1,angular.isDefined(s)&&(e.cancel(s),s=void 0),angular.isDefined(d)&&(e.cancel(d),d=void 0),l.counter=3}function t(){angular.isDefined(l.config.shutterUrl)&&(u=new Audio,u.autoplay=!1,navigator.userAgent.match(/Firefox/)?u.src=l.config.shutterUrl.split(".")[0]+".ogg":u.src=l.config.shutterUrl),Webcam.set({width:l.config.viewerWidth,height:l.config.viewerHeight,dest_width:l.config.outputWidth,dest_height:l.config.outputHeight,force_flash:!1,image_format:"jpeg",jpeg_quality:100,flip_horiz:!0}),angular.isDefined(l.config.flashNotDetectedText)&&Webcam.set("flashNotDetectedText",l.config.flashNotDetectedText),angular.isDefined(l.config.flashFallbackUrl)&&Webcam.setSWFLocation(l.config.flashFallbackUrl),Webcam.attach("#ng-webcam-container")}function c(){Webcam.on("load",function(){n.$apply(function(){l.webcamLoaded=!0,angular.isDefined(l.onLoad)&&l.onLoad()})}),Webcam.on("live",function(){n.$apply(function(){l.webcamLive=!0,angular.isDefined(l.onLive)&&l.onLive()})}),Webcam.on("error",function(n){angular.isDefined(l.onError)&&l.onError({err:n})})}function a(n){u&&u.play(),n===l.config.shots-1&&e.cancel(s),Webcam.snap(function(e){if(m[n]=e,n<l.config.shots-1&&angular.isDefined(l.onCaptureProgress)){var o=Math.round(100*(n+1)/l.config.shots);l.onCaptureProgress({src:e,progress:o})}if(n===l.config.shots-1&&angular.isDefined(l.onCaptureComplete))return l.onCaptureComplete({src:m})})}function r(){if(angular.isUndefined(l.config.countdown)){var n=0;s=e(function(){a(n),n++},1e3*l.config.delay,l.config.shots)}else{if(void 0!==d)return;l.counter=3,d=e(function(){if(l.counter=l.counter-1,0===l.counter){d&&e.cancel(d);var n=0;s=e(function(){a(n),n++},1e3*l.config.delay,l.config.shots)}},1e3,3)}}function f(){Webcam.attach("#ng-webcam-container")}function g(){i()}var u,s,d,l=this,m=[];l.webcamLoaded=!1,l.webcamLive=!1,l.counter=3,l.init=o,l.destroy=i,n.$on("ngWebcam_capture",r),n.$on("ngWebcam_on",f),n.$on("ngWebcam_off",g)}var i={restrict:"E",template:n,link:e,bindToController:!0,controller:o,controllerAs:"vm",scope:{config:"=",onCaptureComplete:"&",onError:"&",onLoad:"&",onCaptureProgress:"&",onLive:"&"}};return o.$inject=["$scope","$interval"],i}angular.module("ng-webcam",[]).directive("ngWebcam",n),n.$inject=[]}();
-//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ng-webcam.js"],"names":["ngWebcam","template","element","attrs","join","link","scope","ctrl","init","$on","destroy","ngWebcamController","$scope","$interval","vm","config","window","localStorage","setItem","angular","isUndefined","viewerWidth","viewerHeight","outputWidth","outputHeight","delay","shots","countdown","configureListeners","configure","webcamLive","Webcam","reset","webcamLoaded","isDefined","snapshotTimer","cancel","undefined","countdownTimer","counter","shutterUrl","sound","Audio","autoplay","navigator","userAgent","match","src","split","set","width","height","dest_width","dest_height","force_flash","image_format","jpeg_quality","flip_horiz","flashNotDetectedText","flashFallbackUrl","setSWFLocation","attach","on","$apply","onLoad","onLive","err","onError","capture","index","play","snap","data_uri","images","onCaptureProgress","progress","Math","round","onCaptureComplete","onWebcamCapture","count","onWebcamOn","onWebcamOff","this","directive","restrict","bindToController","controller","controllerAs","$inject","module"],"mappings":"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","file":"ng-webcam.min.js","sourcesContent":["(function() {\r\n  'use strict';\r\n  angular.module('ng-webcam', []).directive('ngWebcam', ngWebcam);\r\n  ngWebcam.$inject = [];\r\n  /**\r\n   *  @ngdoc Directive\r\n   *  @name ng-webcam\r\n   *  @description\r\n   *\r\n   *  Directive for capturing images from your computer's camera, and delivery then to you as data uri\r\n   *\r\n   *  @usage\r\n   *  ```html\r\n   *  <ng-webcam\r\n   *    config=\"vm.config\"\r\n   *    on-error=\"vm.onError(err)\"\r\n   *    on-load=\"vm.onLoad()\"\r\n   *    on-live=\"vm.onLive()\"\r\n   *    on-capture-progress=\"vm.onCaptureProgress(src, progress)\"\r\n   *    on-capture-complete=\"vm.onCaptureComplete(src)\">\r\n   *  </ng-webcam>\r\n   *  ```\r\n   */\r\n  function ngWebcam() {\r\n    var directive = {\r\n      restrict: 'E',\r\n      template: template,\r\n      link: link,\r\n      bindToController: true,\r\n      controller: ngWebcamController,\r\n      controllerAs: 'vm',\r\n      scope: {\r\n        config: '=',\r\n        onCaptureComplete: '&',\r\n        onError: '&',\r\n        onLoad: '&',\r\n        onCaptureProgress: '&',\r\n        onLive: '&'\r\n      }\r\n    };\r\n\r\n    function template(element, attrs) {\r\n      return ['<div class=\"ng-webcam no-overlay\" ng-class=\"{\\'no-overlay\\' : vm.counter === 0 || vm.config.countdown === 0}\">',\r\n        '<span ng-show=\"vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0\" id=\"ng-webcam-counter\">{{vm.counter}}</span>',\r\n        '<img ng-show=\"vm.webcamLive === true\" id=\"ng-webcam-overlay\" src=\"{{vm.config.overlay}}\" />',\r\n        '<div id=\"ng-webcam-container\"></div>',\r\n        '</div>'].join('');\r\n    }\r\n\r\n    function link(scope, element, attrs, ctrl) {\r\n      ctrl.init();\r\n      scope.$on('$destroy', function() {\r\n        ctrl.destroy();\r\n      });\r\n    }\r\n\r\n    ngWebcamController.$inject = ['$scope', '$interval'];\r\n\r\n    function ngWebcamController($scope, $interval) {\r\n      /*jshint validthis: true */\r\n      var vm = this;\r\n      var sound, snapshotTimer, countdownTimer;\r\n      var images = [];\r\n      vm.webcamLoaded = false;\r\n      vm.webcamLive = false;\r\n      vm.counter = 3;\r\n      vm.init = init;\r\n      vm.destroy = destroy;\r\n      /**\r\n       *  @ngdoc listener\r\n       *  @name ngWebcam_capture\r\n       *  @description\r\n       *\r\n       *  Listener for capture user action\r\n       *\r\n       *  @usage\r\n       *  `$scope.$broadcast('ngWebcam_capture');`\r\n       */\r\n      $scope.$on('ngWebcam_capture', onWebcamCapture);\r\n      /**\r\n       *  @ngdoc listener\r\n       *  @name ngWebcam_on\r\n       *  @description\r\n       *\r\n       *  Listener for camera on user action\r\n       *\r\n       *  @usage\r\n       *  `$scope.$broadcast('ngWebcam_on');`\r\n       */\r\n      $scope.$on('ngWebcam_on', onWebcamOn);\r\n      /**\r\n       *  @ngdoc listener\r\n       *  @name ngWebcam_off\r\n       *  @description\r\n       *\r\n       *  Listener for camera off user action\r\n       *\r\n       *  @usage\r\n       *  `$scope.$broadcast('ngWebcam_off');`\r\n       */\r\n      $scope.$on('ngWebcam_off', onWebcamOff);\r\n\r\n      function init() {\r\n        vm.config = vm.config || {};\r\n        if(window.localStorage) window.localStorage.setItem('visited', '1');\r\n        if(angular.isUndefined(vm.config.viewerWidth)) vm.config.viewerWidth = 'auto';\r\n        if(angular.isUndefined(vm.config.viewerHeight)) vm.config.viewerHeight = 'auto';\r\n        if(angular.isUndefined(vm.config.outputWidth)) vm.config.outputWidth = 320;\r\n        if(angular.isUndefined(vm.config.outputHeight)) vm.config.outputHeight = 240;\r\n        if(angular.isUndefined(vm.config.delay)) vm.config.delay = 0;\r\n        if(angular.isUndefined(vm.config.shots)) vm.config.shots = 1;\r\n        if(angular.isUndefined(vm.config.countdown)) vm.config.countdown = 0;\r\n        configureListeners();\r\n        configure();\r\n      }\r\n\r\n      function destroy() {\r\n        if(vm.webcamLive) Webcam.reset();\r\n        vm.webcamLive = false;\r\n        vm.webcamLoaded = false;\r\n        if(angular.isDefined(snapshotTimer)) {\r\n          $interval.cancel(snapshotTimer);\r\n          snapshotTimer = undefined;\r\n        }\r\n        if(angular.isDefined(countdownTimer)) {\r\n          $interval.cancel(countdownTimer);\r\n          countdownTimer = undefined;\r\n        }\r\n        vm.counter = 3;\r\n\r\n      }\r\n\r\n      function configure() {\r\n        if(angular.isDefined(vm.config.shutterUrl)) {\r\n          sound = new Audio();\r\n          sound.autoplay = false;\r\n          if(navigator.userAgent.match(/Firefox/)) {\r\n            sound.src = vm.config.shutterUrl.split('.')[0] + '.ogg';\r\n          } else {\r\n            sound.src = vm.config.shutterUrl;\r\n          }\r\n        }\r\n        Webcam.set({\r\n          width: vm.config.viewerWidth,\r\n          height: vm.config.viewerHeight,\r\n          dest_width: vm.config.outputWidth,\r\n          dest_height: vm.config.outputHeight,\r\n          force_flash: false,\r\n          image_format: 'jpeg',\r\n          jpeg_quality: 100,\r\n          flip_horiz: true\r\n        });\r\n        if(angular.isDefined(vm.config.flashNotDetectedText)) {\r\n          Webcam.set('flashNotDetectedText', vm.config.flashNotDetectedText);\r\n        }\r\n        if(angular.isDefined(vm.config.flashFallbackUrl)) {\r\n          Webcam.setSWFLocation(vm.config.flashFallbackUrl);\r\n        }\r\n        Webcam.attach('#ng-webcam-container');\r\n      }\r\n\r\n      function configureListeners() {\r\n        Webcam.on('load', function() {\r\n          $scope.$apply(function() {\r\n            vm.webcamLoaded = true;\r\n            if(angular.isDefined(vm.onLoad)) {\r\n              vm.onLoad();\r\n            }\r\n          });\r\n        });\r\n        Webcam.on('live', function() {\r\n          $scope.$apply(function() {\r\n            vm.webcamLive = true;\r\n            if(angular.isDefined(vm.onLive)) {\r\n              vm.onLive();\r\n            }\r\n          });\r\n        });\r\n        Webcam.on('error', function(err) {\r\n          if(angular.isDefined(vm.onError)) {\r\n            vm.onError({err:err});\r\n          }\r\n        });\r\n      }\r\n\r\n      function capture(index) {\r\n        if(sound) {\r\n          sound.play();\r\n        }\r\n        if(index === (vm.config.shots-1)) {\r\n          $interval.cancel(snapshotTimer);\r\n        }\r\n        Webcam.snap(function(data_uri) {\r\n          images[index] = data_uri;\r\n          if(index < (vm.config.shots-1) && angular.isDefined(vm.onCaptureProgress)) {\r\n            var progress = Math.round(((index+1) * 100) / vm.config.shots);\r\n            vm.onCaptureProgress({src: data_uri,progress: progress});\r\n          }\r\n          if(index === (vm.config.shots-1) && angular.isDefined(vm.onCaptureComplete)) {\r\n            return vm.onCaptureComplete({src: images});\r\n          }\r\n        });\r\n      }\r\n\r\n      function onWebcamCapture() {\r\n        if(angular.isUndefined(vm.config.countdown)) {\r\n          var count = 0;\r\n          snapshotTimer = $interval(function() {\r\n            capture(count);\r\n            count++;\r\n          }, (vm.config.delay * 1000), vm.config.shots);\r\n        } else {\r\n          if(countdownTimer !== undefined) return;\r\n          vm.counter = 3;\r\n          countdownTimer = $interval(function() {\r\n            vm.counter = vm.counter - 1;\r\n            if(vm.counter === 0) {\r\n              if(countdownTimer) {\r\n                $interval.cancel(countdownTimer);\r\n              }\r\n              var count = 0;\r\n              snapshotTimer = $interval(function() {\r\n                capture(count);\r\n                count++;\r\n              }, (vm.config.delay * 1000), vm.config.shots);\r\n            }\r\n          }, 1000, 3);\r\n        }\r\n      }\r\n\r\n      function onWebcamOn() {\r\n        Webcam.attach('#ng-webcam-container');\r\n      }\r\n\r\n      function onWebcamOff() {\r\n        destroy();\r\n      }\r\n    }\r\n    return directive;\r\n  }\r\n})();"],"sourceRoot":"/source/"}
+!function(){"use strict";function n(){function n(n,e){return['<div class="ng-webcam" ng-class="{\'no-overlay\' : vm.counter === 0 || vm.config.countdown === 0}">','<span ng-show="vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0" id="counter">{{vm.counter}}</span>','<img ng-show="vm.webcamLive === true" id="ng-webcam-overlay" ng-src="{{vm.config.overlay}}" />','<div id="ng-webcam-container"></div>',"</div>"].join("")}function e(n,e,o,i){i.init(),n.$on("$destroy",function(){i.destroy()})}function o(n,e){function o(){l.config=l.config||{},window.localStorage&&window.localStorage.setItem("visited","1"),angular.isUndefined(l.config.viewerWidth)&&(l.config.viewerWidth=320),angular.isUndefined(l.config.viewerHeight)&&(l.config.viewerHeight=240),angular.isUndefined(l.config.outputWidth)&&(l.config.outputWidth=320),angular.isUndefined(l.config.outputHeight)&&(l.config.outputHeight=240),angular.isUndefined(l.config.delay)&&(l.config.delay=0),angular.isUndefined(l.config.shots)&&(l.config.shots=1),angular.isUndefined(l.config.countdown)?l.config.countdown=0:l.counter=l.config.countdown,c(),t()}function i(){l.webcamLive&&Webcam.reset(),l.webcamLive=!1,l.webcamLoaded=!1,angular.isDefined(s)&&(e.cancel(s),s=void 0),angular.isDefined(d)&&(e.cancel(d),d=void 0),l.counter=0}function t(){angular.isDefined(l.config.shutterUrl)&&(u=new Audio,u.autoplay=!1,navigator.userAgent.match(/Firefox/)?u.src=l.config.shutterUrl.split(".")[0]+".ogg":u.src=l.config.shutterUrl),Webcam.set({width:l.config.viewerWidth,height:l.config.viewerHeight,dest_width:l.config.outputWidth,dest_height:l.config.outputHeight,force_flash:!1,image_format:"jpeg",jpeg_quality:100,flip_horiz:!0}),angular.isDefined(l.config.flashNotDetectedText)&&Webcam.set("flashNotDetectedText",l.config.flashNotDetectedText),angular.isDefined(l.config.flashFallbackUrl)&&Webcam.setSWFLocation(l.config.flashFallbackUrl),Webcam.attach("#ng-webcam-container")}function c(){Webcam.on("load",function(){n.$apply(function(){l.webcamLoaded=!0,angular.isDefined(l.onLoad)&&l.onLoad()})}),Webcam.on("live",function(){n.$apply(function(){l.webcamLive=!0,angular.isDefined(l.onLive)&&l.onLive()})}),Webcam.on("error",function(n){angular.isDefined(l.onError)&&l.onError({err:n})})}function a(n){u&&u.play(),n===l.config.shots-1&&e.cancel(s),Webcam.snap(function(e){if(m[n]=e,n<l.config.shots-1&&angular.isDefined(l.onCaptureProgress)){var o=Math.round(100*(n+1)/l.config.shots);l.onCaptureProgress({src:e,progress:o})}if(n===l.config.shots-1&&angular.isDefined(l.onCaptureComplete))return l.onCaptureComplete({src:m})})}function r(){if(l.config.countdown){if(void 0!==d)return;l.counter=l.config.countdown,d=e(function(){if(l.counter=l.counter-1,0===l.counter){d&&e.cancel(d),a(0);var n=1;s=e(function(){a(n),n++},1e3*l.config.delay,l.config.shots-1)}},1e3,l.config.countdown)}else{var n=0;s=e(function(){a(n),n++},1e3*l.config.delay,l.config.shots)}}function f(){Webcam.attach("#ng-webcam-container")}function g(){i()}var u,s,d,l=this,m=[];l.webcamLoaded=!1,l.webcamLive=!1,l.counter=0,l.init=o,l.destroy=i,n.$on("ngWebcam_capture",r),n.$on("ngWebcam_on",f),n.$on("ngWebcam_off",g)}var i={restrict:"E",template:n,link:e,bindToController:!0,controller:o,controllerAs:"vm",scope:{config:"=",onCaptureComplete:"&",onError:"&",onLoad:"&",onCaptureProgress:"&",onLive:"&"}};return o.$inject=["$scope","$interval"],i}angular.module("ng-webcam",[]).directive("ngWebcam",n),n.$inject=[]}();
+//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["ng-webcam.js"],"names":["ngWebcam","template","element","attrs","join","link","scope","ctrl","init","$on","destroy","ngWebcamController","$scope","$interval","vm","config","window","localStorage","setItem","angular","isUndefined","viewerWidth","viewerHeight","outputWidth","outputHeight","delay","shots","countdown","counter","configureListeners","configure","webcamLive","Webcam","reset","webcamLoaded","isDefined","snapshotTimer","cancel","undefined","countdownTimer","shutterUrl","sound","Audio","autoplay","navigator","userAgent","match","src","split","set","width","height","dest_width","dest_height","force_flash","image_format","jpeg_quality","flip_horiz","flashNotDetectedText","flashFallbackUrl","setSWFLocation","attach","on","$apply","onLoad","onLive","err","onError","capture","index","play","snap","data_uri","images","onCaptureProgress","progress","Math","round","onCaptureComplete","onWebcamCapture","count","onWebcamOn","onWebcamOff","this","directive","restrict","bindToController","controller","controllerAs","$inject","module"],"mappings":"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","file":"ng-webcam.min.js","sourcesContent":["(function() {\n  'use strict';\n  angular.module('ng-webcam', []).directive('ngWebcam', ngWebcam);\n  ngWebcam.$inject = [];\n  /**\n   *  @ngdoc Directive\n   *  @name ng-webcam\n   *  @description\n   *\n   *  Directive for capturing images from your computer's camera, and delivery then to you as data uri\n   *\n   *  @usage\n   *  ```html\n   *  <ng-webcam\n   *    config=\"vm.config\"\n   *    on-error=\"vm.onError(err)\"\n   *    on-load=\"vm.onLoad()\"\n   *    on-live=\"vm.onLive()\"\n   *    on-capture-progress=\"vm.onCaptureProgress(src, progress)\"\n   *    on-capture-complete=\"vm.onCaptureComplete(src)\">\n   *  </ng-webcam>\n   *  ```\n   */\n  function ngWebcam() {\n    var directive = {\n      restrict: 'E',\n      template: template,\n      link: link,\n      bindToController: true,\n      controller: ngWebcamController,\n      controllerAs: 'vm',\n      scope: {\n        config: '=',\n        onCaptureComplete: '&',\n        onError: '&',\n        onLoad: '&',\n        onCaptureProgress: '&',\n        onLive: '&'\n      }\n    };\n\n    function template(element, attrs) {\n      return ['<div class=\"ng-webcam\" ng-class=\"{\\'no-overlay\\' : vm.counter === 0 || vm.config.countdown === 0}\">',\n        '<span ng-show=\"vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0\" id=\"counter\">{{vm.counter}}</span>',\n        '<img ng-show=\"vm.webcamLive === true\" id=\"ng-webcam-overlay\" ng-src=\"{{vm.config.overlay}}\" />',\n        '<div id=\"ng-webcam-container\"></div>',\n        '</div>'].join('');\n    }\n\n    function link(scope, element, attrs, ctrl) {\n      ctrl.init();\n      scope.$on('$destroy', function() {\n        ctrl.destroy();\n      });\n    }\n\n    ngWebcamController.$inject = ['$scope', '$interval'];\n\n    function ngWebcamController($scope, $interval) {\n      /*jshint validthis: true */\n      var vm = this;\n      var sound, snapshotTimer, countdownTimer;\n      var images = [];\n      vm.webcamLoaded = false;\n      vm.webcamLive = false;\n      vm.counter = 0;\n      vm.init = init;\n      vm.destroy = destroy;\n      /**\n       *  @ngdoc listener\n       *  @name ngWebcam_capture\n       *  @description\n       *\n       *  Listener for capture user action\n       *\n       *  @usage\n       *  `$scope.$broadcast('ngWebcam_capture');`\n       */\n      $scope.$on('ngWebcam_capture', onWebcamCapture);\n      /**\n       *  @ngdoc listener\n       *  @name ngWebcam_on\n       *  @description\n       *\n       *  Listener for camera on user action\n       *\n       *  @usage\n       *  `$scope.$broadcast('ngWebcam_on');`\n       */\n      $scope.$on('ngWebcam_on', onWebcamOn);\n      /**\n       *  @ngdoc listener\n       *  @name ngWebcam_off\n       *  @description\n       *\n       *  Listener for camera off user action\n       *\n       *  @usage\n       *  `$scope.$broadcast('ngWebcam_off');`\n       */\n      $scope.$on('ngWebcam_off', onWebcamOff);\n\n      function init() {\n        vm.config = vm.config || {};\n        if(window.localStorage) window.localStorage.setItem('visited', '1');\n        if(angular.isUndefined(vm.config.viewerWidth)) vm.config.viewerWidth = 320;\n        if(angular.isUndefined(vm.config.viewerHeight)) vm.config.viewerHeight = 240;\n        if(angular.isUndefined(vm.config.outputWidth)) vm.config.outputWidth = 320;\n        if(angular.isUndefined(vm.config.outputHeight)) vm.config.outputHeight = 240;\n        if(angular.isUndefined(vm.config.delay)) vm.config.delay = 0;\n        if(angular.isUndefined(vm.config.shots)) vm.config.shots = 1;\n\t    if(angular.isUndefined(vm.config.countdown)){ vm.config.countdown = 0; } else {vm.counter = vm.config.countdown; }\n        configureListeners();\n        configure();\n      }\n\n      function destroy() {\n        if(vm.webcamLive) Webcam.reset();\n        vm.webcamLive = false;\n        vm.webcamLoaded = false;\n        if(angular.isDefined(snapshotTimer)) {\n          $interval.cancel(snapshotTimer);\n          snapshotTimer = undefined;\n        }\n        if(angular.isDefined(countdownTimer)) {\n          $interval.cancel(countdownTimer);\n          countdownTimer = undefined;\n        }\n        vm.counter = 0;\n\n      }\n\n      function configure() {\n        if(angular.isDefined(vm.config.shutterUrl)) {\n          sound = new Audio();\n          sound.autoplay = false;\n          if(navigator.userAgent.match(/Firefox/)) {\n            sound.src = vm.config.shutterUrl.split('.')[0] + '.ogg';\n          } else {\n            sound.src = vm.config.shutterUrl;\n          }\n        }\n        Webcam.set({\n          width: vm.config.viewerWidth,\n          height: vm.config.viewerHeight,\n          dest_width: vm.config.outputWidth,\n          dest_height: vm.config.outputHeight,\n          force_flash: false,\n          image_format: 'jpeg',\n          jpeg_quality: 100,\n          flip_horiz: true\n        });\n        if(angular.isDefined(vm.config.flashNotDetectedText)) {\n          Webcam.set('flashNotDetectedText', vm.config.flashNotDetectedText);\n        }\n        if(angular.isDefined(vm.config.flashFallbackUrl)) {\n          Webcam.setSWFLocation(vm.config.flashFallbackUrl);\n        }\n        Webcam.attach('#ng-webcam-container');\n      }\n\n      function configureListeners() {\n        Webcam.on('load', function() {\n          $scope.$apply(function() {\n            vm.webcamLoaded = true;\n            if(angular.isDefined(vm.onLoad)) {\n              vm.onLoad();\n            }\n          });\n        });\n        Webcam.on('live', function() {\n          $scope.$apply(function() {\n            vm.webcamLive = true;\n            if(angular.isDefined(vm.onLive)) {\n              vm.onLive();\n            }\n          });\n        });\n        Webcam.on('error', function(err) {\n          if(angular.isDefined(vm.onError)) {\n            vm.onError({err:err});\n          }\n        });\n      }\n\n      function capture(index) {\n        if(sound) {\n          sound.play();\n        }\n        if(index === (vm.config.shots-1)) {\n          $interval.cancel(snapshotTimer);\n        }\n        Webcam.snap(function(data_uri) {\n          images[index] = data_uri;\n          if(index < (vm.config.shots-1) && angular.isDefined(vm.onCaptureProgress)) {\n            var progress = Math.round(((index+1) * 100) / vm.config.shots);\n            vm.onCaptureProgress({src: data_uri,progress: progress});\n          }\n          if(index === (vm.config.shots-1) && angular.isDefined(vm.onCaptureComplete)) {\n            return vm.onCaptureComplete({src: images});\n          }\n        });\n      }\n\n      function onWebcamCapture() {\n        if(!vm.config.countdown) {\n          var count = 0;\n          snapshotTimer = $interval(function() {\n            capture(count);\n            count++;\n          }, (vm.config.delay * 1000), vm.config.shots);\n        } else {\n          if(countdownTimer !== undefined) return;\n          vm.counter = vm.config.countdown;\n          countdownTimer = $interval(function() {\n            vm.counter = vm.counter - 1;\n            if(vm.counter === 0) {\n              if(countdownTimer) {\n                $interval.cancel(countdownTimer);\n              }\n              \n              //snap first\n\t          capture(0);\n              var count = 1;\n              snapshotTimer = $interval(function() {\n\t              capture(count);\n                  count++;\n              }, (vm.config.delay * 1000), vm.config.shots - 1);\n            }\n          }, 1000, vm.config.countdown);\n        }\n      }\n\n      function onWebcamOn() {\n        Webcam.attach('#ng-webcam-container');\n      }\n\n      function onWebcamOff() {\n        destroy();\n      }\n    }\n    return directive;\n  }\n})();"]}
diff --git a/src/ng-webcam.js b/src/ng-webcam.js
index 91c9f35..49e02fe 100644
--- a/src/ng-webcam.js
+++ b/src/ng-webcam.js
@@ -40,9 +40,9 @@
     };
 
     function template(element, attrs) {
-      return ['<div class="ng-webcam no-overlay" ng-class="{\'no-overlay\' : vm.counter === 0 || vm.config.countdown === 0}">',
-        '<span ng-show="vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0" id="ng-webcam-counter">{{vm.counter}}</span>',
-        '<img ng-show="vm.webcamLive === true" id="ng-webcam-overlay" src="{{vm.config.overlay}}" />',
+      return ['<div class="ng-webcam" ng-class="{\'no-overlay\' : vm.counter === 0 || vm.config.countdown === 0}">',
+        '<span ng-show="vm.webcamLive === true && vm.config.countdown > 0 && vm.counter > 0" id="counter">{{vm.counter}}</span>',
+        '<img ng-show="vm.webcamLive === true" id="ng-webcam-overlay" ng-src="{{vm.config.overlay}}" />',
         '<div id="ng-webcam-container"></div>',
         '</div>'].join('');
     }
@@ -63,7 +63,7 @@
       var images = [];
       vm.webcamLoaded = false;
       vm.webcamLive = false;
-      vm.counter = 3;
+      vm.counter = 0;
       vm.init = init;
       vm.destroy = destroy;
       /**
@@ -103,13 +103,13 @@
       function init() {
         vm.config = vm.config || {};
         if(window.localStorage) window.localStorage.setItem('visited', '1');
-        if(angular.isUndefined(vm.config.viewerWidth)) vm.config.viewerWidth = 'auto';
-        if(angular.isUndefined(vm.config.viewerHeight)) vm.config.viewerHeight = 'auto';
+        if(angular.isUndefined(vm.config.viewerWidth)) vm.config.viewerWidth = 320;
+        if(angular.isUndefined(vm.config.viewerHeight)) vm.config.viewerHeight = 240;
         if(angular.isUndefined(vm.config.outputWidth)) vm.config.outputWidth = 320;
         if(angular.isUndefined(vm.config.outputHeight)) vm.config.outputHeight = 240;
         if(angular.isUndefined(vm.config.delay)) vm.config.delay = 0;
         if(angular.isUndefined(vm.config.shots)) vm.config.shots = 1;
-        if(angular.isUndefined(vm.config.countdown)) vm.config.countdown = 0;
+	    if(angular.isUndefined(vm.config.countdown)){ vm.config.countdown = 0; } else {vm.counter = vm.config.countdown; }
         configureListeners();
         configure();
       }
@@ -126,7 +126,7 @@
           $interval.cancel(countdownTimer);
           countdownTimer = undefined;
         }
-        vm.counter = 3;
+        vm.counter = 0;
 
       }
 
@@ -203,7 +203,7 @@
       }
 
       function onWebcamCapture() {
-        if(angular.isUndefined(vm.config.countdown)) {
+        if(!vm.config.countdown) {
           var count = 0;
           snapshotTimer = $interval(function() {
             capture(count);
@@ -211,20 +211,23 @@
           }, (vm.config.delay * 1000), vm.config.shots);
         } else {
           if(countdownTimer !== undefined) return;
-          vm.counter = 3;
+          vm.counter = vm.config.countdown;
           countdownTimer = $interval(function() {
             vm.counter = vm.counter - 1;
             if(vm.counter === 0) {
               if(countdownTimer) {
                 $interval.cancel(countdownTimer);
               }
-              var count = 0;
+              
+              //snap first
+	          capture(0);
+              var count = 1;
               snapshotTimer = $interval(function() {
-                capture(count);
-                count++;
-              }, (vm.config.delay * 1000), vm.config.shots);
+	              capture(count);
+                  count++;
+              }, (vm.config.delay * 1000), vm.config.shots - 1);
             }
-          }, 1000, 3);
+          }, 1000, vm.config.countdown);
         }
       }