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
|
||||
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.Log;
|
||||
import org.linphone.mediastream.video.AndroidVideoWindowImpl;
|
||||
import org.linphone.mediastream.video.capture.hwconf.AndroidCameraConfiguration;
|
||||
|
||||
import android.annotation.TargetApi;
|
||||
import android.app.Activity;
|
||||
import android.opengl.GLSurfaceView;
|
||||
import android.os.Bundle;
|
||||
|
@ -32,6 +34,7 @@ import android.view.GestureDetector.OnDoubleTapListener;
|
|||
import android.view.GestureDetector.OnGestureListener;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.MotionEvent;
|
||||
import android.view.ScaleGestureDetector;
|
||||
import android.view.SurfaceHolder;
|
||||
import android.view.SurfaceView;
|
||||
import android.view.View;
|
||||
|
@ -42,15 +45,15 @@ import android.view.WindowManager;
|
|||
/**
|
||||
* @author Sylvain Berfini
|
||||
*/
|
||||
@TargetApi(5)
|
||||
public class VideoCallFragment extends Fragment implements OnGestureListener, OnDoubleTapListener {
|
||||
public class VideoCallFragment extends Fragment implements OnGestureListener, OnDoubleTapListener, CompatibilityScaleGestureListener {
|
||||
private SurfaceView mVideoView;
|
||||
private SurfaceView mCaptureView;
|
||||
private AndroidVideoWindowImpl androidVideoWindowImpl;
|
||||
private InCallActivity inCallActivity;
|
||||
private GestureDetector mGestureDetector;
|
||||
private float mZoomFactor = 1;
|
||||
private float mZoomFactor = 1.f;
|
||||
private float mZoomCenterX, mZoomCenterY;
|
||||
private CompatibilityScaleGestureDetector mScaleDetector;
|
||||
|
||||
@SuppressWarnings("deprecation") // Warning useless because value is ignored and automatically set by new APIs.
|
||||
@Override
|
||||
|
@ -61,6 +64,7 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
|||
View view = inflater.inflate(R.layout.video, container, false);
|
||||
|
||||
mGestureDetector = new GestureDetector(getActivity(), this);
|
||||
mScaleDetector = Compatibility.getScaleGestureDetector(getActivity(), this);
|
||||
|
||||
mVideoView = (SurfaceView) view.findViewById(R.id.videoSurface);
|
||||
mCaptureView = (SurfaceView) view.findViewById(R.id.videoCaptureSurface);
|
||||
|
@ -98,8 +102,13 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
|||
|
||||
mVideoView.setOnTouchListener(new OnTouchListener() {
|
||||
public boolean onTouch(View v, MotionEvent event) {
|
||||
if (mScaleDetector != null) {
|
||||
mScaleDetector.onTouchEvent(event);
|
||||
}
|
||||
|
||||
mGestureDetector.onTouchEvent(event);
|
||||
inCallActivity.displayVideoCallControlsIfHidden();
|
||||
return mGestureDetector.onTouchEvent(event);
|
||||
return true;
|
||||
}
|
||||
});
|
||||
|
||||
|
@ -165,21 +174,14 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
|||
((GLSurfaceView) mVideoView).onPause();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onDown(MotionEvent e) {
|
||||
return true; // Needed to make the GestureDetector working
|
||||
}
|
||||
public boolean onScale(ScaleGestureDetector detector) {
|
||||
mZoomFactor *= detector.getScaleFactor();
|
||||
// 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
|
||||
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
|
||||
float velocityY) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onLongPress(MotionEvent e) {
|
||||
|
||||
}
|
||||
LinphoneManager.getLc().getCurrentCall().zoomVideo(mZoomFactor, mZoomCenterX, mZoomCenterY);
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
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;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onShowPress(MotionEvent e) {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onSingleTapUp(MotionEvent e) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onDoubleTap(MotionEvent e) {
|
||||
if (LinphoneUtils.isCallEstablished(LinphoneManager.getLc().getCurrentCall())) {
|
||||
|
@ -237,6 +229,20 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
|||
mZoomFactor = 1;
|
||||
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
|
||||
public boolean onDoubleTapEvent(MotionEvent e) {
|
||||
|
@ -247,13 +253,25 @@ public class VideoCallFragment extends Fragment implements OnGestureListener, On
|
|||
public boolean onSingleTapConfirmed(MotionEvent e) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void onDestroy() {
|
||||
if (androidVideoWindowImpl != null) {
|
||||
// Prevent linphone from crashing if correspondent hang up while you are rotating
|
||||
androidVideoWindowImpl.release();
|
||||
}
|
||||
super.onDestroy();
|
||||
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
|
||||
float velocityY) {
|
||||
return false;
|
||||
}
|
||||
|
||||
@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);
|
||||
}
|
||||
}
|
||||
|
||||
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