亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cameracontrolleraquynza.java

?? 基于java的3d開發庫。對坐java3d的朋友有很大的幫助。
?? JAVA
字號:
//===========================================================================package vsdk.toolkit.gui;import java.awt.event.MouseEvent;import java.awt.event.MouseWheelEvent;//import java.awt.event.KeyEvent; // Do not include, deprecatedimport vsdk.toolkit.common.Vector3D;import vsdk.toolkit.common.Matrix4x4;import vsdk.toolkit.environment.Camera;public class CameraControllerAquynza extends CameraController {    private Camera camera;    private int oldMouseX;    private int oldMouseY;    private double deltaMov;    public CameraControllerAquynza(Camera camera) {        this.camera = camera;        oldMouseX = 0;        oldMouseY = 0;        deltaMov = 0.25;    }    public double getDeltaMovement()    {        return deltaMov;    }    public void setDeltaMovement(double val)    {        deltaMov = val;    }    public boolean processMouseEventAwt(MouseEvent mouseEvent) {      return true;    }    private double augmentLogarithmic(double val, double EPSILON)    {        if ( val < 0.001 ) val += 0.0001;        else if ( val < 0.01 ) val += 0.001;        else if ( val < 0.1 - EPSILON ) val += 0.01;        else if ( val < 1 - EPSILON ) val += 0.1;        else if ( val < 10 - EPSILON ) val += 1;        else if ( val < 100 - EPSILON ) val += 10;        else if ( val < 1000 - EPSILON ) val += 100;        else if ( val < 10000 - EPSILON ) val += 1000;        else if ( val < 100000 - EPSILON ) val += 10000;        else if ( val < 1000000 - EPSILON ) val += 100000;        else if ( val < 10000000 - EPSILON ) val *= 2;        else val = 10000000;          return val;    }      private double diminishLogarithmic(double val, double EPSILON)    {        if ( val > 10000000 + EPSILON ) val /= 2;        else if ( val > 1000000 + EPSILON ) val -= 1000000;        else if ( val > 100000 + EPSILON ) val -= 100000;        else if ( val > 10000 + EPSILON ) val -= 10000;        else if ( val > 1000 + EPSILON ) val -= 1000;        else if ( val > 100 + EPSILON ) val -= 100;        else if ( val > 10 + EPSILON ) val -= 10;        else if ( val > 1 + EPSILON ) val -= 1;        else if ( val > 0.1 + EPSILON ) val -= 0.1;        else if ( val > 0.01 + EPSILON ) val -= 0.01;        else if ( val > 0.001 + EPSILON ) val -= 0.001;        else if ( val > 0.0001 + EPSILON ) val -= 0.0001;        else val = 0.0001;        return val;    }      public boolean processKeyPressedEvent(KeyEvent keyEvent) {        // Local copy of the Camera's internal parameters        Vector3D eyePosition;        Vector3D focusedPosition;        Matrix4x4 R; // Camera rotation matrix        int projectionMode;        double fov;        double orthogonalZoom;        double nearPlaneDistance;        double farPlaneDistance;        // Internal variables to control the interaction        char unicode_id;        int keycode;        double yaw;        double pitch;        double roll;        double angleInc;        boolean updated = false;        double EPSILON = 0.0001;        // 1. Obtain a copy of the camera's internal parameters        eyePosition = camera.getPosition();        focusedPosition = camera.getFocusedPosition();        R = camera.getRotation();        projectionMode = camera.getProjectionMode();        fov = camera.getFov();        orthogonalZoom = camera.getOrthogonalZoom();        nearPlaneDistance = camera.getNearPlaneDistance();        farPlaneDistance = camera.getFarPlaneDistance();        // 2. Calculate variables used for interaction manipulation        yaw = R.obtainEulerYawAngle();        pitch = R.obtainEulerPitchAngle();        roll = R.obtainEulerRollAngle();          if ( fov > 90 ) angleInc = Math.toRadians(10);        else if ( fov > 45 ) angleInc = Math.toRadians(5);        else if ( fov > 15 ) angleInc = Math.toRadians(2.5);        else if ( fov > 5 ) angleInc = Math.toRadians(1);        else angleInc = Math.toRadians(0.1);        // 3. Event processing: update the copy of the camera's internal parameters        switch ( keyEvent.keycode ) {          case KeyEvent.KEY_UP:            pitch -= angleInc;            if ( pitch < Math.toRadians(-90) ) pitch = Math.toRadians(-90);            updated = true;            break;          case KeyEvent.KEY_DOWN:            pitch += angleInc;            if ( pitch > Math.toRadians(90) ) pitch = Math.toRadians(90);            updated = true;            break;          case KeyEvent.KEY_LEFT:            yaw += angleInc;            while ( yaw >= Math.toRadians(360) ) yaw -= Math.toRadians(360);            updated = true;            break;          case KeyEvent.KEY_RIGHT:            yaw -= angleInc;            while ( yaw < 0 ) yaw += Math.toRadians(360);            updated = true;            break;          // Position          case KeyEvent.KEY_x:            eyePosition.x -= deltaMov; focusedPosition.x -= deltaMov;            updated = true;            break;          case KeyEvent.KEY_X:            eyePosition.x += deltaMov; focusedPosition.x += deltaMov;            updated = true;            break;          case KeyEvent.KEY_y:            eyePosition.y -= deltaMov; focusedPosition.y -= deltaMov;            updated = true;            break;          case KeyEvent.KEY_Y:            eyePosition.y += deltaMov; focusedPosition.y += deltaMov;            updated = true;            break;          case KeyEvent.KEY_z:            eyePosition.z -= deltaMov; focusedPosition.z -= deltaMov;            updated = true;            break;          case KeyEvent.KEY_Z:            eyePosition.z += deltaMov; focusedPosition.z += deltaMov;            updated = true;            break;           // Rotation          case KeyEvent.KEY_S:            roll -= Math.toRadians(5);            while ( roll < 0 ) roll += Math.toRadians(360);            updated = true;            break;          case KeyEvent.KEY_s:            roll += Math.toRadians(5);            while ( roll > Math.toRadians(360) ) roll -= Math.toRadians(360);            updated = true;            break;            // View volume modification          case KeyEvent.KEY_A:            if ( camera.getProjectionMode() == camera.PROJECTION_MODE_ORTHOGONAL ) {                orthogonalZoom /= 2;              }              else {                if ( fov < 0.1 - EPSILON ) fov += 0.1;                else if ( fov < 1 - EPSILON ) fov++;                else if ( fov < 175 - EPSILON ) fov += 5;            }            updated = true;            break;          case KeyEvent.KEY_a:            if ( camera.getProjectionMode() == camera.PROJECTION_MODE_ORTHOGONAL ) {                orthogonalZoom *= 2;              }              else {                if ( fov > 5 + EPSILON ) fov -= 5;                else if ( fov > 1 + EPSILON  ) fov--;                else if ( fov > 0.1 + EPSILON  ) fov -= 0.1;            }            updated = true;            break;            case KeyEvent.KEY_N:            nearPlaneDistance = augmentLogarithmic(nearPlaneDistance, EPSILON);            updated = true;            break;          case KeyEvent.KEY_n:            nearPlaneDistance = diminishLogarithmic(nearPlaneDistance, EPSILON);            updated = true;            break;            case KeyEvent.KEY_F:            farPlaneDistance = augmentLogarithmic(farPlaneDistance, EPSILON);            updated = true;            break;          case KeyEvent.KEY_f:            farPlaneDistance = diminishLogarithmic(farPlaneDistance, EPSILON);            updated = true;            break;            case KeyEvent.KEY_p: // Rote el modo de proyeccion            switch ( projectionMode ) {              case Camera.PROJECTION_MODE_PERSPECTIVE:                projectionMode = Camera.PROJECTION_MODE_ORTHOGONAL;                break;              default:                projectionMode = Camera.PROJECTION_MODE_PERSPECTIVE;                break;            }            updated = true;            break;            // Queries          case KeyEvent.KEY_i:            System.out.println(camera);            break;        }        // 4. Update camera's internal parameters from local copy        R.eulerAnglesRotation(yaw, pitch, roll);          camera.setPosition(eyePosition);        camera.setFocusedPositionMaintainingOrthogonality(focusedPosition);        camera.setRotation(R);        camera.setOrthogonalZoom(orthogonalZoom);        camera.setFov(fov);        camera.setProjectionMode(projectionMode);        camera.setNearPlaneDistance(nearPlaneDistance);        camera.setFarPlaneDistance(farPlaneDistance);          return updated;    }    /**    @deprecated    Migrated to generalized version of this class, which is    independent of Awt.    This method has been deprecated in january 1st 2008. It should be    deleted by june 1st 2008.    */    @Deprecated    public boolean processKeyPressedEventAwt(java.awt.event.KeyEvent keyEvent) {        return processKeyPressedEvent(AwtSystem.awt2vsdkEvent(keyEvent));    }    public boolean processKeyReleasedEventAwt(java.awt.event.KeyEvent keyEvent) {        return false;    }    public boolean processMousePressedEventAwt(MouseEvent e)    {        oldMouseX = e.getX();        oldMouseY = e.getX();        return false;    }    public boolean processMouseReleasedEventAwt(MouseEvent e)    {        return false;    }    public boolean processMouseClickedEventAwt(MouseEvent e)    {        return false;    }    public boolean processMouseMovedEventAwt(MouseEvent e)    {        return false;    }    public boolean processMouseDraggedEventAwt(MouseEvent e)    {        //------------------------------------------------------------        int deltaX;        int deltaY;        boolean updated = false;        double senseFactor = deltaMov/5;        deltaX = e.getX() - oldMouseX;        deltaY = e.getY() - oldMouseY;        if ( deltaX > 5 ) deltaX = 5;        if ( deltaX < -5 ) deltaX = -5;        if ( deltaY > 5 ) deltaY = 5;        if ( deltaY < -5 ) deltaY = -5;        //------------------------------------------------------------        Matrix4x4 R; // Camera rotation matrix        Matrix4x4 DR;        Vector3D eyePosition;        Vector3D focusedPosition;        double ax, ay;        // Obtain a copy of the camera's internal parameters        eyePosition = camera.getPosition();        focusedPosition = camera.getFocusedPosition();        Vector3D u, v, w;        int modifiers;        modifiers = e.getModifiersEx();        R = camera.getRotation();        u = new Vector3D(R.M[0][0], R.M[1][0], R.M[2][0]);        v = new Vector3D(R.M[0][1], R.M[1][1], R.M[2][1]);        w = new Vector3D(R.M[0][2], R.M[1][2], R.M[2][2]);        if ( (modifiers & e.BUTTON1_DOWN_MASK) != 0 ) {            // Turn            ax = -Math.min(2, 0.01*deltaX);            ay = Math.min(2, 0.01*deltaY);            DR = new Matrix4x4();            DR.axisRotation(ay, v.x, v.y, v.z);            R = DR.multiply(R);            DR.axisRotation(ax, w.x, w.y, w.z);            R = DR.multiply(R);            updated = true;        }        else if ( (modifiers & e.BUTTON2_DOWN_MASK) != 0 ) {            // Move            eyePosition = eyePosition.substract(v.multiply(senseFactor*((double)deltaX)));            eyePosition = eyePosition.substract(w.multiply(senseFactor*((double)deltaY)));            focusedPosition = focusedPosition.substract(v.multiply(senseFactor*((double)deltaX)));            focusedPosition = focusedPosition.substract(w.multiply(senseFactor*((double)deltaY)));            updated = true;        }        else if ( (modifiers & e.BUTTON3_DOWN_MASK) != 0 ) {            // Advance            eyePosition = eyePosition.substract(u.multiply(senseFactor*((double)deltaY)));            ax = Math.min(2, 0.01*deltaX);            DR = new Matrix4x4();            DR.axisRotation(ax, u.x, u.y, u.z);            R = DR.multiply(R);            updated = true;        }        // Update camera's internal parameters from local copy        //R.eulerAnglesRotation(yaw, pitch, roll);        camera.setPosition(eyePosition);        camera.setFocusedPositionMaintainingOrthogonality(focusedPosition);        camera.setRotation(R);        //------------------------------------------------------------        oldMouseX = e.getX();          oldMouseY = e.getY();        return updated;    }    public boolean processMouseWheelEventAwt(MouseWheelEvent e)    {        //------------------------------------------------------------        double fov, angleInc;        boolean updated = false;        double EPSILON = 0.0001;        double orthogonalZoom;        fov = camera.getFov();        orthogonalZoom = camera.getOrthogonalZoom();        if ( fov > 90 ) angleInc = Math.toRadians(10);        else if ( fov > 45 ) angleInc = Math.toRadians(5);        else if ( fov > 15 ) angleInc = Math.toRadians(2.5);        else if ( fov > 5 ) angleInc = Math.toRadians(1);        else angleInc = Math.toRadians(0.1);        int clicks = e.getWheelRotation();        //------------------------------------------------------------        if ( clicks > 0 ) {            if ( camera.getProjectionMode() == camera.PROJECTION_MODE_ORTHOGONAL ) {                orthogonalZoom /= clicks;              }              else {                if ( fov < 0.1 - EPSILON ) fov += 0.1*clicks;                else if ( fov < 1 - EPSILON ) fov += clicks;                else if ( fov < 175 - EPSILON ) fov += 5*clicks;            }            updated = true;        }        else if ( clicks < 0 ) {            if ( camera.getProjectionMode() == camera.PROJECTION_MODE_ORTHOGONAL ) {                orthogonalZoom *= 2*clicks;              }              else {                if ( fov > 5 + EPSILON ) fov -= 5*clicks;                else if ( fov > 1 + EPSILON  ) fov -= clicks;                else if ( fov > 0.1 + EPSILON  ) fov -= 0.1*clicks;            }            updated = true;        }        //------------------------------------------------------------        camera.setFov(fov);        camera.setOrthogonalZoom(orthogonalZoom);        return updated;    }    public Camera getCamera()    {        return camera;    }    public void setCamera(Camera camera)    {        this.camera = camera;    }}//===========================================================================//= EOF                                                                     =//===========================================================================

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人免费网站| 日韩高清中文字幕一区| 丝袜亚洲另类欧美| 国产一区二区三区久久久| 日韩欧美一级在线播放| 欧美精品一区二区三区高清aⅴ| 秋霞国产午夜精品免费视频| 欧美久久久久久久久中文字幕| 香蕉乱码成人久久天堂爱免费| 欧美日韩国产欧美日美国产精品| 亚洲图片欧美综合| 日韩av中文在线观看| 高清国产一区二区| 久久久欧美精品sm网站| 国产一区91精品张津瑜| 日韩精品成人一区二区三区| 日韩欧美国产一区在线观看| 国产自产2019最新不卡| 国产精品久久久久久久久搜平片 | 精品亚洲免费视频| 欧美电影一区二区| 欧美a级一区二区| 久久久精品国产免大香伊| 国产精品影视在线| 久久久.com| 亚洲在线视频一区| 欧美大片一区二区三区| 午夜欧美一区二区三区在线播放| 91精品一区二区三区久久久久久| 毛片不卡一区二区| 欧美国产日韩a欧美在线观看| 色呦呦国产精品| 蜜桃久久av一区| 1000精品久久久久久久久| 欧美久久久久久蜜桃| 秋霞国产午夜精品免费视频| 国产精品免费视频一区| 欧美一区二区高清| 欧美三级电影精品| 欧美怡红院视频| 色综合久久综合网| av动漫一区二区| 成人激情免费视频| 国产美女娇喘av呻吟久久| 久久国产生活片100| 琪琪一区二区三区| 日韩激情中文字幕| 日本亚洲免费观看| 看片网站欧美日韩| 久久不见久久见免费视频1| 蜜桃视频在线观看一区二区| 日本v片在线高清不卡在线观看| 中文字幕中文字幕一区| 国产亚洲自拍一区| 91蜜桃在线观看| 色狠狠综合天天综合综合| 91无套直看片红桃| 国产九九视频一区二区三区| 国产米奇在线777精品观看| 性久久久久久久久久久久| 午夜激情一区二区| 蜜臀av在线播放一区二区三区| 天堂一区二区在线| 麻豆一区二区三| 国产麻豆精品视频| 国产馆精品极品| eeuss鲁片一区二区三区| 91首页免费视频| 欧美色国产精品| 日韩欧美卡一卡二| 国产日韩欧美制服另类| 国产精品国产a级| 国产精品久久久久一区二区三区 | 国模大尺度一区二区三区| 午夜一区二区三区在线观看| 婷婷国产v国产偷v亚洲高清| 免费亚洲电影在线| 国产精品主播直播| 欧美无砖专区一中文字| 日韩免费一区二区| 中文字幕人成不卡一区| 中文字幕在线不卡| 亚洲午夜精品网| 国产精品综合久久| 欧美羞羞免费网站| 国产日韩欧美亚洲| 亚洲线精品一区二区三区八戒| 欧美aa在线视频| 色妞www精品视频| 久久久久久久久久久久久久久99 | 欧美一级夜夜爽| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 麻豆精品在线看| 91色乱码一区二区三区| 精品免费国产一区二区三区四区| 亚洲免费视频成人| 国产真实乱偷精品视频免| 91国内精品野花午夜精品| 久久蜜桃香蕉精品一区二区三区| 亚洲综合免费观看高清完整版在线| 久久精品国产色蜜蜜麻豆| 91女人视频在线观看| 久久久久久久久99精品| 五月天欧美精品| 成人天堂资源www在线| 欧美妇女性影城| 亚洲一二三区在线观看| 粉嫩欧美一区二区三区高清影视| 91麻豆精品国产91久久久久久久久| 中文字幕一区二区三区色视频| 久草热8精品视频在线观看| 精品视频在线免费| 亚洲精品欧美二区三区中文字幕| 国产精品亚洲一区二区三区在线| 91精品欧美一区二区三区综合在| 久久日一线二线三线suv| 亚洲日本成人在线观看| 国产**成人网毛片九色 | 欧美一级片在线看| 亚洲视频1区2区| 99精品久久只有精品| 国产亚洲精品aa午夜观看| 久久精品国产色蜜蜜麻豆| 欧美一区二区福利在线| 另类欧美日韩国产在线| 日韩一区二区三区三四区视频在线观看| 伊人开心综合网| 在线精品国精品国产尤物884a| 亚洲免费在线电影| 色老汉av一区二区三区| 亚洲午夜视频在线| 欧美精品三级日韩久久| 伊人色综合久久天天| 欧美精品一级二级三级| 日韩电影在线看| 欧美va亚洲va在线观看蝴蝶网| 久久激情五月激情| 精品国产凹凸成av人网站| 激情久久五月天| 日本一区二区视频在线观看| av中文字幕一区| 久久日韩粉嫩一区二区三区| 国产福利91精品| 亚洲欧美成aⅴ人在线观看| 久久蜜桃一区二区| 亚洲欧美一区二区三区久本道91| 一本到三区不卡视频| 国产精品视频麻豆| 99久久免费精品高清特色大片| 2021国产精品久久精品 | 国产女人水真多18毛片18精品视频| 国产精品中文字幕日韩精品| 国产精品日韩精品欧美在线| 91搞黄在线观看| 麻豆成人91精品二区三区| 国产婷婷色一区二区三区| av在线免费不卡| ...xxx性欧美| 91精品久久久久久久91蜜桃| 国产成人aaa| 亚洲国产cao| 久久一区二区三区四区| av综合在线播放| 九色综合狠狠综合久久| 中文av一区二区| 538在线一区二区精品国产| 国产成人精品综合在线观看| 午夜精品久久久久久久99樱桃| 久久久综合精品| 国产盗摄一区二区三区| 天天亚洲美女在线视频| 国产精品国产三级国产有无不卡 | 六月婷婷色综合| 亚洲欧美成人一区二区三区| 精品免费99久久| 91在线观看视频| 久久久久青草大香线综合精品| 亚洲欧美aⅴ...| 久久久久久久久一| 91麻豆精品国产91久久久久久| 97久久超碰国产精品电影| 久久电影网电视剧免费观看| 亚洲一区二区三区在线看| 国产精品白丝在线| 久久九九99视频| 欧美三级视频在线播放| 国产成人丝袜美腿| 夜夜亚洲天天久久| 亚洲图片欧美激情| 91久久精品网| 国产v日产∨综合v精品视频| 免费在线视频一区| 丝袜a∨在线一区二区三区不卡| 亚洲欧洲国产专区| 久久久精品免费免费| 日韩精品一区二区在线| 51久久夜色精品国产麻豆| 欧美三级在线看| 欧美日本高清视频在线观看| 在线观看亚洲精品|