Pinch to zoom added for devices >= Froyo
This commit is contained in:
parent
f96130528a
commit
3a9030925a
4 changed files with 103 additions and 36 deletions
|
@ -17,12 +17,14 @@ You should have received a copy of the GNU General Public License
|
||||||
along with this program; if not, write to the Free Software
|
along with this program; if not, write to the Free Software
|
||||||
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
import org.linphone.compatibility.Compatibility;
|
||||||
|
import org.linphone.compatibility.CompatibilityScaleGestureDetector;
|
||||||
|
import org.linphone.compatibility.CompatibilityScaleGestureListener;
|
||||||
import org.linphone.core.LinphoneCore;
|
import org.linphone.core.LinphoneCore;
|
||||||
import org.linphone.core.Log;
|
import org.linphone.core.Log;
|
||||||
import org.linphone.mediastream.video.AndroidVideoWindowImpl;
|
import org.linphone.mediastream.video.AndroidVideoWindowImpl;
|
||||||
import org.linphone.mediastream.video.capture.hwconf.AndroidCameraConfiguration;
|
import org.linphone.mediastream.video.capture.hwconf.AndroidCameraConfiguration;
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.opengl.GLSurfaceView;
|
import android.opengl.GLSurfaceView;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
@ -32,6 +34,7 @@ import android.view.GestureDetector.OnDoubleTapListener;
|
||||||
import android.view.GestureDetector.OnGestureListener;
|
import android.view.GestureDetector.OnGestureListener;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
|
import android.view.ScaleGestureDetector;
|
||||||
import android.view.SurfaceHolder;
|
import android.view.SurfaceHolder;
|
||||||
import android.view.SurfaceView;
|
import android.view.SurfaceView;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
@ -42,15 +45,15 @@ import android.view.WindowManager;
|
||||||
/**
|
/**
|
||||||
* @author Sylvain Berfini
|
* @author Sylvain Berfini
|
||||||
*/
|
*/
|
||||||
@TargetApi(5)
|
public class VideoCallFragment extends Fragment implements OnGestureListener, OnDoubleTapListener, CompatibilityScaleGestureListener {
|
||||||
public class VideoCallFragment extends Fragment implements OnGestureListener, OnDoubleTapListener {
|
|
||||||
private SurfaceView mVideoView;
|
private SurfaceView mVideoView;
|
||||||
private SurfaceView mCaptureView;
|
private SurfaceView mCaptureView;
|
||||||
private AndroidVideoWindowImpl androidVideoWindowImpl;
|
private AndroidVideoWindowImpl androidVideoWindowImpl;
|
||||||
private InCallActivity inCallActivity;
|
private InCallActivity inCallActivity;
|
||||||
private GestureDetector mGestureDetector;
|
private GestureDetector mGestureDetector;
|
||||||
private float mZoomFactor = 1;
|
private float mZoomFactor = 1.f;
|
||||||
private float mZoomCenterX, mZoomCenterY;
|
private float mZoomCenterX, mZoomCenterY;
|
||||||
|
private CompatibilityScaleGestureDetector mScaleDetector;
|
||||||
|
|
||||||
@SuppressWarnings("deprecation") // Warning useless because value is ignored and automatically set by new APIs.
|
@SuppressWarnings("deprecation") // Warning useless because value is ignored and automatically set by new APIs.
|
||||||
@Override
|
@Override
|
||||||
|
@ -61,6 +64,7 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
||||||
View view = inflater.inflate(R.layout.video, container, false);
|
View view = inflater.inflate(R.layout.video, container, false);
|
||||||
|
|
||||||
mGestureDetector = new GestureDetector(getActivity(), this);
|
mGestureDetector = new GestureDetector(getActivity(), this);
|
||||||
|
mScaleDetector = Compatibility.getScaleGestureDetector(getActivity(), this);
|
||||||
|
|
||||||
mVideoView = (SurfaceView) view.findViewById(R.id.videoSurface);
|
mVideoView = (SurfaceView) view.findViewById(R.id.videoSurface);
|
||||||
mCaptureView = (SurfaceView) view.findViewById(R.id.videoCaptureSurface);
|
mCaptureView = (SurfaceView) view.findViewById(R.id.videoCaptureSurface);
|
||||||
|
@ -98,8 +102,13 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
||||||
|
|
||||||
mVideoView.setOnTouchListener(new OnTouchListener() {
|
mVideoView.setOnTouchListener(new OnTouchListener() {
|
||||||
public boolean onTouch(View v, MotionEvent event) {
|
public boolean onTouch(View v, MotionEvent event) {
|
||||||
|
if (mScaleDetector != null) {
|
||||||
|
mScaleDetector.onTouchEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
mGestureDetector.onTouchEvent(event);
|
||||||
inCallActivity.displayVideoCallControlsIfHidden();
|
inCallActivity.displayVideoCallControlsIfHidden();
|
||||||
return mGestureDetector.onTouchEvent(event);
|
return true;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -165,21 +174,14 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
||||||
((GLSurfaceView) mVideoView).onPause();
|
((GLSurfaceView) mVideoView).onPause();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public boolean onScale(ScaleGestureDetector detector) {
|
||||||
public boolean onDown(MotionEvent e) {
|
mZoomFactor *= detector.getScaleFactor();
|
||||||
return true; // Needed to make the GestureDetector working
|
// Don't let the object get too small or too large.
|
||||||
}
|
mZoomFactor = Math.max(0.1f, Math.min(mZoomFactor, mVideoView.getHeight() / LinphoneManager.getLc().getPreferredVideoSize().height));
|
||||||
|
|
||||||
@Override
|
LinphoneManager.getLc().getCurrentCall().zoomVideo(mZoomFactor, mZoomCenterX, mZoomCenterY);
|
||||||
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
|
return true;
|
||||||
float velocityY) {
|
}
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onLongPress(MotionEvent e) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
|
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
|
||||||
|
@ -205,16 +207,6 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onShowPress(MotionEvent e) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onSingleTapUp(MotionEvent e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onDoubleTap(MotionEvent e) {
|
public boolean onDoubleTap(MotionEvent e) {
|
||||||
if (LinphoneUtils.isCallEstablished(LinphoneManager.getLc().getCurrentCall())) {
|
if (LinphoneUtils.isCallEstablished(LinphoneManager.getLc().getCurrentCall())) {
|
||||||
|
@ -237,6 +229,20 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
||||||
mZoomFactor = 1;
|
mZoomFactor = 1;
|
||||||
mZoomCenterX = mZoomCenterY = 0.5f;
|
mZoomCenterX = mZoomCenterY = 0.5f;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDestroy() {
|
||||||
|
if (androidVideoWindowImpl != null) {
|
||||||
|
// Prevent linphone from crashing if correspondent hang up while you are rotating
|
||||||
|
androidVideoWindowImpl.release();
|
||||||
|
}
|
||||||
|
super.onDestroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onDown(MotionEvent e) {
|
||||||
|
return true; // Needed to make the GestureDetector working
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onDoubleTapEvent(MotionEvent e) {
|
public boolean onDoubleTapEvent(MotionEvent e) {
|
||||||
|
@ -247,13 +253,25 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
||||||
public boolean onSingleTapConfirmed(MotionEvent e) {
|
public boolean onSingleTapConfirmed(MotionEvent e) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onDestroy() {
|
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
|
||||||
if (androidVideoWindowImpl != null) {
|
float velocityY) {
|
||||||
// Prevent linphone from crashing if correspondent hang up while you are rotating
|
return false;
|
||||||
androidVideoWindowImpl.release();
|
}
|
||||||
}
|
|
||||||
super.onDestroy();
|
@Override
|
||||||
|
public void onLongPress(MotionEvent e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onShowPress(MotionEvent e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onSingleTapUp(MotionEvent e) {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -161,4 +161,13 @@ public class Compatibility {
|
||||||
ApiFivePlus.setNotificationLatestEventInfo(notif, context, title, content, intent);
|
ApiFivePlus.setNotificationLatestEventInfo(notif, context, title, content, intent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static CompatibilityScaleGestureDetector getScaleGestureDetector(Context context, CompatibilityScaleGestureListener listener) {
|
||||||
|
if (Version.sdkAboveOrEqual(8)) {
|
||||||
|
CompatibilityScaleGestureDetector csgd = new CompatibilityScaleGestureDetector(context);
|
||||||
|
csgd.addListener(listener);
|
||||||
|
return csgd;
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
package org.linphone.compatibility;
|
||||||
|
|
||||||
|
import android.annotation.TargetApi;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.view.MotionEvent;
|
||||||
|
import android.view.ScaleGestureDetector;
|
||||||
|
|
||||||
|
@TargetApi(8)
|
||||||
|
public class CompatibilityScaleGestureDetector extends ScaleGestureDetector.SimpleOnScaleGestureListener {
|
||||||
|
private ScaleGestureDetector detector;
|
||||||
|
private CompatibilityScaleGestureListener listener;
|
||||||
|
|
||||||
|
public CompatibilityScaleGestureDetector(Context context) {
|
||||||
|
detector = new ScaleGestureDetector(context, this);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addListener(CompatibilityScaleGestureListener newListener) {
|
||||||
|
listener = newListener;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean onTouchEvent(MotionEvent event) {
|
||||||
|
return detector.onTouchEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onScale(ScaleGestureDetector detector) {
|
||||||
|
if (listener == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return listener.onScale(detector);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,7 @@
|
||||||
|
package org.linphone.compatibility;
|
||||||
|
|
||||||
|
import android.view.ScaleGestureDetector;
|
||||||
|
|
||||||
|
public interface CompatibilityScaleGestureListener {
|
||||||
|
public boolean onScale(ScaleGestureDetector detector);
|
||||||
|
}
|
Loading…
Reference in a new issue