-
Notifications
You must be signed in to change notification settings - Fork 187
bug: Drag events not working in Android 4.4.2 #11
Comments
From @perrygovier on May 11, 2015 18:24 Thanks for creating a new issue for this. I'd like to make it as a fast follower for the 1.0. |
From @perrygovier on May 20, 2015 16:16 Closed with #3769 on the 1.0.1 branch. Thanks! |
From @MartinMa on May 21, 2015 7:49 Perfect, a one-liner. 👍 Thanks! 🍻 |
From @benlozano on December 5, 2015 20:12 @perrygovier I confirmed that this fix exists in my current ionic (1.1.0) and drag events are still broken on 4.4.4 (and have always been for me). Any insight into whether this is the same as your issue? I have seen this get tossed around and really haven't had any luck getting the ionic gestures to work cross-platform. |
From @MartinMa on December 22, 2015 9:21 I can confirm that this issue is present (again) on Android 4.4.2 running Ionic 1.2.1. This seems to be a regression (again) introduced with commit e10b5d2 This part of the code seems to change back and forth because of an iOS scrolling issue (see #4008). If you have an Android device with a 4.4 webview you can reproduce the issue as mentioned above:
|
From @mlynch on December 24, 2015 3:20 Okay, I just reverted that old fix to enable dragging to work correctly. Looking more closely, I think the fix for the side menu issue in #4022 was not correct. I'm still looking into how to get these both playing well together for 1.2.1. |
From @jskrzypek on December 24, 2015 9:14 @mlynch I want to be sure that this doesn't break native scrolling again... |
From @mlynch on December 24, 2015 15:38 I'm not really sure what the original issue was, and scrolling works fine with this change on iOS and Android. Any more info or thoughts on the impact? |
From @jskrzypek on December 24, 2015 18:21 You can see the original issue by following the steps to reproduce i listed in #4008 in the ios emulator or on a device. It might no longer be an issue I'll try check it tomorrow. |
From @MartinMa on December 28, 2015 15:15 I created a new build of Ionic based on the current master branch (with the reverted old fix). The good news is, that the red-box-dragging-demo is working again. Unfortunately native scrolling is broken for me now. It doesn't work at all, even though the webview is receiving all touchmove events. I used an example with a simple list as described in #4022 (first post). JS-scrolling on the other hand works fine. All testing done on a Samsung Galaxy Tab 3 with Android 4.4.2. This webview bug is also documented on the Android issue tracker: WebView touch events are not fired properly. See comment 41 and later. This seems to be "normal behavior" on Android 4.4 "KitKat". The first
Then, all subsequent touchmove events never reach the webview. But if you prevent default, you get all touch events, and native scrolling doesn't work. It's kind of a vicious cycle. What do you think is the best solution? Fallback to js-scrolling on Android 4.4? Which devices are you testing on? |
From @mlynch on December 28, 2015 15:39 I tested on 4.4.2 and it worked fine, so let's dig in: are you adding any gesture listeners to your app? Or is it breaking on a vanilla example? |
From @mlynch on December 29, 2015 2:10 Okay, can confirm now. Looking into this and will fix for 1.2.2 |
From @mlynch on December 29, 2015 17:42 Fix for this will be out in 1.2.2 |
From @mlynch on December 31, 2015 4:8 Grrr, that had bad side effects. Need a different solution. |
From @MartinMa on January 1, 2016 10:34 Hey @mlynch thank you very much for your effort! What kind of side effects? Have you really been able to reproduce? For me it is breaking in a vanilla example. I'll try to provide a new example utilizing native scrolling and custom drag gestures. From what you are experiencing it doesn't seem to affect "KitKat" in general. |
From @MartinMa on January 5, 2016 10:19 I made a quick minimal vanilla example demonstrating the general issue at MartinMa/drag_vanilla with a possible solution. It is a simple Cordova project (build instructions included). On Android 4.4.2 (at least on my device) the situation is as follows. I register event handlers for What's wrong here? Actually But if you For Ionic, I think, we need to figure out whether js-scrolling or native scrolling is active in a specific content view. If native scrolling is active: don't |
From @MartinMa on January 5, 2016 16:13 @mlynch I added a pull request with a fix for this issue. I also removed the length check because it is not needed. The fix is inspired by @perrygovier (see commit 71e8971 (Sorry for the mess with the GitHub references above. I had to update my pull request because of a linter error.) |
From @jskrzypek on January 5, 2016 16:19 Interesting @MartinMa. Now I understand the flow of the system a bit better, that makes sense and I agree, we probably need two separate behaviors for the native- and js-scrolling. This also seems like it should be a separate check from killing the drag event if its going in the wrong direction. Your fix is a step in the right direction but I think a slightly more general rewrite might be called for.
I'm also wondering about the comment Perry added for explanation, is it actually telling us what's going on? It seems to me now that this describes the opposite of the actual behavior at that point. // Prevent gestures that are not intended for this event handler from firing subsequent times It comes from commit ionic-team/ionic-framework@56ab0f2, but if we look at the code we see that if the current direction is in the I think possibly what's happened is that the logic needs to get inverted between the js-scrolling and native scrolling scenarios, as you suggest, but this wasn't always clear during development. Additionally I think the logic around the implementation of It seems to me that the code Perry wrote in ionic-team/ionic-framework@56ab0f2 only worked to cancel wrong-direction drags in js-scrolling by abusing the fact that no Here's a verbal description of what I think we should be doing in the drag handler, taken form the top:
|
From @MartinMa on January 5, 2016 16:51 Hi @jskrzypek I agree that the coupling you mentioned is unfortunate. That's why I removed the length check altogether in the pull request. The code is equivalent without it. I think the fix proposal doesn't break native scrolling. I tested it on my device, it works. This is because the I have to think about your description... |
From @MartinMa on January 6, 2016 12:57 I added an example to prove that this fix is functioning correctly: https://github.com/MartinMa/dragtest I also added an explanation of how and why it works (see README.md). I'd be very happy see this fix land and be included in the next release 1.2.4. 😄 @jskrzypek I think we should move the |
From @MartinMa on January 11, 2016 16:19 Hold up. The fix provided, doesn't play well with Update I updated the pull request and moved the check (slightly altered) to |
From @wbhob on January 6, 2017 2:40 It probably made it into 1.3.2. I don't use v1 anymore, can anyone verify? |
From @MartinMa on May 11, 2015 6:25
Type: bug
Platform: android 4.4 webview
This issue refers to a regression introduced with this commit from 19 Mar.
This is a new issue as desired by @perrygovier. Again (concerning above commit), what exactly do you mean by "Prevent gestures from breaking native scrolling"? Is there a use/test case? I could't find a related issue.
Here is a codepen that demonstrates the issue (try to drag the red box): http://codepen.io/MartinMa/pen/vOEmVR
Please confirm.
To get it up and running on your Android device, run the following commands using Ionic CLI.
As already mentioned by @gregor-srdic, this issue also affects built-in events like
on-hold
. (see issue 1729)There is a work around. You have to pass
{prevent_default_directions = ['left', 'up', 'right', 'down']}
as fourth argument to$ionicGesture.on
.I think
preventDefault();
should be the default, if'overflow-scroll'
isn't present? With the current behavior it breaks drag gestures when using Ionic scroll - which is the default. So it's broken by default ;)Copied from original issue: ionic-team/ionic-framework#3695
The text was updated successfully, but these errors were encountered: