Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add get focusx and focusy #32

Open
wants to merge 10 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions build.gradle
Original file line number Diff line number Diff line change
@@ -1,18 +1,18 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.3'

// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
classpath 'com.android.tools.build:gradle:3.3.0'
}
}

allprojects {
repositories {
google()
jcenter()
mavenCentral()
}
}
6 changes: 3 additions & 3 deletions gradle.properties
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
VERSION_NAME=1.0
VERSION_CODE=2
VERSION_CODE=3
GROUP=com.almeros.android-gesture-detectors

POM_DESCRIPTION=Gesture detector framework for multitouch handling on Android, based on Android's ScaleGestureDetector
Expand All @@ -15,7 +15,7 @@ POM_DEVELOPER_NAME=Almeros Thies

ANDROID_MIN_SDK=8
ANDROID_TARGET_SDK=21
ANDROID_COMPILE_SDK=21
ANDROID_BUILD_TOOLS_VERSION=25.0.0
ANDROID_COMPILE_SDK=28
ANDROID_BUILD_TOOLS_VERSION=28.0.3

org.gradle.jvmargs=-Xmx1536M
2 changes: 1 addition & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,4 @@ distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-4.10.3-all.zip
10 changes: 0 additions & 10 deletions library/src/main/AndroidManifest.xml
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,6 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.almeros.android.multitouch">

<uses-configuration android:reqTouchScreen="finger" />

mariopce marked this conversation as resolved.
Show resolved Hide resolved
<uses-feature
android:name="android.hardware.touchscreen"
android:required="true" />
<uses-feature
android:name="android.hardware.touchscreen.multitouch"
android:required="true" />


<application/>

</manifest>
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,8 @@ public void onRotateEnd(RotateGestureDetector detector) {

private final OnRotateGestureListener mListener;
private boolean mSloppyGesture;
private float mFocusX;
mariopce marked this conversation as resolved.
Show resolved Hide resolved
private float mFocusY;

public RotateGestureDetector(Context context, OnRotateGestureListener listener) {
super(context);
Expand Down Expand Up @@ -139,6 +141,7 @@ protected void handleInProgressEvent(int actionCode, MotionEvent event){
// a certain limit. This can help filter shaky data as a
// finger is lifted.
if (mCurrPressure / mPrevPressure > PRESSURE_THRESHOLD) {
determineFocusPoint(event);
final boolean updatePrevious = mListener.onRotate(this);
if (updatePrevious) {
mPrevEvent.recycle();
Expand All @@ -155,6 +158,25 @@ protected void resetState() {
mSloppyGesture = false;
}

/**
* Get gesture focus X point.
*/
public float getFocusX() {
return mFocusX;
}


/**
* Get gesture focus Y point.
*/
public float getFocusY() {
mariopce marked this conversation as resolved.
Show resolved Hide resolved
return mFocusY;
}

private void determineFocusPoint(MotionEvent curr) {
mFocusX = (curr.getX(0) + curr.getX(1)) * 0.5f;
mFocusY = (curr.getY(0) + curr.getY(1)) * 0.5f;
}

/**
* Return the rotation difference from the previous rotate event to the current
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ public float getCurrentSpan() {
if (mCurrLen == -1) {
final float cvx = mCurrFingerDiffX;
final float cvy = mCurrFingerDiffY;
mCurrLen = FloatMath.sqrt(cvx*cvx + cvy*cvy);
mCurrLen = (float) Math.sqrt(cvx*cvx + cvy*cvy);
mariopce marked this conversation as resolved.
Show resolved Hide resolved
}
return mCurrLen;
}
Expand All @@ -107,7 +107,7 @@ public float getPreviousSpan() {
if (mPrevLen == -1) {
final float pvx = mPrevFingerDiffX;
final float pvy = mPrevFingerDiffY;
mPrevLen = FloatMath.sqrt(pvx*pvx + pvy*pvy);
mPrevLen = (float) Math.sqrt(pvx*pvx + pvy*pvy);
}
return mPrevLen;
}
Expand Down