2

私はAngularが初めてで、angular-hammer.jsディレクティブを使用してタップのXY座標を取得しようとしています. ディレクティブの設定方法は次のとおりです。

var hmTouchevents = angular.module('hmTouchevents', []),
hmGestures = ['hmHold:hold',
              'hmTap:tap',
              'hmDoubletap:doubletap',
              'hmDrag:drag',
              'hmDragup:dragup',
              'hmDragdown:dragdown',
              'hmDragleft:dragleft',
              'hmDragright:dragright',
              'hmSwipe:swipe',
              'hmSwipeup:swipeup',
              'hmSwipedown:swipedown',
              'hmSwipeleft:swipeleft',
              'hmSwiperight:swiperight',
              'hmTransform:transform',
              'hmRotate:rotate',
              'hmPinch:pinch',
              'hmPinchin:pinchin',
              'hmPinchout:pinchout',
              'hmTouch:touch',
              'hmRelease:release'];

angular.forEach(hmGestures, function(name){
  var directive = name.split(':'),
  directiveName = directive[0],
  eventName = directive[1];
  hmTouchevents.directive(directiveName, ["$parse", function($parse) {
    return {
      scope: true,
      link: function(scope, element, attr) {
        var fn, opts;
        fn = $parse(attr[directiveName]);
        opts = $parse(attr["hmOptions"])(scope, {});
        scope.hammer = scope.hammer || Hammer(element[0], opts);
        return scope.hammer.on(eventName, function(event) {
          return scope.$apply(function() {
            return fn(scope, {
              $event: event
            });
          });
        });
      }
    };
    }
  ]);
});

私のhtmlは次のようになります:

<div ng-controller="IndexCtrl" >
    <div class='tap-area' hm-tap="tap();">
    </div>
</div>

私のコントローラーは次のようになります。

App.controller('IndexCtrl', function ($scope, Myapp) {

$scope.tap = function(ev){
     //How do I get the event.gesture.center.pageX in here?
};

});
4

2 に答える 2

1

これを機能させる方法を見つけました。return scope.hammer.on(eventName, function(event) {追加した後、コントローラーでorscope.event = event;を使用してタップの XY 座標を取得できます。this.event.center.pageXthis.event.center.pageY

于 2013-09-20T06:33:31.213 に答える