【开发总结】—— BABYLON 项目开发必备系列
前言:在公司主要使用Babylon.js作为前端引擎,我自己在开发中总结到基本上每一个新项目都会需要这些基本设置。
![]() |
![]() |
![]() |
| 一、ios兼容:解决镜面反射 |
如果不加offline,材质中有镜面反射,苹果手机都会打不开项目
//ios兼容,解决镜面反射
var offline;
if (os.isPhone) {
offline = false
} else {
offline = true
} var demo = {
scene: 'MI8',
binary: true,
offline: offline,
|
二、提高支持硬件的质量(在查看器中应该是动态的) |
var scale = Math.max(1 / (window.devicePixelRatio || 2));
engine.setHardwareScalingLevel(scale);
|
三、如果模型把材质都赋给了blank材质球,需手动赋材质 |
在JSON中分出两套材质,实现调试后即时保存
var mats = {};
function initMaterial() {
//分材质
scene.meshes.forEach(function (mesh) {
if (mesh.material && mesh.material.name == "blank") {
var mat1 = new BABYLON.StandardMaterial(mesh.name + 'mat', scene);
var mat2 = new BABYLON.StandardMaterial(mesh.name + 'mat_2', scene);
if (!mats[mesh.name]) {
mats[mesh.name] = {}
}
}
if (mesh.material && mesh.material.diffuseTexture) {
var text = mesh.material.diffuseTexture;
mesh.material.opacityTexture = text;
mesh.material.backFaceCulling = false;
}
mesh.isPickable = true;
});
// if (os.isPc) {
// openDebug();
// }
//initSceneByJSON(json);
遍历获取两套材质一定要在开启调试链接,初始化json后:
for (key in mats) {
mats[key].mat1 = scene.getMaterialByName(key + "mat");
mats[key].mat2 = scene.getMaterialByName(key + "mat_2");
//默认显示的材质
scene.getMeshByName(key).material = scene.getMaterialByName(key + "mat_2");
}
按钮切换分别为:
for (key in mats) {
scene.getMeshByName(key).material = scene.getMaterialByName(key + "mat");
//console.log(scene.getMeshByName(key).material.name)
}
for (key in mats) {
scene.getMeshByName(key).material = scene.getMaterialByName(key + "mat_2");
//console.log(scene.getMeshByName(key).material.name)
}
|
四、初始化场景、材质等资源 |
function initHUA(){
function initScene(){
//透明背景
scene.clearColor = new BABYLON.Color4(0, 0, 0, 0);
//全部材质可pick
scene.meshes.forEach(function(mesh){
mesh.isPickable = true;
if(mesh.animations.length){
scene.beginAnimation(mesh, 0, 0, false)
}
});
//isready = true;
}
function initCamera(){
window.camera = new BABYLON.ArcRotateCamera("Camera",0 ,0.8 ,0, new BABYLON.Vector3(0,0,0),scene);
//限制范围
camera.lowerBetaLimit = 0.95;
camera.upperBetaLimit = 1.25;
//camera.lowerAlphaLimit = -Math.PI / 6;
//camera.upperAlphaLimit = Math.PI / 6;
camera.lowerRadiusLimit = 45;
camera.upperRadiusLimit = 65;
//变焦速度
camera.wheelPrecision = 1;
camera.pinchPrecision = 1;
camera.zoomOnFactor = 50;
////调整参数
camera.radius = 52;
camera.alpha = 0;
camera.beta = 1.25;
camera.targetScreenOffset.y = -10;
camera.inertia = 0.85;
camera.useAutoRotationBehavior = false;
scene.activeCamera = camera;
camera.attachControl(canvas,true);
}
function initLight(){
var hem = new BABYLON.HemisphericLight("HemiLight", new BABYLON.Vector3(0, 1, 0),scene);
hem.intensity = 0.3;
//创建缓冲函数 - Bezier曲线自定义缓冲
//var easingFunction = new BABYLON.BezierCurveEase(.5,.21,.06,.98);
}
|
五、微信钉钉兼容性问题 |
- 微信中Dom元素全部需要放在canvas上面,放在下面会被场景挡住,设置z-index也没用
- 钉钉中的动画全部需要兼容-webkit前缀,因为钉钉内嵌chrome
- 注意@keyframes加前缀的形式是:@-webkit-keyframes
|
六、微信分享 |
<script type="text/javascript">
try{
wxShareConfig({
shareTitle: "小米8",
shareLink: window.location.href,
shareImgUrl: "https://forreall.cn/3ds/app/MI8/img/logo.png",
shareDesc: "8周年旗舰手机"
});
}catch(e){
}
</script>
|
七、数据/事件统计 |
//点击事件统计
try {
Forreall3d.trackEvent('_trackEvent', '小米8', '点
击', '切换普通版');
} catch (e) {
}
注意:点击事件有效时才统计一次,无效点击不统计
//旋转事件统计
Forreall3d.eventDetect("花儿送给你");
|
八、数字型loading |
<script src="../../js/loading.js"></script>
Fn1要放在demo前:
function fn1(num){
$('.loadwrap-first .heart').html(num);
}
Fn2和loading放在最后:
//loading
function fn2(){
$(".loadwrap-first").fadeOut();
}
loading(scene,fn1,fn2);
版权声明:本文原创,非本人允许不得转载
【开发总结】—— BABYLON 项目开发必备系列的更多相关文章
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(二)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(三)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(四)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(五)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(六)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(七)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(八)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(九)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - Blazor 实战系列(一)
系列文章 基于 abp vNext 和 .NET Core 开发博客项目 - 使用 abp cli 搭建项目 基于 abp vNext 和 .NET Core 开发博客项目 - 给项目瘦身,让它跑起来 ...
- ASP.NET MVC开发:Web项目开发必备知识点
最近加班加点完成一个Web项目,使用Asp.net MVC开发.很久以前接触的Asp.net开发还是Aspx形式,什么Razor引擎,什么MVC还是这次开发才明白,可以算是新手. 对新手而言,那进行A ...
随机推荐
- 安装的 Python 版本太多互相干扰?pyenv 建议了解一下。
写在之前 我们都知道现在的 Python 有 Python2 和 Python3,但是由于各种乱七八糟的原因导致这俩哥们要长期共存,荣辱与共,尴尬的是这哥俩的差异还比较大,在很多时候我们可能要同时用到 ...
- [转]/dev/null 命令用法
/dev/null :代表空设备文件 :代表重定向到哪里,例如:echo "123" > /home/123.txt 1 :表示stdout标准输出,系统默认值是1,所以&q ...
- nmon系统监控
nmon系统监控篇 本文目录 1 nmon的安装 2 nmon控制台指令 3 输出监控文件 一 下载nmon 本次使用的是nmon_linux_14i.tar.gz 二 放入linux中后解压 gzi ...
- caffe-dnnh实验
下面是我在做基于深度哈希的大规模图像检索中的一个实验,相关文档介绍给大家,具体内容查看提供的相关链接,总结的很到位了,我就不再赘述. 实践cvpr2015年的深度哈希图像检索论文:Simultaneo ...
- [ZJOI2011][bzoj2229] 最小割 [最小割树]
题面 传送门 思路 首先我们明确一点:这道题不是让你把$n^2$个最小割跑一遍[废话] 但是最小割过程是必要的,因为最小割并没有别的效率更高的算法(Stoer-Wagner之类的?) 那我们就要尽量找 ...
- BZOJ 4826 [Hnoi2017]影魔 ——扫描线 单调栈
首先用单调栈和扫描线处理出每一个数左面最近的比他大的数在$l[i]$,右面最近的比他大的数$r[i]$. 然后就可以考虑每种贡献是在什么时候产生的. 1.$(l[i],r[i])$产生$p1$的贡献 ...
- js面向对象实现切换面板
js面向对象的特点: 继承(inheritance):对象方法和属性的继承 多态(polymorphism):组件开发 抽象(abstract):抓住核心问题 封装(encapsulation):把功 ...
- nodeJS学习(4)--- webstorm/...开发 NodeJS 项目-节1
前提: 已安装好 IDE ,eg:webstorm/IDEA 2016.3 & 2017.1 nodeJS(含 npm 及 相应的模板等) 要用 webstorm 开发 NodeJS项目(we ...
- 【03】react 之 创建component
React推出后,出于不同的原因先后出现三种定义react组件的方式,殊途同归:具体的三种方式: 函数式定义的无状态组件 es5原生方式React.createClass定义的组件 es6形式的ext ...
- 归并排序Merge sort(转)
原理,把原始数组分成若干子数组,对每一个子数组进行排序, 继续把子数组与子数组合并,合并后仍然有序,直到全部合并完,形成有序的数组 举例 无序数组[6 2 4 1 5 9] 先看一下每个步骤下的状态, ...


