地图可视化

  • 示例
  • HTML
  • CSS
  • JS

更多有趣示例 尽在 知屋安砖社区

示例

HTML

<div class="wrapper"><h1>THREEJS - A breast cancer visualization by joni.giuro</h1><canvas width="750" height="500" id="source"></canvas><div id="container"></div><div class="dida"><h2 class="subtitle">Out of 100'000 women, how many were diagnosed with breast cancer?</h2><ul class="inline-list"><!--<li class="item"><a class="button" href="#" id="zero">10+</a></li>--><li class="item"><a class="button active" href="#" id="one">22-40</a></li><li class="item"><a class="button" href="#" id="two">41-57</a></li><li class="item"><a class="button" href="#" id="three">58-74</a></li><li class="item"><a class="button" href="#" id="four">75-92</a></li><li class="item"><a class="button" href="#" id="five">92+</a></li></ul></div><p>Nothing too fancy. I took the original image from here:<a href="http://www.worldwidebreastcancer.com/wp-content/uploads/2011/08/breastcancerstatsworldwide.jpg">Breast cancer stats</a>, converted it to grayscale, placed it on a canvas and read pixel information from it. Once I have collected the color informations I need, I then proceed to create a lot of cubes with threejs. After a while the bars get resized. That's the ideal breast cancer graph</p><div class="me"><ul class="block-list"><li class="item"><a href="http://zhereicome.com/experiments">Blog</a></li><li class="item"><a href="https://twitter.com/JoniGiuro">Twittur</a></li></ul></div></div>

CSS

@import url(https://fonts.googleapis.com/css?family=Alef);body {background: url('https://subtlepatterns.com/patterns/ticks.png') center center repeat;
}
.wrapper {font-family: Alef, Helvetica, Arial, sans-serif;text-align: center;color: #444;text-shadow: 0 1px white;
}a {color: #33b0d6;
}#source-image {display: none;
}#source {display: none;
}#container {position: relative;width: 750px;margin: 0 auto;
}canvas {margin: 0 auto;text-align: center;border: 1px solid black;background: rgba(255,255,255,.5);
}.inline-list {list-style: none;width: 740px;margin: 0 auto;padding: 0;
}.item {width: 15%;display: inline-block;
}.block-list .item {display: block;text-align: center;width: 100%;
}.button {display: block;padding: 10px;font-size: 20px;background: #444;color: #FFF;text-shadow: none;border-radius: 3px;text-decoration: none;font-weight: bold;
}.button:hover {background: #777;box-shadow: 0 0 5px rgba(0,0,0,.5);
}.button.active {background-color: #BADA55;
}

JS

var BreastCancer = {commonStuff : {tileSize: 15,heightGain: 1/30,width: 750,height: 420,sourceContext: null,dataArray: [],cubesArray: [],hReached : false,vReached : true,mouseDown : false,fighting : false,currentShow: 44,minShow: 22},doNotInit: function() {this.copySourceToCanvas();},copySourceToCanvas : function() {var self = this;var sourceCanvas = document.getElementById('source');var ctx = sourceCanvas.getContext('2d');this.commonStuff.sourceContext = ctx;var img = new Image();img.onload = function() {ctx.drawImage(img, 0, 0);self.collectData();};img.src = '';},collectData : function() {var width = this.commonStuff.width;var height = this.commonStuff.height;var tileSize = this.commonStuff.tileSize;var ctx = this.commonStuff.sourceContext;var dataArray = this.commonStuff.dataArray;for ( var i = 0 ; i < width ; i += tileSize ) {for ( var q = 0 ; q < height ; q += tileSize ) {var pixelInfo = ctx.getImageData(i, q, 1, 1);dataArray.push({alpha: 255 - pixelInfo.data[2],column: i,row: q  });}}//this.boxesFlat();this.drawBoxes();},//THIS WAS THE SAME THING ON A 2D CANVAS, JUST FOR TESTING PURPOSESboxesFlat : function() {var data = this.commonStuff.dataArray;var arrayLength = data.length;var tileSize = this.commonStuff.tileSize;var width = this.commonStuff.width;var height = this.commonStuff.height;var row = -1;var ctx = this.commonStuff.sourceContext;for ( var i = 0 ; i < arrayLength ; i++ ) {var item = data[i];ctx.fillStyle = "rgb("+ (255 - item.alpha) + "," +(255 - item.alpha)+ "," + (255 - item.alpha)+ ")" ;ctx.fillRect( item.column, item.row, 4, 4 )}},//CREATE ALL THE BOXESdrawBoxes : function(  ) {var data = this.commonStuff.dataArray;var arrayLength = data.length;var tileSize = this.commonStuff.tileSize;var width = this.commonStuff.width;var height = this.commonStuff.height;var row = -1;var self = this;//THREEJS STUFF// set the scene sizevar WIDTH = 750,HEIGHT = 500// set some camera attributesvar VIEW_ANGLE = 45,ASPECT = WIDTH / HEIGHT,NEAR = 0.1,FAR = 10000;// get the DOM element to attach to// - assume we've got jQuery to handvar $container = $('#container');// create a WebGL renderer, camera// and a scenevar renderer = new THREE.WebGLRenderer();var camera =new THREE.PerspectiveCamera(VIEW_ANGLE,ASPECT,NEAR,FAR);var scene = new THREE.Scene();// add the camera to the scenescene.add(camera);// the camera starts at 0,0,0// so pull it backcamera.position.z = 700;camera.position.y = 0;//camera.lookAt(0,0,0)// start the rendererrenderer.setSize(WIDTH, HEIGHT);// attach the render-supplied DOM element$container.append(renderer.domElement);// create a point lightvar ambientLight =new THREE.AmbientLight(0x404040);var pointLight = new THREE.DirectionalLight(0xFFFFFF);// set its positionpointLight.position.x = 10;pointLight.position.y = 50;pointLight.position.z = 130;// add to the scenescene.add(pointLight);scene.add(ambientLight);var whiteMaterial =new THREE.MeshLambertMaterial({color: 0xFFFFFF});var greyMaterial =new THREE.MeshLambertMaterial({color: 0x444444});var cubeTopGeo = new THREE.CubeGeometry(800, 10, 10);var cubeTop = new THREE.Mesh( cubeTopGeo, greyMaterial);cubeTop.position.y = 250;cubeTop.position.z = -20;var cubeBottomGeo = new THREE.CubeGeometry(800, 10, 10);var cubeBottom = new THREE.Mesh( cubeTopGeo, greyMaterial);cubeBottom.position.y = -250;cubeBottom.position.z = -20;scene.add(cubeTop)scene.add(cubeBottom)//SCENEvar planeGeo = new THREE.PlaneGeometry(800, 500, 1, 1);var planeMesh = new THREE.Mesh( planeGeo, whiteMaterial);planeMesh.position.z = -20;scene.add(planeMesh)var otherMaterial =new THREE.MeshLambertMaterial({color: 0x2583db});// set up the sphere varsvar radius = 8,segments = 8,rings = 8;var geometry = new THREE.CubeGeometry( tileSize - 4, tileSize - 4, tileSize - 4 );var sphere = new THREE.SphereGeometry( tileSize - 10, 4, 4 );//LOOP TO CREATE ALL THE BLOCKS FROM THE DATA ARRAY PREVIOUSLY POPULATEDfor ( var i = 0 ; i < arrayLength ; i ++ ) {var item = data[i];// create the boxes materialvar material =new THREE.MeshLambertMaterial({//color: 0xEA80B0color: 0x444444});if(item.alpha > 30) {var mesh = new THREE.Mesh( geometry, material );} else {var mesh = new THREE.Mesh( sphere, otherMaterial );}//new mesh//position x//mesh.position.x = item.column - 350;mesh.position.x = 0;//position y//mesh.position.y = (20 - (item.row - 200));mesh.position.y = 0;//if it is not sea/*if(item.alpha > 30) {mesh.position.z = ((item.alpha ) * this.commonStuff.heightGain) * 10;mesh.scale.set(1 ,1 , (item.alpha + .1) * this.commonStuff.heightGain);}*///had to add .1 because inverting a matrix3 thing with 0 was logging an errorthis.commonStuff.cubesArray.push({mesh: mesh,positionX : item.column - 370,positionY :(20 - (item.row - 180)),//animatable: item.alpha < 10,alpha: 100/255 * item.alpha})// add the box to the scenescene.add(mesh);}var m = 0;var loop = this.commonStuff.cubesArray.length;var scaleCancer = false;//Didn't use request animation, don't even know why..var t = window.setInterval( function() {m++;// animation loop!for ( var i = 0 ; i < loop ; i++ ) {var current = self.commonStuff.cubesArray[i];if( m == 30 ) {self.commonStuff.hReached = true;self.commonStuff.vReached = false;}if( m == 80 ) {self.commonStuff.vReached = true;}if (m == 150) {scaleCancer = true;}if( !self.commonStuff.hReached ) {current.mesh.position.x = current.mesh.position.x + ( current.positionX - current.mesh.position.x ) / 10;}if( !self.commonStuff.vReached ) {current.mesh.position.y = current.mesh.position.y + ( current.positionY - current.mesh.position.y ) / 10;}if ( current.alpha < self.commonStuff.currentShow && current.alpha > self.commonStuff.minShow) {//console.log('ye')current.mesh.scale.z = current.mesh.scale.z + ( current.alpha / 10 - current.mesh.scale.z) / 20 ;current.mesh.material.color.setHex(0xEA80B0);} else {if (current.alpha > 12 ) {current.mesh.scale.z = current.mesh.scale.z + ( 1 - current.mesh.scale.z) / 20;current.mesh.material.color.setHex(0x444444);} else {current.mesh.position.z = Math.sin( (m + current.mesh.position.x) / 20 ) * 8}}}if (self.commonStuff.mouseDown) {camera.position.z -= 2;}camera.lookAt( scene.position );renderer.render(scene, camera);}, 10);//LISTENERSvar container = document.getElementById('container');//var zero = document.getElementById('zero');var one = document.getElementById('one');var two = document.getElementById('two');var three = document.getElementById('three');var four = document.getElementById('four');var five = document.getElementById('five');/*zero.onmousedown = function(e) {self.commonStuff.minShow = 0;self.commonStuff.currentShow = 10;e.preventDefault();};*/one.onmousedown = function(e) {self.commonStuff.minShow = 22;self.commonStuff.currentShow = 44;$('.button').removeClass('active');$(this).addClass('active');e.preventDefault();};two.onmousedown = function(e) {self.commonStuff.minShow = 44;self.commonStuff.currentShow = 57;$('.button').removeClass('active');$(this).addClass('active');e.preventDefault();};three.onmousedown = function(e) {self.commonStuff.minShow = 57;self.commonStuff.currentShow = 74;$('.button').removeClass('active');$(this).addClass('active');e.preventDefault();};four.onmousedown = function(e) {self.commonStuff.minShow = 74;self.commonStuff.currentShow = 92;$('.button').removeClass('active');$(this).addClass('active');e.preventDefault();};five.onmousedown = function(e) {self.commonStuff.minShow = 92;self.commonStuff.currentShow = 150;$('.button').removeClass('active');$(this).addClass('active');e.preventDefault();};container.onmousedown = function(e) {//self.commonStuff.mouseDown = true;self.commonStuff.currentShow = Math.random() * 100;}container.onmouseup = function(e) {//self.commonStuff.mouseDown = false;}//Camera movementcontainer.onmousemove = function(e) {camera.position.x = (e.offsetX - 350) / 2;camera.position.y = (e.offsetY - 250) / 2;}}}//DIDN'T USE INIT because I don't want to init a friggin' cancer :(BreastCancer.doNotInit();

疫情可视化(visualization)相关推荐

  1. Python新冠疫情可视化分析系统 计算机专业毕业设计源码08504

    摘 要 文中首先对新冠疫情可视化分析的项目需求进行了背景分析,接着介绍了项目的总体设计思路,然后具体阐述了疫情数据库的设计.疫情数据的查询.疫情数据的展示,并分析了核心代码.文中利用MySQL数据库存 ...

  2. 记录自己三天速成django+html制作国内疫情可视化平台的过程(二)

    3.可视化页面 3.1设计 经过(一)中的操作,我们已经将登录/注册的功能基本实现.下面就是设计可视化页面了,一共会画8张图,我初步的设计是这样的: {% load static %} <!DO ...

  3. 大数据疫情可视化平台1_基于Hadoop3.2.1、Hive3.1.2、搭建疫情信息可视化系统

    前言 项目效果展示 项目源码免费获得请私信博主,绝对免费! 目录 Linux基础命令:往期博客Linux课堂篇3_Linux目录结构.快捷键.常用基础命令 Hadoop3.2.1介绍与环境搭建 Hiv ...

  4. 【实战篇】39 # 如何实现世界地图的新冠肺炎疫情可视化?

    说明 [跟月影学可视化]学习笔记. 世界地图新冠肺炎疫情可视化 下面将实现世界地图新冠肺炎疫情可视化.数据用的是从 2020 年 1 月 22 日到 3 月 19 日这些天的新冠肺炎疫情进展.效果类似 ...

  5. python爬虫疫情可视化

    学习了pyecharts后来小试牛刀下,来做一个中国疫情可视化 首先安装pyecharts库 1.可以直接在pycharm上装 2.也可以更快命令行装,win+r cmd pip install -i ...

  6. 全球疫情可视化实时更新

    全球疫情可视化实时更新 1. 配置 boostrap为前端框架,echarts可视化,jQuery获取.处理数据 2. 思路 前端框架搭好,这里不细说 后端用JQuery从API中获取数据 3. 如何 ...

  7. 数据可视化之疫情可视化

    一 前言 新型冠状病毒肺炎(COVID-19,简称"新冠肺炎")疫情肆虐全球多个国家,2020年3月11日,世界卫生组织 (WHO) 正式宣布将新冠肺炎列为全球性大流行病. 在全球 ...

  8. 基于Springboot的新冠疫情可视化管理系统(可视化展示+后台管理功能)

    这里写自定义目录标题 基于Springboot的新冠疫情可视化管理系统 基础环境: 功能快捷键 实现效果图 源码查看 基于Springboot的新冠疫情可视化管理系统 本项目有基于Springboot ...

  9. 疫情数据可视化-湖北省疫情可视化软件设计大赛作品

    湖北省疫情监测中心(疫情数据可视化)目录 前言 一.数据可视化 二.疫情可视化 湖北省疫情监测中心 ① 主要框架 ② 数据爬取 ③ 疫情可视化模块(疫情监测模块) ④ 便民信息可视化模块(检测信息模块 ...

  10. Flask+Echarts搭建全国疫情可视化大屏

    Flask+Echarts搭建全国疫情可视化大屏 1.前言 2.实现 2.1 搭建flask应用 2.2 编写html及其对应css代码 2.3 可视化展示 2.3.1 左上角板块 2.3.2 中间上 ...

最新文章

  1. 111.二叉树的最小深度
  2. 开发日记-20190821 关键词 读书笔记《掌控习惯》DAY 1
  3. Spring Cloud【Finchley】-09Feign使用Hystrix
  4. spring AOP解析之xml方式详解
  5. SAP Spartacus cxOutlet里的元数据存储,outlet名称和待渲染Component的映射关系
  6. 方向向量转欧拉角_欧拉角、旋转向量和旋转矩阵的相互转换
  7. AngularJS:表达式
  8. 服务器虚拟化之-——VMware组件与功能。
  9. 带用户名和密码的GitHub链接
  10. 新电脑怎么分盘_新买的笔记本电脑收货后,该如何验机?
  11. java 访问权限控制
  12. mysql查阅建立的库_mysql 怎么查看创建的数据库和表
  13. 查看MySQL数据库大小
  14. 赢在电子商务网站制作与营销:B2C版
  15. Linux中vi的退出命令
  16. 微信小程序订阅消息 微信公众号模板消息
  17. c语言if语句用法总结,C语言if语句总结.doc
  18. 今天母亲节,作为程序员,我是这样表达爱的……
  19. 【第005问 Unity中如何显示三角形中心法线?】
  20. 上海万国驾校 科目三考试

热门文章

  1. 关于微星主板官网下载网卡驱动后,网络适配器消失的问题
  2. Linux系统的注销与关闭
  3. Session注销方式
  4. phpoffice 编辑excel文档
  5. 苹果自带地图定位 经纬度
  6. Axure交互式设计
  7. 【GANs学习笔记】(十六)CGAN、TRIPLEGAN
  8. 经典算法研究系列:八、再谈启发式搜索算法
  9. wmware16如何安装win7---超详细
  10. 服务器打不开微信怎么办,手机wifi只能用微信,打不开网页怎么处理?