JSFIDDLE 动力 Threejs 功能探秘
JSFIDDLE 助力 WebGL 功能探秘
太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es)
本文遵循“署名-非商业用途-保持一致”创作公用协议
下面演示样例能产生基本几何体的阴影投射,还有还有一份代码。是无法投射的,和本份能投射的代码。相差点儿相同,但确始终不得其法,需进一步核对,才干知道详细差异在哪里,哪些关键的部位起了阴影投射的作用。
还是静下心来,把每一行代码搞清楚吧,这才是捷径!
往往追求捷径的结果。就是盲人摸象,最后,越摸越离谱。连最初的无意识界都没有了。
所以佛祖告诫我们,要追求本真。象孩童一样。
事实上。就是去除妄念和推測。实事求是地按事情本来的面目去考虑问题,才不会被妄端推測出来的东西影响你的心绪,以至偏离正途,生出事端来。
在微信中流传的一条信息,大概意思是。仅仅要你想了,就会去不知不觉地做。做了就会产生效果。效果持续久了,就会变成习惯,习惯多了就形成性格,而性格决定着命运。
所以,要想改变,首先从想法開始改变。
这不算是唯心主义论吧,有时侯感觉,纯粹的唯物主义,往往让人们忽略和人的思维和潜意识对物质世界的改变。
而人类之所以差别于动物。最概本的就在于。人类是能够通过思维来改变其自身世界的状态,当然了。这状态。也是物质世界固有存在的多种选择之中的一个。但至少是能够选择的。
而我们假设不加以掌控的话,就会变成了随机选择,物质世界的状态有好有坏,随机选择的结果可想而知。全然是不好状态的可能也不是没有。
综上所述,人类的高级。就在于,能够通过思考指导行动,终于改变默认的选择项,而优先选择有利的选项。
http://jsfiddle.net/4Txgp/13/embedded
- var SCREEN_WIDTH = window.innerWidth - 100;
- var SCREEN_HEIGHT = window.innerHeight - 100;
- var camera, scene;
- var canvasRenderer, webglRenderer;
- var container, mesh, geometry, plane;
- var windowHalfX = window.innerWidth / 2;
- var windowHalfY = window.innerHeight / 2;
- init();
- animate();
- function init() {
- container = document.createElement('div');
- document.body.appendChild(container);
- camera = new THREE.PerspectiveCamera(30, window.innerWidth / window.innerHeight, 1, 100000);
- camera.position.x = 1200;
- camera.position.y = 1000;
- camera.lookAt({
- x: 0,
- y: 0,
- z: 0
- });
- scene = new THREE.Scene();
- var groundMaterial = new THREE.MeshPhongMaterial({
- color: 0x6C6C6C
- });
- plane = new THREE.Mesh(new THREE.PlaneGeometry(500, 500), groundMaterial);
- plane.rotation.x = -Math.PI / 2;
- plane.receiveShadow = true;
- scene.add(plane);
- // LIGHTS
- scene.add(new THREE.AmbientLight(0x666666));
- var light;
- light = new THREE.DirectionalLight(0xdfebff, 1.75);
- light.position.set(300, 400, 50);
- light.position.multiplyScalar(1.3);
- light.castShadow = true;
- light.shadowCameraVisible = true;
- light.shadowMapWidth = 512;
- light.shadowMapHeight = 512;
- var d = 200;
- light.shadowCameraLeft = -d;
- light.shadowCameraRight = d;
- light.shadowCameraTop = d;
- light.shadowCameraBottom = -d;
- light.shadowCameraFar = 1000;
- light.shadowDarkness = 0.2;
- scene.add(light);
- var boxgeometry = new THREE.CubeGeometry(100, 100, 100);
- var boxmaterial = new THREE.MeshLambertMaterial({
- color: 0x0aeedf
- });
- var cube = new THREE.Mesh(boxgeometry, boxmaterial);
- cube.castShadow = true;
- cube.position.x = 0;
- cube.position.y = 100;
- cube.position.z = 0;
- scene.add(cube);
- // RENDERER
- webglRenderer = new THREE.WebGLRenderer();
- webglRenderer.setSize(SCREEN_WIDTH, SCREEN_HEIGHT);
- webglRenderer.domElement.style.position = "relative";
- webglRenderer.shadowMapEnabled = true;
- webglRenderer.shadowMapSoft = true;
- container.appendChild(webglRenderer.domElement);
- window.addEventListener('resize', onWindowResize, false);
- }
- function onWindowResize() {
- windowHalfX = window.innerWidth / 2;
- windowHalfY = window.innerHeight / 2;
- camera.aspect = window.innerWidth / window.innerHeight;
- camera.updateProjectionMatrix();
- webglRenderer.setSize(window.innerWidth, window.innerHeight);
- }
- function animate() {
- var timer = Date.now() * 0.0002;
- camera.position.x = Math.cos(timer) * 1000;
- camera.position.z = Math.sin(timer) * 1000;
- requestAnimationFrame(animate);
- render();
- }
- function render() {
- camera.lookAt(scene.position);
- webglRenderer.render(scene, camera);
- }
JSFIDDLE 动力 Threejs 功能探秘的更多相关文章
- [Android] android studio 2.0即时运行功能探秘
即时运行instant Run是android studio 2中,开发人员最关心的特性之一 在google发布studio 2.0之后,马上更新体验了一把,然而发现,并没快多少,说好的即时运行呢? ...
- 乐动力APP案例
第一部分 调研, 评测 下载软件并使用起来,描述最简单直观的个人第一次上手体验. 这款软件的主界面功能还是比较完善,里面有多个关于运动相关的数据,还有一些推荐健身教程,记录功能也十分不错,其中最难理解 ...
- 代码演示神器——jsfiddle
目录: 1. 介绍 2. jsfiddle的具体使用 3. 总结 1. 介绍 很多时候,我们需要在我们写的文章或博客中,即时显示出我们写的demo,能方便的解释出我们的思路.很久之前我也写过一篇文章, ...
- Spring Cloud 新一代Web框架微服务翘楚(一)
序言 springcloud是微服务架构的集大成者,将一系列优秀的组件进行了整合.基于springboot构建,对我们熟悉spring的程序员来说,上手比较容易. 通过一些简单的注解,我们就可以快速的 ...
- WebGL和ThreeJs学习5--ThreeJS基本功能控件
Threejs 2017年6月6日 15:06 Stats: new Stats();性能监视器,性能测试的方法,引入 Stats.js http://www.hewebgl.com ...
- 动力节点Java培训告诉你Java线程的多功能用法
现在的java开发可谓是八仙过海各显神通啊!遥想当下各种编程语言萎靡不振,而我Java开发异军突起,以狂风扫落叶之态,作为Java培训行业的黄埔军校,为了守护Java之未来,特意总结了一些不被人所熟知 ...
- 探秘IntelliJ IDEA 13测试版新功能——调试器显示本地变量
IntelliJ IDEA在业界被公认为最好的Java开发平台之一,JetBrains公司将在12月正式发布IntelliJ IDEA 13版本. 现在,小编将和大家一起探秘密IntelliJ IDE ...
- 探秘小程序(10):分享功能+webview
场景: 小程序页面用webview嵌入了h5页面,h5页面需要与小程序进行交互,h5页面内容不同,分享的链接也不一样 分享功能: 小程序的分享功能即用户点击小程序右上角,转发功能页面.可以指定分享卡片 ...
- 探秘Tomcat——启动篇
tomcat作为一款web服务器本身很复杂,代码量也很大,但是模块化很强,最核心的模块还是连接器Connector和容器Container.具体请看下图: 从图中可以看出 a. 高亮的两块是Conne ...
随机推荐
- 如何安装一个优秀的BUG管理平台(转)
前言 就BUG管理而言,国内的禅道做得很不错,而且持续有更新.我们来看看如何从头到尾安装禅道,各位要注意的是,不是文章深或者浅,而是文章如何在遇到问题的时候,从什么途径和用什么方法解决问题的.现在发觉 ...
- Html.Partial和Html. RenderPartial
圣殿骑士-蓝剑行动 Html.Partial和Html. RenderPartial用法 Html.Partial和Html. RenderPartial用法 Html.partial和RenderP ...
- 《Javascript语言精粹》 读书笔记
1 6种值被当做假:false.null.undefined.空字符串''.数字0.数字NaN,其他所有值都为真,包括"false" 2 typeof有6种值,分别是'number ...
- Android pm命令用法
Sam综观有关PackageManager时,无意中发现Android 下提供一个pm命令,通常放在/system/bin/下. 这个命令与Package有关.且很有用.所以研究之. 0. Usage ...
- 完全背包 (DP)
输入: n=3 (w,v)={(3,4),(4,5),(2,3)} W=7 输出: 10(0号物品选1个,2号物品选2个) 和01背包的区别是物品可以任意选择. 令dp[i+1][j]=从前i种物品中 ...
- C# 使用 Code Snippet 简化 Coding
在开发的项目的时候,你是否经常遇到需要重复编写一些类似的代码,比如是否经常会使用 for.foreach ? 在编写这两个循环语句的时候,你是一个字符一个字符敲还是使用 Visual Studio 提 ...
- Visual Studio GitHub For Windows部署
使用GitHub For Windows部署Visual Studio项目 因为最近同时再看很多技术方面的书,书上的例子有很多自己想亲自尝试一下,但是每次写例子都得创建一个新项目未免太麻烦,索性就整理 ...
- (c#)SKYPE API项目总结(一)
原文:(c#)SKYPE API项目总结(一) 这个项目的需求:SKYPE软件文字聊天同步翻译,并将翻译后的内容会发送给对方,将对方发给自己的话翻译成自己语种.功能见图: ...
- iis配置网址(主机名)
一直以来,常常弄不成功关于网址的问题. 今天查了下资料 首先,找到你的文件:C:\Windows\System32\drivers\etc的hosts文件,直接用记事本打开 # Copyright ( ...
- Code Forces 414B 很不错的双手,以促进合规
http://codeforces.com/problemset/problem/414/B 题目挺不错的.留个纪念,活动脑筋不错的题目 #include<iostream> #inclu ...