summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ios/experimental/LibreOffice/LibreOffice/View.m36
1 files changed, 21 insertions, 15 deletions
diff --git a/ios/experimental/LibreOffice/LibreOffice/View.m b/ios/experimental/LibreOffice/LibreOffice/View.m
index 44fa6df3aa3d..c90859592b92 100644
--- a/ios/experimental/LibreOffice/LibreOffice/View.m
+++ b/ios/experimental/LibreOffice/LibreOffice/View.m
@@ -155,10 +155,22 @@
- (void)panGesture:(UIPanGestureRecognizer *)gestureRecognizer
{
static enum { NONE, TOPLEFT, BOTTOMRIGHT } draggedHandle = NONE;
- static CGFloat previousX = 0.0f, previousY = 0.0f;
+ static CGFloat previousX, previousY;
CGPoint translation = [gestureRecognizer translationInView:self];
+ if (gestureRecognizer.state == UIGestureRecognizerStateBegan) {
+ previousX = previousY = 0;
+ }
+
+ CGFloat deltaX = translation.x - previousX;
+ CGFloat deltaY = translation.y - previousY;
+
+ NSLog(@"drag: %f,%f", deltaX, deltaY);
+
+ previousX = translation.x;
+ previousY = translation.y;
+
if (gestureRecognizer.state == UIGestureRecognizerStateBegan &&
gestureRecognizer.numberOfTouches == 1) {
if (CGRectContainsPoint([self topLeftResizeHandle],
@@ -172,16 +184,17 @@
if (draggedHandle == TOPLEFT) {
const int N = self.selectionRectangleCount;
- self.selectionRectangles[0].origin.x += translation.x;
- self.selectionRectangles[0].origin.y += translation.y;
- self.selectionRectangles[0].size.width -= translation.x;
- self.selectionRectangles[0].size.height -= translation.y;
+ self.selectionRectangles[0].origin.x += deltaX;
+ self.selectionRectangles[0].origin.y += deltaY;
+ self.selectionRectangles[0].size.width -= deltaX;
+ self.selectionRectangles[0].size.height -= deltaY;
#if 0
touch_lo_selection_attempt_resize(self.documentHandle,
self.selectionRectangles,
self.selectionRectangleCount);
#else
+ touch_lo_tap(0, 0);
touch_lo_mouse(self.selectionRectangles[0].origin.x,
self.selectionRectangles[0].origin.y,
DOWN, NONE);
@@ -197,16 +210,15 @@
} else if (draggedHandle == BOTTOMRIGHT) {
const int N = self.selectionRectangleCount;
- self.selectionRectangles[N-1].origin.x += translation.x;
- self.selectionRectangles[N-1].origin.y += translation.y;
- self.selectionRectangles[N-1].size.width += translation.x;
- self.selectionRectangles[N-1].size.height += translation.y;
+ self.selectionRectangles[N-1].size.width += deltaX;
+ self.selectionRectangles[N-1].size.height += deltaY;
#if 0
touch_lo_selection_attempt_resize(self.documentHandle,
self.selectionRectangles,
self.selectionRectangleCount);
#else
+ touch_lo_tap(0, 0);
touch_lo_mouse(self.selectionRectangles[0].origin.x,
self.selectionRectangles[0].origin.y,
DOWN, NONE);
@@ -222,16 +234,10 @@
}
if (gestureRecognizer.state != UIGestureRecognizerStateBegan) {
- int deltaX = translation.x - previousX;
- int deltaY = translation.y - previousY;
-
// NSLog(@"panGesture: pan (delta): (%d,%d)", deltaX, deltaY);
touch_lo_pan(deltaX, deltaY);
}
-
- previousX = translation.x;
- previousY = translation.y;
}
- (void)pinchGesture:(UIPinchGestureRecognizer *)gestureRecognizer