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

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

?? mofang.java

?? java編寫的3D魔方源代碼
?? JAVA
?? 第 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一区二区三区免费野_久草精品视频
婷婷六月综合网| 欧美国产日本韩| 日韩和的一区二区| 欧美一区二区三区白人| 激情文学综合网| 久久精品人人爽人人爽| 不卡av在线免费观看| 亚洲另类在线一区| 欧美精品久久一区二区三区| 美女网站视频久久| 久久久精品黄色| 91免费看`日韩一区二区| 一区二区免费看| 日韩免费观看2025年上映的电影| 蜜臀av性久久久久蜜臀aⅴ四虎| 精品少妇一区二区三区在线视频| 国产成人午夜视频| 亚洲一区二区在线观看视频| 91麻豆精品91久久久久久清纯| 精品一区二区三区免费毛片爱| 国产精品免费看片| 欧美日韩久久一区| 老司机精品视频导航| 国产精品理论在线观看| 欧美中文字幕一二三区视频| 精品一区二区三区在线视频| 中文字幕在线一区二区三区| 欧美电影一区二区三区| 国产成人综合视频| 亚洲成av人综合在线观看| 久久夜色精品一区| 在线看不卡av| 国产99精品国产| 亚洲成人免费av| 国产精品国产三级国产aⅴ中文 | 亚洲免费观看视频| 日韩欧美激情四射| 色综合久久六月婷婷中文字幕| 日本91福利区| 亚洲欧美日韩久久精品| 欧美成人三级电影在线| 欧美在线一区二区| 国产成人亚洲综合a∨猫咪| 三级不卡在线观看| 亚洲品质自拍视频| 日本一区二区高清| 欧美videossexotv100| 91福利视频网站| 成人视屏免费看| 久久激情五月婷婷| 日韩二区三区四区| 亚洲国产aⅴ天堂久久| 国产精品国产三级国产普通话三级 | 久久精品无码一区二区三区| 欧美久久久久久蜜桃| 在线看不卡av| 91啦中文在线观看| 成人性生交大片免费看中文网站| 蜜桃视频第一区免费观看| 午夜欧美视频在线观看| 一区二区三区在线不卡| 自拍偷拍国产精品| 亚洲欧洲色图综合| 国产精品每日更新在线播放网址| 精品久久久久久久久久久久久久久久久 | 69成人精品免费视频| 欧美无砖专区一中文字| 91麻豆蜜桃一区二区三区| 国产成人综合在线观看| 国产成人综合在线播放| 成人一区二区三区| 成人久久视频在线观看| 成人久久视频在线观看| 丁香婷婷综合五月| 成人免费高清视频在线观看| 国产一区二区三区四区在线观看| 久久电影国产免费久久电影 | 亚洲国产综合在线| 亚洲午夜精品在线| 亚洲成在线观看| 视频一区二区三区在线| 日韩电影在线免费| 蜜臀va亚洲va欧美va天堂| 美女脱光内衣内裤视频久久影院| 麻豆精品一区二区综合av| 久久99热狠狠色一区二区| 国产伦理精品不卡| 福利一区在线观看| 91女厕偷拍女厕偷拍高清| 欧美视频在线不卡| 日韩欧美不卡一区| 久久久精品日韩欧美| 国产精品国产自产拍在线| 亚洲欧美日韩国产成人精品影院| 亚洲免费观看高清| 婷婷久久综合九色综合绿巨人| 毛片av一区二区| 成人在线综合网| 91精彩视频在线观看| 欧美疯狂性受xxxxx喷水图片| 精品国产一区二区亚洲人成毛片| 久久久综合网站| 一区二区三区四区视频精品免费 | 制服丝袜亚洲色图| 精品国产网站在线观看| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 午夜精品福利视频网站| 免费在线观看视频一区| 国产aⅴ精品一区二区三区色成熟| 不卡在线观看av| 6080yy午夜一二三区久久| 久久久青草青青国产亚洲免观| 亚洲欧洲性图库| 奇米在线7777在线精品| 成人黄色在线网站| 欧美一级在线视频| 国产精品福利一区二区三区| 亚洲va国产天堂va久久en| 国产精品一区二区久久不卡| 欧美亚洲日本一区| 精品1区2区在线观看| 亚洲欧美激情在线| 久久国产夜色精品鲁鲁99| 色婷婷精品大在线视频| 2021中文字幕一区亚洲| 亚洲成人激情综合网| 国产不卡一区视频| 91精品国产综合久久精品 | 精品人在线二区三区| 亚洲欧美另类久久久精品| 国内外精品视频| 欧美丝袜丝交足nylons| 欧美韩国日本综合| 青青草国产精品97视觉盛宴 | 日韩不卡一区二区| 91老司机福利 在线| 国产欧美一区二区精品仙草咪| 亚洲第一主播视频| 91免费精品国自产拍在线不卡| 久久在线免费观看| 日本va欧美va瓶| 欧美日韩国产高清一区二区 | 国产女人aaa级久久久级| 午夜亚洲福利老司机| 91麻豆精品在线观看| 国产精品网曝门| 国产成人av自拍| 久久精品亚洲麻豆av一区二区 | 97久久精品人人爽人人爽蜜臀| 337p日本欧洲亚洲大胆色噜噜| 亚洲成人资源网| 欧美性大战xxxxx久久久| 亚洲色图丝袜美腿| 99久久精品一区二区| 国产精品久久久久一区二区三区| 极品少妇xxxx精品少妇偷拍| 91精品国产色综合久久| 亚洲第一av色| 欧美精品 国产精品| 亚洲午夜激情av| 欧美丝袜丝交足nylons图片| 亚洲最色的网站| 91久久久免费一区二区| 一区二区三区四区国产精品| 色国产综合视频| 亚洲综合精品久久| 欧美在线999| 亚洲高清免费观看| 欧美色大人视频| 午夜激情一区二区| 制服丝袜亚洲播放| 麻豆精品在线观看| 久久久久国产精品麻豆ai换脸 | jiyouzz国产精品久久| 亚洲国产高清aⅴ视频| 99精品欧美一区二区三区小说| 中文字幕欧美一| 欧美专区日韩专区| 婷婷丁香激情综合| 日韩欧美中文字幕一区| 韩国av一区二区三区四区 | 精品国产乱码久久久久久老虎| 免费观看在线综合色| 欧美成人性福生活免费看| 国产综合色产在线精品| 国产日韩精品视频一区| 91美女视频网站| 香蕉乱码成人久久天堂爱免费| 在线播放日韩导航| 国内一区二区在线| 1区2区3区国产精品| 欧美日本在线播放| 精品在线观看免费| 中文字幕在线观看不卡| 欧美日韩精品一二三区| 国产一区二三区好的| 亚洲精品中文字幕乱码三区| 777xxx欧美| 成人精品国产福利| 爽好久久久欧美精品|