首页 > 编程语言 >(2)cessium python 选择TXT文件gnss估计可视化

(2)cessium python 选择TXT文件gnss估计可视化

时间:2024-06-15 20:32:57浏览次数:25  
标签:__ latitude python JPG height gnss longitude cessium DJI

   

1 注册账号

https://ion.cesium.com/tokens?page=1

10511
L4

2 获取秘钥

https://ion.cesium.com/tokens?page=1

 

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIyZmVmYjIwZC01MWMwLTQ1ODMtOTgyYi01NWRlYjI5MDQzZTQiLCJpZCI6MzY5MTAsImlhdCI6MTcxODQ0MzQyM30.W67FXIW320E6hr9RLPj-I107TqSjrzEZoIB6cDXO50A

  

 

3 部署python flask

pip install Flask

  

4 部署censuim代码 离线库

https://ion.cesium.com/tokens?page=1

 

 主要依赖库位置

调用工程

 

 

 依赖cesuim库代码位置修改

<head>
  <script src="Cesium-1.118/Build/Cesium/Cesium.js"></script>
  <link href="Cesium-1.118/Build/Cesium/Widgets/widgets.css" rel="stylesheet">
  <link href="style.css" rel="stylesheet">
</head>

  

5开发

 

5-1运行

activate py38
python gnss_show.py

  

 界面

 

 

 5-2代码

 

输入 txt数据

 

DJI_0002.JPG 34.032505638888885 108.76779925 514.638
DJI_0005.JPG 34.03267641666667 108.76781155555555 514.464
DJI_0011.JPG 34.03394725 108.76789833333333 514.635
DJI_0015.JPG 34.03487661111111 108.76796561111111 514.642
DJI_0018.JPG 34.03509530555555 108.76797844444444 514.615
DJI_0022.JPG 34.03506447222222 108.76773913888889 514.582
DJI_0025.JPG 34.03463080555555 108.76770336111112 514.66
DJI_0028.JPG 34.03403180555556 108.76765755555556 514.578
DJI_0031.JPG 34.033382777777774 108.76761005555555 514.547
DJI_0035.JPG 34.03253316666667 108.7675511111111 514.661
DJI_0041.JPG 34.032487583333335 108.76718336111111 514.831
DJI_0042.JPG 34.03248605555555 108.76717719444444 514.781
DJI_0048.JPG 34.03325102777778 108.76728608333333 514.608
DJI_0051.JPG 34.03387375 108.76732563888889 514.609
DJI_0052.JPG 34.034081083333334 108.76734075 514.59
DJI_0055.JPG 34.03470161111111 108.76738266666666 514.587
DJI_0061.JPG 34.03516225 108.76709783333334 514.61
DJI_0065.JPG 34.03492263888889 108.7670823888889 514.535
DJI_0068.JPG 34.03433427777777 108.76704025 514.691
DJI_0072.JPG 34.033466999999995 108.76698133333333 514.629
DJI_0075.JPG 34.03280680555555 108.76694088888888 514.528
DJI_0078.JPG 34.03247211111111 108.76691944444444 514.524
DJI_0081.JPG 34.03250063888889 108.76672519444445 514.701
DJI_0085.JPG 34.032728444444444 108.7665366388889 514.542
DJI_0091.JPG 34.03391938888889 108.76662430555555 514.618
DJI_0092.JPG 34.03412261111111 108.76664058333333 514.588
DJI_0098.JPG 34.03518033333333 108.76671308333333 514.628
DJI_0101.JPG 34.035119083333335 108.76656191666666 514.596
DJI_0102.JPG 34.03512708333333 108.76638525 514.611
DJI_0105.JPG 34.03509647222222 108.76637558333333 514.643
DJI_0111.JPG 34.033914833333334 108.76629880555555 514.529
DJI_0115.JPG 34.03300075 108.76621002777777 514.643
DJI_0118.JPG 34.032449694444445 108.76618838888889 514.69
DJI_0122.JPG 34.03240563888889 108.765901 514.69
DJI_0125.JPG 34.032411055555556 108.76582372222222 514.662
DJI_0128.JPG 34.03271611111111 108.76583419444444 514.517
DJI_0131.JPG 34.03324172222222 108.76585058333333 514.588
DJI_0135.JPG 34.03400922222222 108.76589261111111 514.61
DJI_0141.JPG 34.03509111111111 108.76597241666667 514.656
DJI_0142.JPG 34.03511819444444 108.76597658333333 514.619

  

  数据格式读取位置

 

gnss_show.py

#激活环境
 
#!/usr/bin/env python2
# -*- coding: utf-8 -*-
import time
from flask import *
 
 
app = Flask(__name__)
 
import os
pathnow=os.getcwd()
pathnow=pathnow.replace('\\','/')
#print(pathnow) #获取当前工作目录路径
#print (os.path.abspath('mainPage0.html'))
 
 
 
app = Flask(
    __name__,
    template_folder='.',  # 表示在当前目录 (myproject/) 寻找模板文件
    static_folder='',     # 空 表示为当前目录 (myproject/) 开通虚拟资源入口
    static_url_path='',
)
 
  
@app.route('/')
def index():
    return render_template('index.html')
 
 
 
  
if __name__ == '__main__':
    app.run(host='0.0.0.0',port='8080')

  

基本例子为了理解

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <script src="Cesium-1.118/Build/Cesium/Cesium.js"></script>
  <link href="Cesium-1.118/Build/Cesium/Widgets/widgets.css" rel="stylesheet">
  
  <style>
  body {
    overflow: hidden;
    margin: 0px;
    padding: 0px;
    height: 100%;
  }
  #cesiumContainer {
    height: 100%;
  }
</style>

</head>
<body>
  <div id="cesiumContainer"></div>
  <script type="module">
    //<link href="style.css" rel="stylesheet">
    // Get your token from https://cesium.com/ion/tokens  秘钥
   Cesium.Ion.defaultAccessToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiIyZmVmYjIwZC01MWMwLTQ1ODMtOTgyYi01NWRlYjI5MDQzZTQiLCJpZCI6MzY5MTAsImlhdCI6MTcxODQ0MzQyM30.W67FXIW320E6hr9RLPj-I107TqSjrzEZoIB6cDXO50A';
 
 
   //1创建地球可视化
   const viewer = new Cesium.Viewer('cesiumContainer', {
      terrain: Cesium.Terrain.fromWorldTerrain(),
    });

    const osmBuildings = await Cesium.createOsmBuildingsAsync();
    viewer.scene.primitives.add(osmBuildings);
    
    
   //1飞到指定地点 经纬度高度
    viewer.camera.flyTo({
        destination: Cesium.Cartesian3.fromDegrees(-122.384, 37.62, 4000)
      });
 
 
 
    //2创建连续点对
    const flightData = JSON.parse(
      '[{"longitude":-122.39053,"latitude":37.61779,"height":-27.32},{"longitude":-122.39035,"latitude":37.61803,"height":-27.32},{"longitude":-122.39019,"latitude":37.61826,"height":-27.32},{"longitude":-122.39006,"latitude":37.6185,"height":-27.32},{"longitude":-122.38985,"latitude":37.61864,"height":-27.32}]');
 
    // Create a point for each.
    for (let i = 0; i < flightData.length; i++) {
       
     const dataPoint = flightData[i];
 
     const airplaneEntity= viewer.entities.add({
        //点击这个点出现的描述
        description: `Location: (${dataPoint.longitude}, ${dataPoint.latitude}, ${dataPoint.height})`,
        //点的位置
        position: Cesium.Cartesian3.fromDegrees(dataPoint.longitude, dataPoint.latitude, dataPoint.height),
        //点的类型
        point: { pixelSize: 10, color: Cesium.Color.BLUE }
      });
 
    // viewer.flyTo(airplaneEntity);
      
     
    }
 
 
  </script>
</body>
</html>

  

 

标签:__,latitude,python,JPG,height,gnss,longitude,cessium,DJI
From: https://www.cnblogs.com/gooutlook/p/18249694

相关文章

  • Python学习笔记8:入门知识(八)
    前言本篇是元组的知识点学习以及知识点的补充元组概念不可变的列表,叫做元组。在之前列表的特性中,我们就说过列表是可变的,但是在实际使用过程中,我们有时候仍然需要一系列不可变的元素,这个时候就需要元组出场了。定义元组看起来犹如列表,但使用圆括号而不是方括号来标识......
  • 【秋招突围】2024届秋招笔试-小红书笔试题-第一套-三语言题解(Java/Cpp/Python)
    ......
  • python小程序——实现答题作弊
    前言:    本程序可实现对已给出题库的网页知识答题活动能够自动给出答案功能,由于写程序的时候马上就快要到考试时间了,所以写的有点仓促,后续可完善的地方还有很多,不过这个简陋版的能用就行。        本程序的使用步骤是只需鼠标选择一下题目的文本,程序就会自动......
  • python: time object
     #encoding:utf-8#版权所有2024涂聚文有限公司#许可信息查看:#描述:#Author:geovindu,GeovinDu涂聚文.#IDE:PyCharm2023.1python3.11#Datetime:2024/6/1518:59#User:geovindu#Product:PyCharm#Project:pyBaiduAi#F......
  • python保存文件后打不开的原因是什么
    引入数据集,奇怪的是怎么也打不开,显示不存在这个文件:但是,我将文件改个名字,就打开了,难道csv的文件命名必须有一定合法性?import pandasusers = pandas.read_csv("H:\python\data analysis\countries.csv")尝试由此,我试了几个别的名字,直到我尝试了u开头的。原因终......
  • python bytes是什么
    在Python3以后,字符串和bytes类型彻底分开了。字符串是以字符为单位进行处理的,bytes类型是以字节为单位处理的。bytes数据类型在所有的操作和使用甚至内置方法上和字符串数据类型基本一样,也是不可变的序列对象。bytes对象只负责以二进制字节序列的形式记录所需记录的对象,至......
  • Python for循环
    Pythonfor循环for循环的基本语法for循环是编程中常用的结构,用于重复执行一段代码块指定的次数或遍历某个序列(如列表、元组、字符串或集合)中的每个元素。以下是for循环的基本语法结构:for变量in序列:#执行的代码块#可以是任何有效的Python语句#这个代码......
  • python的def函数用法
    Python中的def关键字用于定义函数。函数是一段可重用的代码块,它接受输入(称为参数),执行一些操作,并可以选择性地返回一个输出值。下面是定义和使用Python函数的基本步骤:定义函数:使用def关键字开始定义函数,后跟函数名和圆括号()。圆括号内可以包含零个或多个参数。然后,在......
  • Python武器库 - 科研中常用的python字符串处理 - 字符串扩充
    在python科研编程中,字符串扩充通常在处理文件名、数据集列表、或打印模型训练过程信息时非常实用,尤其是打印模型训练过程信息时,通常需要在每一轮之间打印一行符号表示分隔,此时字符串扩充的功能尤其好用,它能够省去手动输入字符的时间,使得输出字符串更加工整。1.str.center(widt......
  • 比较适合小白练手的Python项目!
    一.学习Python需要掌握的技能成为Python高手需要一定的时间和实践,但以下是一些建议,可以帮助你更快入门并提高技能:学习基础知识:-了解Python的基本语法、数据类型、控制流等。-学习函数、模块和包的使用。深入理解数据结构和算法:-学习常见的数据结构(列表、字典、集合......