HT for Web自定义3D模型的WebGL应用

简介: 有不少朋友询问《HTML5 Web 客户端五种离线存储方式汇总》文章例子的3D表计模型是如何生成的,这个例子是通过导入3dmax设计好的表计模型,然后通过obj格式导入到HT for Web系统中进行控制,这种方式特别适合复杂模型的应用场景,但对于监控系统的很多应用其实并不需要专业的美工使用专业的3D编辑工具,完全通过HT for Web预定义的和内置自定义3D模型API就能满足很多应用,这里介绍几种场景的自定义3D模型应用。

Screen Shot 2015-01-07 at 11.53.23 PM

有不少朋友询问《HTML5 Web 客户端五种离线存储方式汇总》文章例子的3D表计模型是如何生成的,这个例子是通过导入3dmax设计好的表计模型,然后通过obj格式导入到HT for Web系统中进行控制,这种方式特别适合复杂模型的应用场景,但对于监控系统的很多应用其实并不需要专业的美工使用专业的3D编辑工具,完全通过HT for Web预定义的和内置自定义3D模型API就能满足很多应用,这里介绍几种场景的自定义3D模型应用。

Screen Shot 2015-01-07 at 11.48.45 PM

上图是采用HT提供的createRingModel函数,通过编辑2D的多边形生成对应的环状的3D模型,对于花瓶碗杯等环形对称的物体很适合采用该函数构建。除了createRingModel外,HT的建模手册中的custommodel自定义模型例子,还采用了createExtrusionModel等更多的自定义模型API构建了一个餐桌椅和墙面的场景,其效果如下:

Screen Shot 2015-01-07 at 11.46.14 PM

HT内置的基础模型也有很多参数可调节设置出多种模型效果,参见HT建模手册的如下例子:

Screen Shot 2015-01-07 at 11.49.56 PM

自定义模型还可用于构建如机房、机框、板卡和端口的常见电信网管监控模型:

Screen Shot 2015-01-07 at 11.50.54 PM

该EMS设备管理系统例子3D模型和Tree组件通过HT强大灵活的模型与图形的数据绑定功能,从而实现树上自定义图标和3D自定义模型的数据共享,实时一致刷新效果,以下为该EMS例子的全部JavaScript代码:

function init(){                                 
    dm = new ht.DataModel();                
    treeView = new ht.widget.TreeView(dm);                                                                                                 
    g3d = new ht.graph3d.Graph3dView(dm);                          
    mainSplit = new ht.widget.SplitView(treeView, g3d, 'h', 0.2);   
    
    view = mainSplit.getView();  
    view.className = 'main';
    document.body.appendChild(view);    
    window.addEventListener('resize', function (e) {
        mainSplit.invalidate();
    }, false);                         

    register2DImage();
    register3DModel();
    addModel(); 
                    
    g3d.setGridVisible(true); 
    g3d.setGridSize(30);
    g3d.setGridGap(50);
    g3d.setEye([200, 200, 600]);
    g3d.setCenter([0, 200, 0]);
    g3d.getView().style.background = '#F9F9F9';                 
    g3d.getLabel = function(data){
        return data.s('label');
    };
    dm.sm().setFilterFunc(function(data){
        return data !== wall;
    });
    treeView.setVisibleFunc(function(data){
        return data !== wall;
    });                
    treeView.expandAll();
}

function register2DImage(){
    ht.Default.setImage('ems-frame', {
        width: 18,
        height: 18,
        comps: [
            {
                type: 'rect',
                rect: [5, 4, 8, 11],
                borderWidth: 2,
                borderColor: '#34495E'
            }                         
    ]});        

    ht.Default.setImage('ems-pane', {
        width: 18,
        height: 18,
        comps: [
            {
                type: 'rect',
                rect: [0, 4, 18, 10],
                background: {func: 'style@shape3d.color'}
            }                         
    ]});     

    ht.Default.setImage('ems-block', {
        width: 18,
        height: 18,
        comps: [
            {
                type: 'circle',
                rect: [0, 2, 18, 10],
                background: {
                    func: 'attr@circleColor',
                    value: '#3498DB'                               
                }
            }, 
            {
                type: 'rect',
                rect: [4, 14, 10, 3],
                background: {
                    func: 'attr@rectColor',
                    value: '#3498DB'                               
                }
            }                           
    ]});                 
}

function register3DModel(){
    ht.Default.setShape3dModel('ems-frame', ht.Default.createFrameModel(0.1, 0, 0.1, {top: true, bottom: true, back: true}));       

    ht.Default.setShape3dModel('ems-block', [
        {
            shape3d: ht.Default.createCylinderModel(32, 0, 32, false, false, true, true),   
            r3: [Math.PI/2, 0, 0],   
            color: {
                func: 'attr@circleColor',
                value: '#3498DB'
            }     
        },
        {
            shape3d: 'box',
            s3: [1, 0.2, 1], 
            t3: [0, -0.7, 0],
            color: {
                func: 'attr@rectColor',
                value: '#3498DB'
            }
        }
    ]);                  
}

function addModel(){
    wall = new ht.Shape();
    wall.setName('Wall');
    wall.setPoints(new ht.List([
        {x: -750, y: 750},
        {x: -750, y: -750},
        {x: 750, y: -750},
        {x: 750, y: 750}
    ]));
    wall.setTall(400);
    wall.setElevation(200);
    wall.s({
        'shape.border.width': 5,
        'shape.border.color': 'rgba(20, 20, 20, 0.8)',
        'shape.background': null,    
        'all.color': 'rgba(102, 192, 218, 0.95)',
        'all.transparent': true,
        'all.reverse.cull': true
    });
    dm.add(wall);                                               

    var frame = new ht.Node();
    frame.setName('Main Frame');
    frame.setIcon('ems-frame');
    frame.s3(120, 300, 120);
    frame.p3(0, 152, 0);
    frame.s({
        'shape3d': 'ems-frame',
        'shape3d.color': '#34495E',
        'label': 'www.hightopo.com',
        'label.color': 'white',
        'label.background': '#3498DB',
        'label.position': 6,
        'label.t3': [-6, -54, 6],
        'label.r3': [0, Math.PI/4, Math.PI/2]
    });
    dm.add(frame);                                
    
    var colors = ['#9C8CE7', '#00C59D', '#A741B6', '#F5C700', '#31485F', '#F81F25', '#00B862', '#3B7DA7'];
    for(var i=0; i<6; i++){
        var pane = new ht.Node();
        pane.setIcon('ems-pane');
        pane.setName('Pane' + (i+1));
        pane.s3(108, 16, 8);                    
        pane.s({
            'shape3d': 'box',
            'shape3d.color': '#ECF0F1'
        });
        pane.setHost(frame);
        pane.setParent(frame);                     
        dm.add(pane);
        
        if(i < 2){
            for(var j=0; j<8; j++){
                var block = new ht.Node();
                block.setName('block ' + i + '*' + j);
                block.s3(8, 8, 12);                
                block.p3(-39+j*11, 1, 0);
                block.setHost(pane);
                block.setParent(pane); 
                block.setIcon('ems-block');
                block.s({
                    'shape3d': 'ems-block'
                });                       
                if(i === 1){
                    block.a({
                        'circleColor': colors[j],
                        'rectColor': '#00F2CF'
                    });
                    
                }
                dm.add(block);                                        
            }                     
        }else{
            pane.setName('Pane' + (i+1) + ' [ Empty ]');
            pane.s({
                'shape3d.color': '#BDC3C7'
            });
        }                   
        pane.p3(0, 265-i*27, 54);
    }                
}

 

目录
相关文章
|
24天前
|
前端开发 JavaScript 安全
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第27天】本文介绍了HTTP/2和HTTPS在前端性能调优中的应用。通过多路复用、服务器推送和头部压缩等特性,HTTP/2显著提升了Web性能。同时,HTTPS确保了数据传输的安全性。文章提供了示例代码,展示了如何使用Node.js创建一个HTTP/2服务器。
38 3
|
3天前
|
前端开发 JavaScript UED
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势
在数字化时代,Web 应用性能优化尤为重要。本文探讨了CSS与HTML在提升Web性能中的关键作用及未来趋势,包括样式表优化、DOM操作减少、图像优化等技术,并分析了电商网站的具体案例,强调了技术演进对Web性能的深远影响。
11 5
|
12天前
|
缓存 安全 网络安全
HTTP/2与HTTPS在Web加速中的应用
HTTP/2与HTTPS在Web加速中的应用
|
15天前
|
SQL 安全 前端开发
PHP与现代Web开发:构建高效的网络应用
【10月更文挑战第37天】在数字化时代,PHP作为一门强大的服务器端脚本语言,持续影响着Web开发的面貌。本文将深入探讨PHP在现代Web开发中的角色,包括其核心优势、面临的挑战以及如何利用PHP构建高效、安全的网络应用。通过具体代码示例和最佳实践的分享,旨在为开发者提供实用指南,帮助他们在不断变化的技术环境中保持竞争力。
|
25天前
|
前端开发 安全 应用服务中间件
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第26天】随着互联网的快速发展,前端性能调优成为开发者的重要任务。本文探讨了HTTP/2与HTTPS在前端性能优化中的应用,介绍了二进制分帧、多路复用和服务器推送等特性,并通过Nginx配置示例展示了如何启用HTTP/2和HTTPS,以提升Web应用的性能和安全性。
25 3
|
2月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
113 3
|
24天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
126 45
|
6天前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
20 2
|
20天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
36 1
|
23天前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
下一篇
无影云桌面