栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

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

[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;
    }
}
效果图

正常

放大

缩小

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/748217.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号