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

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

?? java-codes.txt

?? 自己改進的魔方源碼
?? TXT
?? 第 1 頁 / 共 5 頁
字號:
//存為MoFang.java

import java.applet.Applet ;
import java.awt.*;
import com.sun.j3d.utils.applet.MainFrame ;
import java.awt.BorderLayout ;
import com.sun.j3d.utils.universe.SimpleUniverse ;
import javax.media.j3d.*;
import javax.vecmath.*;
import com.sun.j3d.utils.behaviors.mouse.*;
import com.sun.j3d.utils.behaviors.keyboard.*;
import com.sun.j3d.utils.picking.behaviors.*;
import com.sun.j3d.utils.geometry.*;
import com.sun.j3d.utils.image.TextureLoader ;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
import javax.swing.JFrame.*;
import javax.swing.*;

class mySimpleUniverse extends Applet
{
    BranchGroup createSceneGraph(Canvas3D canvas)

    {


        //System.out.print("**1**");

        //創建變換組,無用的t3D
        Transform3D t3d=new Transform3D();
        TransformGroup trans=new TransformGroup(t3d);
        trans.setCapability(TransformGroup.ALLOW_TRANSFORM_WRITE);
        trans.setCapability(TransformGroup.ALLOW_TRANSFORM_READ);
        //創建分枝組
        BranchGroup objRoot=new BranchGroup();

        //測試
        //SomeShape3D.book3D( this, trans);
        SomeShape3D.addText3DDonghua(trans,"魔方",new Point3f(-7.0f,6.0f,6.0f),0.1f,new Color3f(1.0f,0.0f,0.0f),1);

        //初始化數據結構
        System.out.println("\n\n載入方塊,并向變換組中加入每個方塊的坐標系和方塊...");
        for(int i=0;i<=2;i++)
        for(int j=0;j<=2;j++)
        for(int k=0;k<=2;k++)
        {
         int[] p;
         p=Position.getPxyzFromPositionAy(i,j,k,MoFang.positionArray);
            MoFang.blockArray[i][j][k]=new Block(i,j,k,p[0],p[1],p[2],trans,t3d,objRoot,this);
        }
        System.out.println("加入每個方塊的坐標系和方塊,完成.\n");

        //創建大坐標軸,自動加到主坐標系
        SomeShape3D.zuoBiaoZhuBigXShape3D(trans);
        SomeShape3D.zuoBiaoZhuBigYShape3D(trans);
        SomeShape3D.zuoBiaoZhuBigZShape3D(trans);

        //創建邊界對象
        BoundingSphere bounds=new BoundingSphere(new Point3d(0.0,0.0,0.0),100);

        //創建鼠標pick行為,加到分支組objRoot
        PickRotateBehavior pickRotate=new PickRotateBehavior(objRoot,canvas,bounds);
        PickTranslateBehavior pickTranslate=new PickTranslateBehavior(objRoot,canvas,bounds);
        PickZoomBehavior pickZoom=new PickZoomBehavior(objRoot,canvas,bounds);
        //objRoot.addChild(pickRotate);
        objRoot.addChild(pickTranslate);
        //objRoot.addChild(pickZoom);

        //創建鼠標旋轉行為
        MouseRotate behavior=new MouseRotate();
        behavior.setTransformGroup(trans);
        behavior.setSchedulingBounds(bounds);

        //創建鼠標平移行為
        //MouseTranslate myMouseRotate=new MouseTranslate();
        //myMouseRotate.setTransformGroup(trans);
        //myMouseRotate.setSchedulingBounds(bounds);

        //創建鼠標縮放行為
        MouseZoom myMouseZoom=new MouseZoom();
        myMouseZoom.setTransformGroup(trans);
        myMouseZoom.setSchedulingBounds(bounds);

        //創建鍵盤默認行為
        KeyNavigatorBehavior keyNavBeh=new KeyNavigatorBehavior(trans);
        keyNavBeh.setSchedulingBounds(bounds);
        objRoot.addChild(keyNavBeh);

        //白色背景
        Background bg=new Background(new Color3f(0.0f,0.0f,0.0f));
        bg.setApplicationBounds(bounds);
        objRoot.addChild(bg);

        //創建帶材質的背景
        //TextureLoader bgTexture=new TextureLoader("bg3.jpg",this);
        //Background bg=new Background(bgTexture.getImage());
        //bg.setApplicationBounds(bounds);
        //trans.addChild(shape1);//3D物體 加到 變換組
        //trans.addChild(shape2);//3D物體 加到 變換組
        objRoot.addChild(trans);
        //變換組 加到 分枝組
        objRoot.addChild(behavior);
        //鼠標行為  加到 分枝組
        //objRoot.addChild(myMouseRotate);
        //objRoot.addChild(myMouseZoom);
        //objRoot.addChild(bg);//背景 加到 分枝組
        //編譯
        objRoot.compile();
        //回送創建好的帶3D物體的分枝組
        return objRoot ;

    }
    mySimpleUniverse()
    {
        //創建帶控制的畫布
        GraphicsConfiguration config=SimpleUniverse.getPreferredConfiguration();
        Canvas3D c=new Canvas3D(config);
        //創建以畫布為依托的簡單場景圖對象,沒有多個Locale
        SimpleUniverse u=new SimpleUniverse(c);
        u.getViewingPlatform().setNominalViewingTransform();
        //創建分支組對象
        BranchGroup scene=createSceneGraph(c);
        //組裝,分支組 對象加到 場景圖
        u.addBranchGraph(scene);

        //帶場景圖的畫布 加到 本applet中
        setLayout(new BorderLayout());
        add("Center",c);
    }

    //測試碼
    //public static void main(String aregs[])
    //{new MainFrame(new mySimpleUniverse(),200,200);//加applet到應用程序界面
    //}
}

class SomeShape3D
{
    public static float zuoBiaoZhouSmallDingDian=0.09f;//小坐標頂點位置
    public static float zuoBiaoZhouSmallDingXi=0.02f;//小坐標頂點傘的半徑
    public static float zuoBiaoZhouSmallDingChang=0.07f;//小坐標頂點傘的長度
    public static float zuoBiaoZhouSmallWeiDian=-0.09f;//小坐標尾巴的位置
    public static float zuoBiaoZhouBigDingDian=1.0f;//大坐標頂點位置
    public static float zuoBiaoZhouBigDingXi=0.04f;//大坐標頂點傘的半徑
    public static float zuoBiaoZhouBigDingChang=0.8f;//大坐標頂點傘的長度
    public static float zuoBiaoZhouBigWeiDian=-1.0f;//大坐標尾巴的位置
    public static float fangKuaiBanJing=0.18f;//每個方塊的半徑
    public static void zuoBiaoZhuBigXShape3D(TransformGroup trans)
    {


        //創建大坐標軸對象

        int i ;
        float x1,x2,y1,y2,z1,z2 ;

         SomeShape3D.addText3DDonghua(trans,"X",new Point3f(zuoBiaoZhouBigDingDian*10,0.0f,0.0f),0.1f,Block.mianColor[0],0);

        Point3f[]vert=new Point3f[41];
        Color3f[]colors=new Color3f[41];
        for(i=0;i<27;i++)
        {
            if(i==0)
            {
                vert[i]=new Point3f(zuoBiaoZhouBigDingDian,0.0f,0.0f);
                colors[i]=Block.mianColor[0];
            }
            else
            {
                z1=(float)(zuoBiaoZhouBigDingXi*Math.cos(i*2*Math.PI/25));
                x1=zuoBiaoZhouBigDingChang;
                y1=(float)(zuoBiaoZhouBigDingXi*Math.sin(i*2*Math.PI/25));
                vert[i]=new Point3f(x1,y1,z1);
                colors[i]=Block.mianColor[0];
            }
        }

        for(i=0;i<14;i++)
        {
            if(i==0)
            {
                vert[27+i]=new Point3f(zuoBiaoZhouBigDingDian,0.0f,0.0f);
                colors[27+i]=Block.mianColor[0];
            }
            else
            {
                z1=(float)(0.01f*Math.cos(i*2*Math.PI/12));
                x1=zuoBiaoZhouBigWeiDian ;
                y1=(float)(0.01f*Math.sin(i*2*Math.PI/12));
                vert[27+i]=new Point3f(x1,y1,z1);
                colors[27+i]=Block.mianColor[1];
            }
        }
        int count[]=new int[2];
        count[0]=27 ;
        count[1]=14 ;

        TriangleFanArray tri=new TriangleFanArray(
        vert.length,
        TriangleFanArray.COORDINATES|TriangleStripArray.COLOR_3,
        count
        );
        tri.setCoordinates(0,vert);
        tri.setColors(0,colors);


        Appearance app=new Appearance();

        PolygonAttributes polyAttrib=new PolygonAttributes();
        polyAttrib.setCullFace(PolygonAttributes.CULL_NONE);
        //polyAttrib.setPolygonMode(PolygonAttributes.POLYGON_LINE);
        app.setPolygonAttributes(polyAttrib);

        Shape3D shape=new Shape3D(tri,app);
        System.out.print("zuoBiaoZhuBigX 創建 完成\n");

        trans.addChild(shape);


        //到這里,大坐標軸對象創建完成


    }
    public static   void zuoBiaoZhuBigYShape3D(TransformGroup trans)
    {


        //創建大坐標軸對象

        int i ;
        float x1,x2,y1,y2,z1,z2 ;

        SomeShape3D.addText3DDonghua(trans,"Y",new Point3f(-1.0f,zuoBiaoZhouBigDingDian*10,0.0f),0.1f,Block.mianColor[2],0);

        Point3f[]vert=new Point3f[41];
        Color3f[]colors=new Color3f[41];
        for(i=0;i<27;i++)
        {
            if(i==0)
            {
                vert[i]=new Point3f(0.0f,zuoBiaoZhouBigDingDian,0.0f);
                colors[i]=Block.mianColor[2];
            }
            else
            {
                x1=(float)(zuoBiaoZhouBigDingXi*Math.cos(i*2*Math.PI/25));
                y1=zuoBiaoZhouBigDingChang;
                z1=(float)(zuoBiaoZhouBigDingXi*Math.sin(i*2*Math.PI/25));
                vert[i]=new Point3f(x1,y1,z1);
                colors[i]=Block.mianColor[2];
            }
        }

        for(i=0;i<14;i++)
        {
            if(i==0)
            {
                vert[27+i]=new Point3f(0.0f,zuoBiaoZhouBigDingDian,0.0f);
                colors[27+i]=Block.mianColor[2];
            }
            else
            {
                x1=(float)(0.01f*Math.cos(i*2*Math.PI/12));
                y1=zuoBiaoZhouBigWeiDian ;
                z1=(float)(0.01f*Math.sin(i*2*Math.PI/12));
                vert[27+i]=new Point3f(x1,y1,z1);
                colors[27+i]=Block.mianColor[3];
            }
        }
        int count[]=new int[2];
        count[0]=27 ;
        count[1]=14 ;

        TriangleFanArray tri=new TriangleFanArray(
        vert.length,
        TriangleFanArray.COORDINATES|TriangleStripArray.COLOR_3,
        count
        );
        tri.setCoordinates(0,vert);
        tri.setColors(0,colors);
        Appearance app=new Appearance();

        PolygonAttributes polyAttrib=new PolygonAttributes();
        polyAttrib.setCullFace(PolygonAttributes.CULL_NONE);
        //polyAttrib.setPolygonMode(PolygonAttributes.POLYGON_LINE);
        app.setPolygonAttributes(polyAttrib);

        Shape3D shape=new Shape3D(tri,app);

        System.out.print("zuoBiaoZhuBigY 創建 完成\n");

        trans.addChild(shape);


        //到這里,大坐標軸對象創建完成


    }

    public static  void  zuoBiaoZhuBigZShape3D(TransformGroup trans)
    {


        //創建大坐標軸對象

        int i ;
        float x1,x2,y1,y2,z1,z2 ;
 SomeShape3D.addText3DDonghua(trans,"Z",new Point3f(-1.0f,0.0f,zuoBiaoZhouBigDingDian*10),0.1f,Block.mianColor[4],0);

        Point3f[]vert=new Point3f[41];
        Color3f[]colors=new Color3f[41];
        for(i=0;i<27;i++)
        {
            if(i==0)
            {
                vert[i]=new Point3f(0.0f,0.0f,zuoBiaoZhouBigDingDian);
                colors[i]=Block.mianColor[4];
            }
            else
            {
                y1=(float)(zuoBiaoZhouBigDingXi*Math.cos(i*2*Math.PI/25));
                z1=zuoBiaoZhouBigDingChang;
                x1=(float)(zuoBiaoZhouBigDingXi*Math.sin(i*2*Math.PI/25));
                vert[i]=new Point3f(x1,y1,z1);
                colors[i]=Block.mianColor[4];
            }
        }

        for(i=0;i<14;i++)
        {
            if(i==0)
            {
                vert[27+i]=new Point3f(0.0f,0.0f,zuoBiaoZhouBigDingDian);
                colors[27+i]=Block.mianColor[4];
            }
            else
            {
                y1=(float)(0.01f*Math.cos(i*2*Math.PI/12));
                z1=zuoBiaoZhouBigWeiDian ;
                x1=(float)(0.01f*Math.sin(i*2*Math.PI/12));
                vert[27+i]=new Point3f(x1,y1,z1);
                colors[27+i]=Block.mianColor[5];
            }
        }
        int count[]=new int[2];
        count[0]=27 ;
        count[1]=14 ;

        TriangleFanArray tri=new TriangleFanArray(
        vert.length,
        TriangleFanArray.COORDINATES|TriangleStripArray.COLOR_3,
        count
        );
        tri.setCoordinates(0,vert);
        tri.setColors(0,colors);
        Appearance app=new Appearance();

        PolygonAttributes polyAttrib=new PolygonAttributes();
        polyAttrib.setCullFace(PolygonAttributes.CULL_NONE);
        //polyAttrib.setPolygonMode(PolygonAttributes.POLYGON_LINE);
        app.setPolygonAttributes(polyAttrib);

        Shape3D shape=new Shape3D(tri,app);
        System.out.print("zuoBiaoZhuBigZ 創建 完成\n");

        trans.addChild(shape);
        //到這里,大坐標軸對象創建完成
    }
    public static  void  zuoBiaoZhuSmallXShape3D(TransformGroup trans)
    {
        //創建小坐標軸對象

        int i ;
        float x1,x2,y1,y2,z1,z2 ;

        Point3f[]vert=new Point3f[41];
        Color3f[]colors=new Color3f[41];
        for(i=0;i<27;i++)
        {
            if(i==0)
            {
                vert[i]=new Point3f(zuoBiaoZhouSmallDingDian,0.0f,0.0f);
                colors[i]=Block.mianColor[0];
            }
            else
            {
                z1=(float)(zuoBiaoZhouSmallDingXi*Math.cos(i*2*Math.PI/25));
                x1=zuoBiaoZhouSmallDingChang ;
                y1=(float)(zuoBiaoZhouSmallDingXi*Math.sin(i*2*Math.PI/25));
                vert[i]=new Point3f(x1,y1,z1);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产色产综合色产在线视频| 一区二区三区日韩精品| 91精品国产色综合久久不卡电影| 色哟哟一区二区在线观看| 成人午夜视频网站| 成人一道本在线| 成人小视频在线| 成人性生交大片| av电影天堂一区二区在线观看| 成人综合在线视频| www.亚洲人| 99国产精品国产精品毛片| 99精品久久99久久久久| 色综合久久中文综合久久97| 色欧美片视频在线观看| 91在线porny国产在线看| 色婷婷综合激情| 欧洲精品中文字幕| 欧美一区二区视频观看视频| 日韩免费在线观看| 日本一区二区三区国色天香| 国产精品人妖ts系列视频| 国产精品成人午夜| 伊人婷婷欧美激情| 亚洲va在线va天堂| 裸体一区二区三区| 国产激情一区二区三区桃花岛亚洲| 国产精品77777| 色综合久久中文字幕综合网| 欧美在线一二三四区| 制服丝袜亚洲精品中文字幕| 精品国产免费人成电影在线观看四季 | 国产精品久久久久四虎| 中文字幕在线观看不卡视频| 亚洲欧美一区二区视频| 一级精品视频在线观看宜春院| 亚洲高清一区二区三区| 奇米在线7777在线精品| 成人一道本在线| 欧洲精品在线观看| 欧美v日韩v国产v| 中文字幕在线播放不卡一区| 亚洲va国产va欧美va观看| 老司机一区二区| 99久久99精品久久久久久| 欧美日韩国产成人在线91| 精品日韩一区二区| 亚洲免费视频中文字幕| 亚洲成人免费看| 国产在线不卡视频| 色综合久久综合网欧美综合网 | 国产欧美日韩综合精品一区二区 | 国产福利一区二区三区视频在线| 色婷婷亚洲婷婷| 日韩一区二区三区四区| 国产精品区一区二区三区| 亚洲成av人片在线观看| 国产一区二区成人久久免费影院| 91免费观看视频在线| 日韩精品一区二区三区视频| 亚洲视频一区二区在线| 免费成人性网站| 日本高清不卡一区| 久久久久久电影| 石原莉奈一区二区三区在线观看| 丁香亚洲综合激情啪啪综合| 91精品免费观看| 亚洲理论在线观看| 国产乱码字幕精品高清av| 欧美日韩激情一区二区| 国产精品久久久久久户外露出 | 久久99精品久久久久久动态图| 99精品视频在线观看| 精品乱码亚洲一区二区不卡| 亚洲综合在线视频| 成人午夜在线播放| 久久综合成人精品亚洲另类欧美 | 欧美丰满少妇xxxxx高潮对白| 国产三级一区二区三区| 美女视频免费一区| 精品视频色一区| 亚洲激情自拍视频| 99精品视频在线免费观看| 久久久www免费人成精品| 日日噜噜夜夜狠狠视频欧美人 | 99精品偷自拍| 国产日韩精品视频一区| 蜜臀99久久精品久久久久久软件| 欧美午夜精品久久久| 亚洲视频在线一区二区| 高清免费成人av| 久久亚洲一级片| 蓝色福利精品导航| 日韩一区国产二区欧美三区| 亚洲成人动漫在线免费观看| 色激情天天射综合网| 国产精品成人免费精品自在线观看| 国产精品一区二区在线播放| 精品久久久久久久久久久久久久久| 午夜激情一区二区| 欧美色倩网站大全免费| 亚洲精品视频在线观看免费| 97成人超碰视| 中文字幕综合网| 色香蕉成人二区免费| 亚洲精品水蜜桃| 在线观看日韩高清av| 亚洲午夜在线电影| 欧美偷拍一区二区| 视频一区二区中文字幕| 91精品国产麻豆| 久久99深爱久久99精品| 精品福利一区二区三区| 国产在线播放一区| 欧美国产综合色视频| www.欧美亚洲| 亚洲色大成网站www久久九九| 日本韩国一区二区三区视频| 亚洲精品伦理在线| 欧美日韩久久一区| 美女网站在线免费欧美精品| 日韩欧美国产一区二区在线播放 | 欧美日韩综合不卡| 蜜臀av性久久久久蜜臀aⅴ | 看片的网站亚洲| 久久综合久久综合亚洲| 风间由美中文字幕在线看视频国产欧美| 久久精品亚洲一区二区三区浴池| 国产成人自拍高清视频在线免费播放| 久久精品一区二区三区av| 成人免费高清在线| 一区二区三区 在线观看视频| 欧美综合视频在线观看| 三级精品在线观看| 久久久亚洲午夜电影| 成人看片黄a免费看在线| 亚洲人精品一区| 欧美色网站导航| 国产呦精品一区二区三区网站| 国产精品久久久久婷婷二区次| 欧美视频一区二区在线观看| 精品一区中文字幕| 亚洲天堂网中文字| 日韩一级视频免费观看在线| 国产98色在线|日韩| 亚洲尤物在线视频观看| 欧美成人精品1314www| 成人av在线播放网站| 亚洲高清免费观看 | 日韩精品五月天| 久久久久久99精品| 欧美天堂一区二区三区| 国产精品中文欧美| 一区二区久久久久久| 欧美精品一区二区久久久 | 久久亚洲二区三区| 91福利国产精品| 精久久久久久久久久久| 亚洲激情第一区| 日韩免费电影一区| 欧洲人成人精品| 高清不卡在线观看av| 午夜国产精品影院在线观看| 欧美激情一二三区| 欧美电影免费观看高清完整版 | 国产日韩欧美一区二区三区乱码| 色视频一区二区| 韩国精品久久久| 亚洲二区在线观看| 国产精品天美传媒沈樵| 欧美一级一级性生活免费录像| 99久精品国产| 国产永久精品大片wwwapp | 欧美精品在线视频| www.成人网.com| 久久精品二区亚洲w码| 亚洲电影激情视频网站| 国产精品美女视频| 精品国产露脸精彩对白| 欧美性欧美巨大黑白大战| 成人av网址在线| 国产一区二区三区在线观看免费视频 | 国产精品996| 蜜臀久久99精品久久久画质超高清| 亚洲精品欧美在线| 国产精品视频九色porn| 欧美va亚洲va香蕉在线| 欧美日韩亚洲国产综合| 99久久国产综合精品色伊| 国产精品原创巨作av| 美国毛片一区二区| 奇米在线7777在线精品| 午夜精品久久久| 一区二区三区四区精品在线视频| 国产精品女人毛片| 国产调教视频一区| 久久久久久一级片| 欧美不卡一二三| 91精品国产91久久综合桃花| 欧美色偷偷大香|