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

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

?? objloader.java

?? world wind java sdk load 3D model
?? JAVA
字號:
/*
 * OBJLoader.java
 *
 * Created on February 12, 2008, 10:26 PM
 *
 * To change this template, choose Tools | Template Manager
 * and open the template in the editor.
 */

package model;

import java.awt.Color;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Vector;

/**
 *
 * @author Brian Wood
 */
class OBJLoader {
    private String OBJModelPath;
    private Vector<Model3D.Vector3f> vertices = new Vector<Model3D.Vector3f>();
    private Vector<Model3D.Vector3f> normals = new Vector<Model3D.Vector3f>();
    private Vector<Model3D.TexCoord> texCoords = new Vector<Model3D.TexCoord>();
    private Vector<Model3D.Face> faces = new Vector<Model3D.Face>();
    
    private int faceFormat;
    private int faceCount;
    private int polyCount = 0;
    private int materialID;
    private boolean hasTexture = false;
    private String baseDir;
    
    private int verticesRead = 0;
    private int verticesSoFar = 0;
    private int texCoordsRead = 0;
    private int texCoordsSoFar = 0;
    private int facesRead = 0;
    
    private final int RENDER_TRIANGLES =    1;
    private final int RENDER_QUADS =	    2;
    private final int RENDER_POLYGONS =	    3;
    
    Model3D theModel;
    
    public OBJLoader() {
    }
    
    public Model3D load(String path) throws IOException, FileNotFoundException {
        String tokens[] = path.split("/");
        baseDir = "/";
        for(int i = 0; i < tokens.length - 1; i++) {
            baseDir += tokens[i] + "/";
        }
        
        theModel = load(Model3D.class.getResourceAsStream("/" + path));
        theModel.setBaseDir(baseDir);
        theModel.setType(Model3D.MODEL_OBJ);
        
        return theModel;
    }
    
    private Model3D load(InputStream stream) {
        if (stream == null)
            return null;
        
        theModel = new Model3D();
        Model3D.ModelObject object = null;
        
        try {
            // Open a file handle and read the models data
            BufferedReader br = new BufferedReader(new InputStreamReader(stream));
            String  line = null;
            while((line = br.readLine()) != null) {
                if (line.startsWith("#")) { // Read Any Descriptor Data in the File
                } else if (line.equals("")) {
                    //Ignore whitespace data
                } else if(line.startsWith("g ")) {
                    
                } else if(line.startsWith("o ")) {
                    if(object != null){
                        loadObjectData(object);
                        theModel.addObject(object);
                    }
                    object = new Model3D.ModelObject();
                    object.name = parseName(line);
                } else if (line.startsWith("v ")) { // Read in Vertex Data
                    processPointData(line, vertices);
                    verticesRead++;
                } else if (line.startsWith("vt ")) { // Read Texture Coordinates
                    processTexCoord(line, texCoords);
                    texCoordsRead++;
                } else if (line.startsWith("vn ")) { // Read Normal Coordinates
                    processPointData(line, normals);
                } else if (line.startsWith("f ")) { // Read Face Data
                    ProcessfData(line);
                } else if(line.startsWith("mtllib ")){
                    processMaterialLib(line);
                } else if(line.startsWith("usemtl ")) {
                    processMaterialType(line);
                }
                
            }
            br.close();
            if(object == null){
                object = new Model3D.ModelObject();
                loadObjectData(object);
                theModel.addObject(object);
            }
        } catch(IOException e) {
            System.out.println("Failed to find or read OBJ: " + stream);
            System.err.println(e);
        }
        
        theModel.setBoundingBox(this.constructBoundingBox());
        
        return theModel;
    }
    
    private void processPointData(String line, Vector<Model3D.Vector3f> points) {
        Model3D.Vector3f point = new Model3D.Vector3f();
        
        final String s[] = line.split("\\s+");
        
        point.x = Float.parseFloat(s[1]);
        point.y = Float.parseFloat(s[2]);
        point.z = Float.parseFloat(s[3]);
        
        points.add(point);
    }
    
    private String parseName(String line) {
        String name;
        
        final String s[] = line.split("\\s+");
        
        name = s[1];
        
        return name;
    }
    
    private Model3D.ModelObject initializeObject() {
        return new Model3D.ModelObject();
    }
    
    private void processTexCoord(String line, Vector<Model3D.TexCoord> tc) {
        Model3D.TexCoord coord = new Model3D.TexCoord();
        
        final String s[] = line.split("\\s+");
        
        coord.u = Float.parseFloat(s[1]);
        coord.v = Float.parseFloat(s[2]);
        
        tc.add(coord);
    }
    
    private float[] ProcessData(String read) {
        final String s[] = read.split("\\s+");
        return (ProcessFloatData(s)); //returns an array of processed float data
    }
    
    private float[] ProcessFloatData(String sdata[]) {
        float data[] = new float[sdata.length-1];
        for (int loop=0; loop < data.length; loop++) {
            data[loop] = Float.parseFloat(sdata[loop+1]);
        }
        return data; // return an array of floats
    }
    
    private void ProcessfData(String fread) {
        polyCount++;
        String s[] = fread.split("\\s+");
        if (fread.contains("//")) { // Pattern is present if obj has only v and vn in face data
            for (int loop=1; loop < s.length; loop++) {
                s[loop] = s[loop].replaceAll("//","/0/"); //insert a zero for missing vt data
            }
        }
        ProcessfIntData(s); // Pass in face data
    }
    
    private void ProcessfIntData(String sdata[]) {
        int vdata[] = new int[sdata.length-1];
        int vtdata[] = new int[sdata.length-1];
        int vndata[] = new int[sdata.length-1];
        Model3D.Face face = new Model3D.Face(sdata.length - 1);
        
        for (int loop = 1; loop < sdata.length; loop++) {
            String s = sdata[loop];
            String[] temp = s.split("/");
            face.vertIndex[loop-1] = Integer.valueOf(temp[0]) - 1 - verticesSoFar;
            
            if (temp.length > 1) { // we have v and vt data
                if(Integer.valueOf(temp[1]) > 0)
                    face.coordIndex[loop - 1] = Integer.valueOf(temp[1]) - 1 - texCoordsSoFar;
                else
                    face.coordIndex[loop - 1] = 0;
            }
        }
        
        faces.add(face);
    }
    
    /**
     * Loads all current mesh data into the object parameter.  The buffers are
     * cleared after the data is loaded so that subsequent data will be loaded
     * correctly into the next object
     *
     * @param object Container for 3D vertex data
     */
    private void loadObjectData(Model3D.ModelObject object) {
        object.faces = new Model3D.Face[faces.size()];
        object.normals = new Model3D.Vector3f[normals.size()];
        object.verts = new Model3D.Vector3f[vertices.size()];
        object.texVerts = new Model3D.TexCoord[texCoords.size()];
        
        if(faces.size() > 0)
            faces.toArray(object.faces);
        if(vertices.size() > 0)
            vertices.toArray(object.verts);
        if(normals.size() > 0)
            normals.toArray(object.normals);
        if(texCoords.size() > 0){
            texCoords.toArray(object.texVerts);
        }
        
        object.materialID = materialID;
        object.hasTexture = hasTexture;
        
        verticesSoFar = verticesRead;
        texCoordsSoFar = texCoordsRead;
        
        faces.clear();
        vertices.clear();
        normals.clear();
        
        theModel.addObject(object);
    }
    
    private void processMaterialLib(String mtlData) {
        String s[] = mtlData.split("\\s+");
        
        Model3D.Material mat = new Model3D.Material();
        
        InputStream stream = OBJLoader.class.getResourceAsStream(baseDir + s[1]);
        
        if(stream == null) {
            try {
                stream = new FileInputStream(baseDir + s[1]);
            } catch (FileNotFoundException ex) {
                ex.printStackTrace();
                return;
            }
        }
        loadMaterialFile(stream);
    }
    
    private void processMaterialType(String line) {
        String s[] = line.split("\\s+");
        
        materialID = -1;
        
        for(int i = 0; i < theModel.getNumberOfMaterials(); i++){
            Model3D.Material mat = theModel.getMaterial(i);
            
            
            if(mat.name.equals(s[1])){
                materialID = i;
                if(mat.file != null)
                    hasTexture = true;
                else
                    hasTexture = false;
                break;
            }
        }
        
        if(materialID == -1)
            materialID = 0;
    }
    
    private void setFaceRenderType() {
        final int vertexPerFace = theModel.getObject(0).faces[0].coordIndex.length;
        
        //final int temp [] = (int[]) fv.get(0);
        if ( vertexPerFace == 3) {
            faceFormat = RENDER_TRIANGLES; // The faces come in sets of 3 so we have triangular faces
            faceCount = 3;
        } else if (vertexPerFace == 4) {
            faceFormat = RENDER_QUADS; // The faces come in sets of 4 so we have quadrilateral faces
            faceCount = 4;
        } else {
            faceFormat = RENDER_POLYGONS; // Fall back to render as free form polygons
        }
    }
    
    public Model3D.BoundingBox constructBoundingBox() {
        float minX = Float.POSITIVE_INFINITY, maxX = Float.NEGATIVE_INFINITY;
        float minY = Float.POSITIVE_INFINITY, maxY = Float.NEGATIVE_INFINITY;
        float minZ = Float.POSITIVE_INFINITY, maxZ = Float.NEGATIVE_INFINITY;
        Model3D.BoundingBox boundingBox;
        
        
        Model3D.Vector3f point;
        
        for(int i = 0; i < theModel.getNumberOfObjects(); i++){
            Model3D.ModelObject object = theModel.getObject(i);
            
            if(object.verts == null){
                System.out.println("Verts should never be null");
                System.exit(1);
            }
            
            for(int j = 0; j < object.verts.length; j++){
                point = object.verts[j];
                if(point.x < minX)
                    minX = (float) point.x;
                else if(point.x > maxX)
                    maxX = (float) point.x;
                else if(point.y < minY)
                    minY = (float) point.y;
                else if(point.y > maxY)
                    maxY = (float) point.y;
                else if(point.z < minZ)
                    minZ = (float) point.z;
                else if(point.z > maxZ)
                    maxZ = (float) point.z;
            }
        }
        
        boundingBox = new Model3D.BoundingBox(minX, maxX, minY, maxY, minZ, maxZ);
        
        return boundingBox;
    }
    
    public Model3D.Material loadMaterialFile(InputStream stream) {
        Model3D.Material mat = null;
        int texId = 0;
        
        try {
            BufferedReader br = new BufferedReader(new InputStreamReader(stream));
            String line;
            
            while((line = br.readLine()) != null){
                
                String parts[] = line.trim().split("\\s+");
                
                if(parts[0].equals("newmtl")){
                    if(mat != null)
                        theModel.addMaterial(mat);
                    
                    mat = new Model3D.Material();
                    mat.name = parts[1];
                    mat.textureId = texId++;
                    
                } else if(parts[0].equals("Ks"))
                    mat.specularColor = parseColor(line);
                else if(parts[0].equals("Ns"))
                    mat.shininess = Float.valueOf(parts[1]);
                else if(parts[0].equals("d"))
                    ;
                else if(parts[0].equals("illum"))
                    ;
                else if(parts[0].equals("Ka"))
                    mat.ambientColor = parseColor(line);
                else if(parts[0].equals("Kd"))
                    mat.diffuseColor = parseColor(line);
                else if(parts[0].equals("map_Kd"))
                    mat.file = baseDir + parts[1];
                else if(parts[0].equals("map_Ka"))
                    mat.file = baseDir + parts[1];
            }
            
            br.close();
            theModel.addMaterial(mat);
            
        } catch (FileNotFoundException ex) {
            ex.printStackTrace();
        } catch (IOException ioe) {
            ioe.printStackTrace();
        }
        return mat;
    }
    
    private String parseMaterialName(String line) {
        String s[] = line.split("\\s+");
        
        return s[1];
    }
    
    private Color parseColor(String line) {
        String parts[] = line.trim().split("\\s+");
        
        Color color = new Color(Float.valueOf(parts[1]),
                Float.valueOf(parts[2]),Float.valueOf(parts[3]));
        
        return color;
    }
    
    public int getPolycount() {
        return polyCount;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线一区二区三区四区| 不卡电影一区二区三区| 亚洲乱码国产乱码精品精的特点| 久久久久久免费毛片精品| 2020国产精品自拍| 欧美激情在线一区二区| 一区精品在线播放| 亚洲人吸女人奶水| 性久久久久久久久久久久| 午夜一区二区三区视频| 日韩和的一区二区| 久久精品国产亚洲aⅴ| 精品一区二区三区在线视频| 久久精品国产久精国产| 国产成人午夜片在线观看高清观看| 激情综合色丁香一区二区| 国产精品白丝jk白祙喷水网站| 高清不卡在线观看| 91丝袜美腿高跟国产极品老师 | 日韩欧美国产综合一区 | 99久久99久久精品免费观看| 欧美老肥妇做.爰bbww视频| 欧美一区二区三区四区视频 | 国产二区国产一区在线观看| 91在线国产福利| 欧美日韩不卡一区| 久久免费的精品国产v∧| 亚洲人成小说网站色在线| 丝袜诱惑亚洲看片| 风间由美一区二区三区在线观看 | 国产成人在线观看免费网站| 99精品欧美一区二区三区小说| 色吧成人激情小说| 欧美va天堂va视频va在线| 国产精品福利一区二区三区| 爽好久久久欧美精品| 成人午夜激情视频| 在线播放视频一区| 国产精品福利在线播放| 久久精品国产亚洲5555| 欧美亚洲国产bt| 久久精品一区蜜桃臀影院| 亚洲一区二区精品视频| 国产乱国产乱300精品| 色综合天天视频在线观看 | 国产成人av资源| 欧美日韩激情一区二区| 国产欧美日韩在线| 免费不卡在线视频| 在线观看日韩电影| 亚洲国产精品99久久久久久久久| 国内精品伊人久久久久av影院 | www.久久精品| 精品国精品国产尤物美女| 亚洲图片自拍偷拍| 91视视频在线直接观看在线看网页在线看 | 国产成人午夜视频| 欧美不卡123| 日韩精品一二区| 91成人免费在线| 亚洲视频综合在线| 成人禁用看黄a在线| 久久一夜天堂av一区二区三区 | 中文字幕一区二区视频| 精品一区二区三区免费观看| 欧美日高清视频| 香港成人在线视频| 欧美在线视频全部完| 亚洲欧美日韩小说| 97久久超碰国产精品| 天天亚洲美女在线视频| 欧美日韩日日夜夜| 亚洲国产精品久久人人爱蜜臀| 色就色 综合激情| 一区二区三区精品| 欧美性生活大片视频| 亚洲线精品一区二区三区八戒| 色狠狠综合天天综合综合| 亚洲免费在线观看| 色综合天天综合网天天看片| 亚洲日本青草视频在线怡红院 | 久久久99精品久久| 国产精品小仙女| 日本一二三四高清不卡| caoporm超碰国产精品| 最新热久久免费视频| 一本大道av一区二区在线播放| 一区二区三区精品视频| 欧美精品三级在线观看| 蜜桃在线一区二区三区| 久久网站最新地址| 91丝袜美腿高跟国产极品老师| 一区二区三区欧美激情| 欧美一区二区三区性视频| 极品少妇一区二区| 国产精品热久久久久夜色精品三区| www.亚洲国产| 午夜精品一区二区三区三上悠亚| 欧美一级高清大全免费观看| 国产精选一区二区三区| 国产精品成人免费| 91精品中文字幕一区二区三区| 国产麻豆9l精品三级站| 中文字幕一区二区三区不卡在线 | 欧美一区二区三区在线电影| 国模少妇一区二区三区| 亚洲欧美日韩电影| 欧美一区二区三区在线视频| 成人丝袜视频网| 亚洲成人资源网| 国产欧美精品一区aⅴ影院| 欧美吻胸吃奶大尺度电影| 捆绑调教美女网站视频一区| 亚洲免费观看高清| 国产日韩精品一区二区三区 | 色综合久久久久久久| 麻豆精品久久精品色综合| 国产精品系列在线| 日韩欧美精品在线视频| 色综合久久66| 丁香激情综合五月| 日本成人在线电影网| 亚洲乱码精品一二三四区日韩在线| 91精品国产福利| 欧洲一区在线电影| 成人app网站| 国产原创一区二区| 日韩电影在线观看电影| 亚洲精品欧美在线| 欧美国产丝袜视频| 日韩精品一区二区三区swag| 色8久久精品久久久久久蜜| 国产jizzjizz一区二区| 美女视频黄 久久| 午夜精品久久久久久不卡8050| 中文字幕精品在线不卡| ww久久中文字幕| 日韩一级片网站| 国产精品久久看| 久久综合狠狠综合久久综合88| 欧美军同video69gay| 欧美日韩在线观看一区二区| www.亚洲色图| 91日韩精品一区| 99国产精品久久| 成年人网站91| 91在线云播放| 日本道免费精品一区二区三区| 99久久精品99国产精品| 成人免费毛片a| av一区二区三区| voyeur盗摄精品| 99久久99精品久久久久久| 93久久精品日日躁夜夜躁欧美| 成人h动漫精品一区二| 国产成人av电影在线播放| 国产在线精品一区二区不卡了| 激情欧美一区二区三区在线观看| 久久精品国产99国产| 精久久久久久久久久久| 国产乱对白刺激视频不卡| 懂色av一区二区在线播放| 国产成人在线电影| aaa亚洲精品一二三区| 色诱亚洲精品久久久久久| 一本久久a久久免费精品不卡| 在线观看91视频| 日韩免费高清av| 国产日韩欧美亚洲| 中文字幕一区二区三区乱码在线| 亚洲天堂福利av| 亚洲bdsm女犯bdsm网站| 看国产成人h片视频| 成人美女视频在线观看| 欧美一a一片一级一片| 91精品婷婷国产综合久久| 国产午夜精品一区二区| 一区二区三区视频在线观看| 日韩黄色小视频| av在线不卡观看免费观看| 欧美性淫爽ww久久久久无| 日韩欧美高清在线| 日韩一区有码在线| 日本美女一区二区| 99久久精品国产观看| 日韩一区国产二区欧美三区| 久久精品一区二区三区不卡牛牛| 一区二区三区四区中文字幕| 免费观看日韩av| 99国产精品国产精品久久| 日韩视频不卡中文| 亚洲伦理在线精品| 国产精品888| 欧美精品自拍偷拍| 国产精品久99| 看国产成人h片视频| 欧洲国内综合视频| 亚洲欧洲三级电影| 精品在线播放午夜| 欧美日韩mp4|