[Java] [OpenGL ES 3.2] 相机控制器

原理

首先来讲相机旋转:求得上一次触摸位置和本次触摸位置的差向量,然后调用Camera的rotate()就行了
然后是重点——计算缩放:得到两个手指本次和上次触摸位置,分别求手指1和手指2的上次与本次触摸位置的差向量的模,相除得出一个比值,这个值就是缩放量,乘上视野即可。

源代码

CameraController.java

package com.Diamond.SGL;

import com.Diamond.SGL.*;
import android.renderscript.Float2;
import android.view.MotionEvent;

public class CameraController {
    public static final float DEFAULT_SPEED = 0.1f;

    public Camera camera;
    public Float2[] lasts;
    public float speed;

    public CameraController(Camera c) {
        camera = c;
        speed = DEFAULT_SPEED;
        lasts = new Float2[2];
    }
    public CameraController(Camera c, float s) {
        camera = c;
        speed = s;
        lasts = new Float2[2];
    }

    public CameraController update(MotionEvent event) {
        int pointer_count = event.getPointerCount();
        int mode = camera.getOrbitMode();

        if (pointer_count > 0) {
            Float2[] nows = new Float2[2];

            nows[0] = new Float2(event.getX(0), event.getY(0));
            if (pointer_count > 1) {
                nows[1] = new Float2(event.getX(1), event.getY(1));
            } else {
                nows[1] = nows[0];
            }

            int action = event.getAction();

            if (action == MotionEvent.ACTION_DOWN) {
                lasts = nows;
            } else if (action == MotionEvent.ACTION_MOVE) {
                Float2 delta = new Float2(nows[0].x - lasts[0].x, nows[0].y - lasts[0].y);
                
                delta.x *= speed;
                delta.y *= speed;

                if (pointer_count == 1) {
                    if (mode == Camera.ORBIT_CENTER) {
                        camera.rotate(-delta.x, delta.y);
                    } else if (mode == Camera.ORBIT_POSITION) {
                        camera.rotate(-delta.x, -delta.y);
                    }
                } else if (pointer_count > 1) {
                    float fovy = camera.getFovy();
                    
                    Float2 d1 = new Float2(nows[0].x - nows[1].x,nows[0].y - nows[1].y);
                    Float2 d2 = new Float2(lasts[0].x - lasts[1].x,lasts[0].y - lasts[1].y);
                    float nowh = (float)Math.hypot((double)d1.x,(double)d1.y);
                    float lasth = (float)Math.hypot((double)d2.x,(double)d2.y);
                    
                    fovy *= lasth / nowh;
                    camera.setFovy(fovy);
                }
            }
            
            lasts = nows;
        }

        return this;
    }
}

效果图

正常
在这里插入图片描述
放大
在这里插入图片描述
缩小
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值