PLM之家精品课程培训,联系电话:18301858168 QQ: 939801026

  • NX二次开培训

    NX二次开培训

    适合初级入门或想深入了解二次开发的工程师,本培训结合ufun,NXOpen C++,大量的实例及官方内部的开发技术对于老鸟也值得借鉴!.

    NX CAM二次开发培训报名 NX二次开发基础培训报名
  • PLM之家Catia CAA二次开发培训

    Catia二次开发培训

    Catia二次开发的市场大,这方面开发人才少,难度大。所以只要你掌握了开发,那么潜力巨大,随着时间的积累,你必将有所用武之地!

  • PLM之Teamcenter最佳学习方案

    Teamcenter培训

    用户应用基础培训,管理员基础培训,管理员高级培训,二次开发培训应有尽有,只要你感兴趣肯学习,专业多年经验大师级打造!

  • PLM之Tecnomatix制造领域培训

    Tecnomatix培训

    想了解制造领域数字化吗?想了解工厂,生产线设计吗?数字化双胞胎,工业4.0吗?我们的课程虚位以待!

PLM之家PLMHome-国产软件践行者

[前端框架] Threejs 基于webGL的3D开发神器

[复制链接]

2019-9-1 18:45:09 2540 0

admin 发表于 2019-9-1 18:45:09 |阅读模式

admin 楼主

2019-9-1 18:45:09

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x
* b  ^# y) }  U4 ]# E6 s# H
5 O: V4 t' ^; @+ x" S: l$ J, d) f( c
废话不多说,官网自己百度下, threejs.org ,入门很简单。  B9 [$ E, n* E6 N+ e
+ T1 Z2 f; B" I2 F$ M* f4 ], d1 O
创建的javascript脚本如下) }! j. F$ _/ `4 V" z
0 Y$ p+ y# f; x- }+ }8 z& r4 K( r
GIF.gif
- b  V# _, C* U8 c& m[mw_shl_code=javascript,true]
% Y1 O, h' L; l+ Avar scene = new THREE.Scene();
, t  ?' `' R5 i( [7 yvar camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
' W8 C: i# K/ z: z1 K( yvar renderer = new THREE.WebGLRenderer();
5 U5 q( d: x3 b8 r, }renderer.setSize(window.innerWidth, window.innerHeight);: k+ {% B8 s* ?# g
document.body.appendChild(renderer.domElement);
- C3 t. z9 c' s1 G
$ I, N$ x1 D8 J* s! o5 M* ^// Refresh Issue + l* @! e* `+ @  }: W* T  n1 P
window.addEventListener('resize', function () {
2 v, a+ a! n0 D+ Y+ O5 |    var width = this.window.innerWidth;/ `* q" s1 l4 |! @1 D
    var height = this.window.innerHeight;
7 ?& B) T9 X% r4 K, A7 w! S    render.setSize(width, height);
. u+ v; }6 L# y6 P" F( |) E8 y    camera.aspect = width / height;$ x" d+ K% N6 C0 x' j) ]5 ^
    camera.updateProjectionMatrix();$ j; I- J8 \& @. L, @8 h8 s
})# r7 n4 {; s/ y- S/ m" ]% L' d% `

; X4 e7 t& Z% B: @. S//orbit contorls
" x" Y( l1 u* R# r2 ?% ?, lcontrols = new THREE.OrbiTControls(camera,renderer.domElement);! i3 E' a  ~9 w0 B# }& v8 H/ k. N

+ _8 W2 p. u/ C8 I7 l) M! u//create the shape4 J$ F* ^  {$ x4 @: ]7 [; k
var geometry = new THREE.TorusGeometry(2, 1, 16, 100);
. V4 A, G) g( K, G' x# n; g# |% l  v//create  a meterial
4 _) s5 j1 j' E! O2 v6 g- `var material = new THREE.MeshBasicMaterial({ color: 0xffff00, wireframe: true, });
# r, Z, l0 p: B9 x5 i//var myMaterial = [new THREE.MeshBasicMaterial({map:new THREE.TextureLoader().load('image/plmhome.png'),side:THREE.DoubleSide}),];% q7 l, S7 |  ]( i+ Y' H9 s
//var material = new THREE.MeshFaceMaterial(myMaterial);& m1 w" P# }. f

0 \1 P8 ~7 d* a6 cvar cube = new THREE.Mesh(geometry, material);
4 O% d- e+ i' O$ Sscene.add(cube);5 l9 o# r) s% |, x' H& x
camera.position.z = 5;
8 I; ?  B* {9 t2 B
, d" d" g: f2 `5 ?+ t1 b- f0 M; F# H% B1 m: N! o  c+ f; f
* T; X. E, U2 _% W8 P

+ G0 e5 n% R* `1 Y7 t$ {; M1 i* g' Y2 z1 h( I
//rotate * \- J* \% H$ h' z
var update = function () {
" d/ `- D+ d/ c- v    cube.rotation.x += .01;
* @; V( w- G1 x    cube.rotation.y += .02;
/ v2 L, X6 D, L/ }' t8 F    cube.rotation.z += .02;. E& m* K- c+ P! E, \7 H
}. T7 V% \9 \+ v+ g
* N6 t- w, B' P! G
var render = function () {3 u( o$ c8 ^( y" z9 i" k
    renderer.render(scene, camera);* ^( {8 W  n" K9 c5 o. l: w
}
% W0 X- M  K* t
, I$ D! E2 Z- `# {! d+ B  Q8 [6 I
1 ]7 @# I6 L0 U
var Gameloop = function () {
, L  M; U+ ?/ i5 R& w+ Y$ D    requestAnimationFrame(Gameloop);9 u7 L, p% N1 `3 o" i3 ^6 T
    update();  N0 g% N3 g% H. ~) P1 x7 F( D8 R
    render();
  Z" ^, I6 Y; `% Y" I}  o/ ?- v* z7 u( }  ^

; s6 }6 }' {8 t5 A4 T  O% W8 e8 jGameloop();" \4 P4 o2 O& a( i6 J4 l
[/mw_shl_code]
2 w; }( P9 F2 X8 X
0 I2 s5 n' p, e- D9 n
3 L# q! G; H& v0 w) m: N* o# z引入争取的html,/ x2 S1 P0 p* a5 w( k

# C" }! e1 f! y' d" b0 D5 X[mw_shl_code=html,true]<!DOCTYPE html>. O. A% c* ^& ?' ?0 i- x" [$ e
<html>8 j% N9 ^# u) _5 a
% L( L* w) I" {5 H3 B
<head>
  q. [, u9 d  N- s$ O3 H/ J    <title>hello ThreeJS</title>+ i) g4 E; d( o& }
    <style>
! N( c$ Q1 f* g  l2 y        body {
# ]4 r* X7 D' N& I4 V% V& L            margin: 0;% i5 m! w3 e& H
        }
# e, \; W9 ~2 e# P, Z* B, R/ J# r  |9 b) a# T
        canvas {3 s5 i* R% {6 Y0 }# a. {
            width: 100%;
4 r0 Z3 A* V, O1 l) ]: _: ^            height: 100%;" C: x/ {' w) D: b/ ]# l
        }
" w: l) E7 Q, J. U# [3 i4 P9 w9 y& n% F! T2 A
        h1 {4 l3 \7 r) f1 Q8 ~( @8 A
            color: aqua;5 O) m- p/ u2 N, U  e
        }6 a' k+ ^$ ~& |
    </style>0 g4 J$ z/ m* g" \$ f- `# k8 J3 c
</head>; V  [4 C4 ]4 C& e1 ]# H
  R% M- ^' Y, S8 n6 D  c
<body>
# }& E/ L$ }) A! Y <script src="js/three.js"></script>8 x6 C" ~- r* w# ]* [
    <script src="js/OrbitControls.js"></script>
3 {" W# X% h  @7 y3 C    <script src="myjs.js"></script>* x& r/ t% ?* A& \  V2 B
  . h' B) u7 f$ j/ t' ^8 O

) j8 i+ X, f+ x2 l3 a* N0 w
& c- ?% `! L& y# x4 o
" J( W: h% g/ k2 F$ @2 C</body>
' m9 @: E, R! z/ ], ~' b8 v! Q! g8 N
</html>[/mw_shl_code]
" j; u( s: X8 a  N6 G' r# m! R* E9 w) q$ `& H# |4 |, D" E
效果点击这里:- l; P4 J. {2 {; N" s# u- a- ~

4 G# Z  H: x$ n0 thttp://plmhome.com/doteam/lesson1.html$ I& c6 g2 N, E' ]
& n& y/ M5 d- z# d( T
: ^9 u( z4 m4 _+ a8 ]0 f# L' w# U
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了