i was trying to implement an interaction within my app where two buttons have to be on-hold simultaneously.
that means: a function is only called when both buttons are touched (with two fingers) at the same time.
i tried my best using the on-hold method on both buttons but it seems that they won’t work together simultaneously?!
any help on this?
Not sure how to deal with this in ionic, but are you sure your device supports multitouch? It could be that your device is just not giving off multitouch (or always assuming it’s scaling intention and not giving up the events to the app? maybe this is webview specific?)
well – i’m using an ipad – so that’s probably not the problem. maybe it’s webview specific? i have no idea!
if there’s any idea or hint someone could give me?
ok – i just ran the actual app on the ipad and it seems to work! it’s not working while testing the app with the actual safari browser on the ipad (accessing a server) – that’s at least something.
i wrote a touch directive on my own to solve this problem. the event is beeing sent everytime a touch is initiated.
works pretty fine even with mixing it with other ng-events like click or tap.
Hi can someone please let me know how they implemented a fix to this? I’m having the same problem. Using two buttons with on-hold directives doesn’t seem to work, it only ever recognizes the first touch event and not the other. Here is a link to my code http://stackoverflow.com/questions/28903877/how-to-enable-ionic-multi-touch-events Please let me know what can be done to work with this issue. I know my device supports mult-touch I’m using an android htc one M8 and testing it on my phone does not work.
i wrote my own directive using touchstart and touchend … and i came up with the idea to set a boolean to check if both buttons were pressed simultanously.
that pretty much worked for me. to give you a kickstart heres a snippet for the directive:
// CHECK FOR TOUCH EVENTS, OTHERWISE USE MOUSE EVENTS (FOR BROWSER TESTING)
if ('ontouchstart' in document.documentElement) {
var touchEventStart = 'touchstart';
var touchEventEnd = 'touchend';
} else {
var touchEventStart = 'mousedown';
var touchEventEnd = 'mouseup';
}
angular.module […] .directive('myTouchstart', [function() {
return function(scope, element, attr) {
element.on(touchEventStart, function(event) {
scope.$apply(function() {
scope.$eval(attr.myTouchstart);
});
});
};
}]).directive('myTouchend', [function() {
return function(scope, element, attr) {
element.on(touchEventEnd, function(event) {
scope.$apply(function() {
scope.$eval(attr.myTouchend);
});
});
};
}]);