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 2488 0

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

admin 楼主

2019-9-1 18:45:09

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

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

x
( P, [7 [2 ^& I) y* \# D" E# x

! W' {' K; N1 m; K2 [/ }# z废话不多说,官网自己百度下, threejs.org ,入门很简单。7 p  ^( P1 p! n. z# v( ^  k

, s% e$ o  ^5 \创建的javascript脚本如下
! f: ~, t3 ?5 _- g2 P2 d8 @( f* \$ V& ^$ [/ x7 C' z
GIF.gif
4 N9 x4 s4 c$ ]' Z[mw_shl_code=javascript,true]
3 \! h8 G  c/ |+ evar scene = new THREE.Scene();
; m' ]4 j. @; H" x, ~4 j) X) Hvar camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);& n, c. @6 e4 q' ~+ o  o, n
var renderer = new THREE.WebGLRenderer();
' I% c4 `& W6 y, v" m- H! \renderer.setSize(window.innerWidth, window.innerHeight);* C/ T8 Y% S, B; Y- _- j( l, p
document.body.appendChild(renderer.domElement);, q0 x8 n" }9 K) h

+ T7 D% C" }! D3 w// Refresh Issue
% I; E4 J+ z. Bwindow.addEventListener('resize', function () {
% R( D. d. M6 Z0 d: U% _2 {    var width = this.window.innerWidth;( c: n9 U, s* g1 A& v. {- c  p8 F
    var height = this.window.innerHeight;
' y) z0 Q/ @1 d2 v. P$ v8 |    render.setSize(width, height);
! _8 Z1 V3 T- W( t1 I( f    camera.aspect = width / height;
) @4 b$ h$ G0 }" \8 C7 [$ C9 j    camera.updateProjectionMatrix();
# R! M$ h. X3 B# U  {})" ?  `+ x5 l/ A  c3 D$ w
4 }, m: Z% _" p/ T0 c$ f* U
//orbit contorls
5 r3 b3 l2 [* g( {8 Z' Acontrols = new THREE.OrbiTControls(camera,renderer.domElement);
$ j8 `9 P% A- n% ~6 x# z2 h0 i
1 B* _, C+ A2 K0 `9 {' e5 z! D//create the shape" ]/ i, h; v: o. D0 t8 V# p5 N
var geometry = new THREE.TorusGeometry(2, 1, 16, 100);+ p% G" k5 w' ^
//create  a meterial, {9 |( h% F& B$ m- ?
var material = new THREE.MeshBasicMaterial({ color: 0xffff00, wireframe: true, });
0 Q( d( M9 Y! M& s//var myMaterial = [new THREE.MeshBasicMaterial({map:new THREE.TextureLoader().load('image/plmhome.png'),side:THREE.DoubleSide}),];, B! }( R8 ]' d/ X
//var material = new THREE.MeshFaceMaterial(myMaterial);
  k9 Y  a% g- O& q# Q# j7 ^) T) }  b6 `7 x! J" r
var cube = new THREE.Mesh(geometry, material);
# K$ E1 o% ]: f4 h( b% k6 vscene.add(cube);
6 {7 q5 v8 g% y5 e5 ?7 c! b" ~camera.position.z = 5;! f& ~' r( o! ?  `2 U) V9 ^$ M

% h2 l7 }+ s: i% K% R/ j; i5 c( S9 @* z# ]# v

, J( T& ]) r  E. Z2 T" h6 \0 e
# A6 I) N- \9 b7 d8 ~7 a! P7 `3 ~' S9 T: Z: f6 `& L
//rotate , b% w: }, l0 R: o0 H2 I; [
var update = function () {
% ?4 M3 v8 s' J    cube.rotation.x += .01;2 r- ~% Z' w: y, h7 F
    cube.rotation.y += .02;( e( m8 D5 J% f  P" f
    cube.rotation.z += .02;
6 [  I9 X2 d  _}
. G# J+ h: m5 \% i4 X7 K
* k9 _/ p; n. [* y: P$ T$ _var render = function () {9 p9 ]. g( K0 F5 f9 [) Y4 P0 e0 M
    renderer.render(scene, camera);" W+ N  T7 F% I1 j# Y
}) g% o# K+ f, Y$ g' k- ]  Z) Y

+ v5 G) `* P8 P* }' ^
6 o$ f* o- q" D5 A: ?
7 I5 g" H% n( m5 S5 A) h2 g9 Rvar Gameloop = function () {2 h3 P; i  g5 `" Y; x' p& F$ {
    requestAnimationFrame(Gameloop);
3 J" o4 ^/ W* L. W    update();: C9 u" R4 n' `+ q9 u1 C$ ~
    render();, ^3 n' i+ x9 J# e" s0 Z% S) [
}
; X8 q7 i, l. A4 |, t4 [7 t6 L' h1 Q+ t: d! q' f
Gameloop();- V4 ~1 f% O) y4 C
[/mw_shl_code]
+ n+ T+ B& V  {4 J% z
  l; K' B1 d7 y: M- x
& ]) m: \2 }: D8 D  B  E( M" C引入争取的html,
* c  }" u% ]( I% w7 @6 G. R% I6 H: T% h9 I
[mw_shl_code=html,true]<!DOCTYPE html>
0 x! C1 V; @5 [<html>. U4 c$ t" f0 q4 e6 ^0 h  B( a
. c6 ?! W3 Z: h  z- R# T
<head>- _# c# v2 q  c! l
    <title>hello ThreeJS</title>5 d0 R( P9 }* A( A. X  k. ~4 Y
    <style>
' {. I' p- T& K( R* L7 L        body {
' b: ]( A3 |9 u5 Q            margin: 0;
# J: I1 l( D+ ]' S$ ~& |! O        }# `( ~6 f+ w9 l* _' @9 k

+ R& O- E9 m. ^$ g        canvas {3 M, S( ^/ K- n! r4 c
            width: 100%;, O9 l; J, x' P  S& Z
            height: 100%;
: w8 e0 x2 i& Q" h: l        }/ A. |" [& b5 T# [% P" _) b
; G, p2 u  N& N: y
        h1 {
6 r! S% H; ?: I" b9 u            color: aqua;6 j% p' T+ n7 R$ T
        }& h  m# J0 @# s% Z; N1 ?
    </style>
# e9 x) c7 T% D9 _# B: X</head>0 i6 B8 f$ H- M; r: P! H
1 a$ Z' V5 a7 t
<body>  a1 @2 P3 q8 m) ^( Y6 b# l2 J. N
<script src="js/three.js"></script>
7 A2 o6 \9 B- [+ J    <script src="js/OrbitControls.js"></script>
9 m0 K7 r* f1 u1 I5 |1 H7 a5 ^    <script src="myjs.js"></script>- t2 K2 C; [+ l9 B6 G+ p
  
) W5 e) j5 S: }3 W8 o1 y- }9 w; H% f# ]% w8 |
9 Z: p1 |1 R( ?
8 P+ X% r' |6 }# C6 k
</body>; r0 i& j/ z& W/ O2 l7 w3 ~# O

* q( R" {2 |* ^' y6 [5 \  D' q</html>[/mw_shl_code]  L6 V# y  H& @7 l

9 \2 E9 V/ f1 B! N6 s: r0 ~' b3 d效果点击这里:" l8 e+ c. I7 I! W: R) K

# T7 D' K4 d3 f0 b6 Z: Phttp://plmhome.com/doteam/lesson1.html
" Z: l# A" S  U! y" J) i. L! O! h
/ n" ^) ~" F' @1 }! k0 X& h4 c' w) M& N, v5 M
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了