首页 web前端 js教程 使用 OpenAI 增强您的 ArcGIS Web 应用程序

使用 OpenAI 增强您的 ArcGIS Web 应用程序

Jan 02, 2025 pm 05:52 PM

随着我在编码经验和职业生涯中的进步(老实说,在我的一生中),我一直在寻找有趣的方法来将我学到的知识与我所知道的联系起来。最近,我一直在为希望在地图应用程序中添加一些人工智能的 Web 开发人员创建一个视频系列。我很高兴测试不同的人工智能库并向开发人员展示在他们的应用程序中实现这些库是多么容易。

今天,我将指导您完成一个教程,该教程展示了如何使用最少的代码生成有关位置的见解。我们将使用 OpenAI API 以及 ArcGIS Maps SDK for JavaScript 和现代 Web 组件方法。这是一种向 Web 应用程序添加强大的地图功能的简单且声明性的方法。如果您不熟悉这些工具,请不要担心 - 我将指导您完成每个步骤。

AI ArcGIS JS SDK 项目设置

首先,我们将使用简单的 HTML、CSS 和 JS 设置。在 Visual Studio Code 中,我将创建 HTML、CSS 和 JS 文件。在 HTML 中,我将使用 ! 输入基本 HTML 设置的快捷方式。我还会确保链接我的 CSS 和 JS 文件。这是目前为止的样子:

    <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
        <link rel="stylesheet" href="/styles.css" />
        <script src="/scripts.js"></script>
      </head>
      <body>
      </body>
    </html>
登录后复制
登录后复制

HTML 设置

由于我使用的是 ArcGIS Maps SDK for JS 组件,因此我需要通过 CDN 添加几个库 — Calcite 组件和 ArcGIS JS SDK。为了简单起见,我们使用 CDN,但对于大型生产应用程序,建议使用 npm。

    <link rel="stylesheet" type="text/css" href="https://js.arcgis.com/calcite-components/2.13.2/calcite.css" />
    <link rel="stylesheet" href="https://js.arcgis.com/4.31/esri/themes/light/main.css" />

    <script type="module" src="https://js.arcgis.com/calcite-components/2.13.2/calcite.esm.js"></script>    
    <script src="https://js.arcgis.com/4.31/"></script>
    <script type="module" src="https://js.arcgis.com/map-components/4.31/arcgis-map-components.esm.js"></script>
登录后复制
登录后复制

在使用 ArcGIS 地图样式之前,我将使用 ArcGIS API 密钥设置身份验证。 注意:切勿在前端公开暴露您的 API 密钥。在生产环境中,您应该使用后端服务器来安全地处理 API 请求和管理密钥。现在,为了简单起见,我将在 HTML 文件中将其包含在所有其他脚本标记之上。

    <script>
       var esriConfig = {
         apiKey: "yourKey"
       };
    </script>
登录后复制
登录后复制

现在,我可以使用自定义元素来表示地图,并根据自己的喜好设置底图、中心(经度、纬度)和缩放属性。

    <arcgis-map basemap="arcgis/topographic" center="-77.02, 38.89" zoom="13">
      <arcgis-zoom position="top-left"></arcgis-zoom>
    </arcgis-map>
登录后复制
登录后复制

最终 HTML 文件应如下所示:

    <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>OpenAI + ArcGIS Map</title>

        <script>
          var esriConfig = {
            apiKey: "yourKey"
          };
        </script>

        <link rel="stylesheet" type="text/css" href="https://js.arcgis.com/calcite-components/2.13.2/calcite.css" />
        <link rel="stylesheet" href="https://js.arcgis.com/4.31/esri/themes/light/main.css" />
        <link rel="stylesheet" href="/styles.css" />

        <script type="module" src="https://js.arcgis.com/calcite-components/2.13.2/calcite.esm.js"></script>    
        <script src="https://js.arcgis.com/4.31/"></script>
        <script type="module" src="https://js.arcgis.com/map-components/4.31/arcgis-map-components.esm.js"></script>
      </head>
     <body>
        <arcgis-map basemap="arcgis/topographic" center="-77.02, 38.89" zoom="13">
          <arcgis-zoom position="top-left"></arcgis-zoom>
        </arcgis-map>
        <script src="/scripts.js"></script>
     </body>
    </html>
登录后复制

CSS 设置

现在,进入 CSS。我们将首先定位 html、body 和 arcgis-map 元素。由于我希望我的地图占据整个页面,因此我将确保没有预定义的填充或边距,并且它占据页面高度和宽度的 100%。

    html,
    body,
    arcgis-map {
      padding: 0;
      margin: 0;
      height: 100%;
      width: 100%;
    }
登录后复制

此时,您将能够在屏幕上看到您的 ArcGIS JS 地图。功能仅限于缩放和平移,所以让我们继续!

Enhance Your ArcGIS Web App with OpenAI

JS设置

现在,进入有趣的部分 - 让我们的地图与 OpenAI 交互!首先,我们需要定义用于身份验证的 OpenAI API 密钥。您需要拥有 OpenAI 帐户才能获得它。之后,我们将通过从 DOM 中选择自定义元素并将其分配给 arcgisMap 变量来获取地图。这让我们能够以编程方式操作地图。

    <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
        <link rel="stylesheet" href="/styles.css" />
        <script src="/scripts.js"></script>
      </head>
      <body>
      </body>
    </html>
登录后复制
登录后复制

说到与我们的地图交互,我们将继续向其添加一个事件侦听器。我们将捕获 arcgisViewClick 事件,该事件在用户单击地图上的任意位置时触发。这将帮助我们获取点击的位置并将其发送到 OpenAI API。

用户点击后,我们将从事件详细信息中提取地图坐标(mapPoint)并将其存储在 params 对象中。这为我们提供了用户点击的位置(经度、纬度)。我们还将使用 outFields: "*" 来请求单击的功能的所有属性(您可以根据您的需要对其进行细化)。

    <link rel="stylesheet" type="text/css" href="https://js.arcgis.com/calcite-components/2.13.2/calcite.css" />
    <link rel="stylesheet" href="https://js.arcgis.com/4.31/esri/themes/light/main.css" />

    <script type="module" src="https://js.arcgis.com/calcite-components/2.13.2/calcite.esm.js"></script>    
    <script src="https://js.arcgis.com/4.31/"></script>
    <script type="module" src="https://js.arcgis.com/map-components/4.31/arcgis-map-components.esm.js"></script>
登录后复制
登录后复制

现在,让我们继续获取 OpenAI 的响应。首先,我们使用 params.location 中的经度和纬度定义将发送到 API 的提示。接下来,我们将从响应中解构选择数组。这是 OpenAI 将根据我们的提示存储生成的内容的地方。然后,我们将使用 fetch() 调用 OpenAI API,向聊天/完成端点发送 POST 请求。标头包括 Content-Type: application/json 来指示我们正在发送和接收 JSON,以及使用不记名令牌进行身份验证的授权。

在正文中,我们指定模型(我在这里选择 gpt-4o 模型)。然后,我们将在消息字段中传递具有“用户”角色的提示,表明这是用户输入。发出请求后,我们使用await获取响应并调用.json()来解析它。

    <script>
       var esriConfig = {
         apiKey: "yourKey"
       };
    </script>
登录后复制
登录后复制

最后,我们使用 arcgisMap.popup.open() 在单击的位置显示弹出窗口。经度和纬度是从 params.location 设置的,标题是您选择的任何内容。内容设置为 AI 生成的choices[0].message.content 文本,在地图上显示事实。

    <arcgis-map basemap="arcgis/topographic" center="-77.02, 38.89" zoom="13">
      <arcgis-zoom position="top-left"></arcgis-zoom>
    </arcgis-map>
登录后复制
登录后复制

最终应用程序的实际应用

一切设置完毕后,该应用程序现在允许用户单击地图上的任意位置。根据他们的点击,它将坐标发送到 OpenAI API。 API 生成有关该位置的相关事实,然后将其显示在地图上的弹出窗口中。但不要就此止步 — 享受其中的乐趣!您可以轻松更改发送到 OpenAI 的提示。例如,您可以要求提供一个可怕的事实?、一个有趣的事实?,甚至要求它包含表情符号!

这里有一个包含完整代码的 CodePen,供您参考。

Enhance Your ArcGIS Web App with OpenAI

结论

通过遵循这些步骤,我们成功创建了一个人工智能驱动的地图应用程序。以下是我们所做工作的快速回顾:

  • 通过 CDN 使用 ArcGIS Maps SDK for JavaScript Web Components 设置地图。

  • 使用 OpenAI API 根据点击位置生成动态内容。

  • 在地图上的弹出窗口中显示该内容。

通过这种方法,您已经看到将 AI 和地图工具集成到您的 Web 应用程序中是多么容易。关键要点是,它确实需要最少的设置和代码来构建功能强大的应用程序,将实时用户交互与人工智能见解相结合。

因此,无论您是在增强地图项目还是在探索使用人工智能的新方法,我希望我今天对您有所启发。我很高兴看到你未来的任何创作,所以请在这里或在我的社交媒体上与我分享。我很想看看你的作品!


本文由 Esri 开发者倡导者 Courtney Yatteau 撰写。本文表达的观点仅代表 Courtney 的观点,并不一定代表其雇主的观点、策略或意见。如果您有任何反馈,请随时点赞和/或评论。此外,如果您有任何问题或意见希望私下发送,您可以通过 LinkedIn、X、Bluesky、 或电子邮件联系 Courtney。如果您正在考虑转行、希望进入科技领域,或者对在 Esri 工作的感觉感到好奇,那么请继续关注未来的帖子!您还可以查看 Esri 的职业页面或此视频以了解更多信息。

以上是使用 OpenAI 增强您的 ArcGIS Web 应用程序的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

前端热敏纸小票打印遇到乱码问题怎么办? 前端热敏纸小票打印遇到乱码问题怎么办? Apr 04, 2025 pm 02:42 PM

前端热敏纸小票打印的常见问题与解决方案在前端开发中,小票打印是一个常见的需求。然而,很多开发者在实...

神秘的JavaScript:它的作用以及为什么重要 神秘的JavaScript:它的作用以及为什么重要 Apr 09, 2025 am 12:07 AM

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

谁得到更多的Python或JavaScript? 谁得到更多的Python或JavaScript? Apr 04, 2025 am 12:09 AM

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

如何实现视差滚动和元素动画效果,像资生堂官网那样?
或者:
怎样才能像资生堂官网一样,实现页面滚动伴随的动画效果? 如何实现视差滚动和元素动画效果,像资生堂官网那样? 或者: 怎样才能像资生堂官网一样,实现页面滚动伴随的动画效果? Apr 04, 2025 pm 05:36 PM

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript难以学习吗? JavaScript难以学习吗? Apr 03, 2025 am 12:20 AM

学习JavaScript不难,但有挑战。1)理解基础概念如变量、数据类型、函数等。2)掌握异步编程,通过事件循环实现。3)使用DOM操作和Promise处理异步请求。4)避免常见错误,使用调试技巧。5)优化性能,遵循最佳实践。

JavaScript的演变:当前的趋势和未来前景 JavaScript的演变:当前的趋势和未来前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

如何使用JavaScript将具有相同ID的数组元素合并到一个对象中? 如何使用JavaScript将具有相同ID的数组元素合并到一个对象中? Apr 04, 2025 pm 05:09 PM

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

前端开发中如何实现类似 VSCode 的面板拖拽调整功能? 前端开发中如何实现类似 VSCode 的面板拖拽调整功能? Apr 04, 2025 pm 02:06 PM

探索前端中类似VSCode的面板拖拽调整功能的实现在前端开发中,如何实现类似于VSCode...

See all articles