찾다
웹 프론트엔드H5 튜토리얼基于HTML5制作在线上海地铁图


       某市政项目要用到地铁图,展示上海地铁站点以及相关信息流,尝试使用HTML5技术来实现,自己折腾有点慢,找到一个HTML5的图形组件-Qunee for HTML5,简单学习一下,就可以很好的解决这类需求,做出优美的展现,下面以上海2012地铁图为例,效果如下:

基于HTML5制作在线上海地铁图


      示例讲解

       首先需要解决数据问题,可以从维基百科或者上海地铁官网中获取,不过也免不了人工,要达到良好的显示效果,需要不只要记录站点的位置,还需要设置文本标签的理想位置,有时为了避免文字叠加,需要设置旋转角度……总之事在人为,想想办法,最终解决了数据问题,再加上Qunee图形组件的强大展示效果,做出来可以交互的在线地铁图

       数据格式

       采用JSON格式数据,分三种类型:文本标签、站点、地铁线

       总的结构如下:

  1. {
  2. "labels" : [  ... ],
  3. "stations" : [ ... ],
  4. "lines" : [ ... ]
  5. }
复制代码

       文本标签数据

       包含坐标和文字信息,如果文字需要旋转,则会增加”rotate”属性,下面是“莘庄”文本标签信息
  1. {
  2. "text" : "莘庄",
  3. "x" : 883.591,
  4. "y" : 1625.695
  5. }
复制代码

       文字与节点旋转效果

基于HTML5制作在线上海地铁图


       站点数据

       包含坐标、旋转角度以及编号信息,下面是“莘庄”站的信息

  1. {
  2. "id" : 5,
  3. "x" : 869.8513512641732,
  4. "y" : 1597.6559686949402,
  5. "rotate" : 0.7853981633974483
  6. }
复制代码

       地铁线数据

       包含名称,颜色,以及经过的站点编号

  1. {
  2. "name" : "1",
  3. "color" : "#e52035",
  4. "stations" : [64, 70, 67, 71, 72, 65, 69, 73, 66, 68, 63, 62, 22, 61, 60, {"id": 21, "yOffset": 0.5}, 59, {"id": 18, "yOffset": -0.5}, 17, 58, 14, 7, 57, 6,
  5. 56, 44, 47, 5]
  6. }
复制代码

       对于特殊情况,比如两条地铁线共用一条线路的情况,会出现两条线重合,为了避免这种情况,还可以指定站点横向偏移量,比如上面一号线中的如下数据

  1. {"id": 21, "yOffset": 0.5}
复制代码

       因为上海地铁三号线与四号线共用线路较多,所以这种处理更加明显

       三号线数据

  1. {
  2. "name" : "3",
  3. "color" : "#f9d300",
  4. "stations" : [6, 95, 96, 97, {"id":12,"yOffset":0.5}, {"id":11,"yOffset":0.5}, {"id":8,"yOffset":0.5}, {"id":9,"yOffset":0.5},
  5. {"id":10,"yOffset":0.5}, {"id":25,"yOffset":0.5}, {"id":26,"yOffset":0.5}, {"id":238,"yOffset":0.5}, {"id":22,"yOffset":-0.5}, {"id":27,"yOffset":-0.5},
  6. 98, 99, 100, 101, 104, 105, 107, 108, 109, 106, 110, 111]
  7. }
复制代码

       地铁共线效果

基于HTML5制作在线上海地铁图

       创建图元

       数据需要转换成qunee图元对象,三种类型分别对应三个创建函数

       创建文本标签
  1. function createText(name, x, y, rotate){
  2.     var text = graph.createNode(name, x, y);
  3.     if(rotate){
  4.         text.rotate = rotate;
  5.     }
  6.     text.zIndex = 20;
  7.     text.image = null;
  8.     text.setStyle(Q.Styles.BACKGROUND_COLOR, Q.toColor(0x88FFFFFF));
  9.     text.setStyle(Q.Styles.LABEL_ANCHOR_POSITION, Q.Position.LEFT_BOTTOM);
  10.     text.setStyle(Q.Styles.LABEL_POSITION, Q.Position.CENTER_MIDDLE);
  11.     text.setStyle(Q.Styles.LABEL_PADDING, PADDING);
  12.     return text;
  13. }
复制代码

       创建站点

  1. function createStation(station){
  2.     var node = graph.createNode(null/**station.name*/, station.x, station.y);
  3.     node.stationId = station.id;
  4.     node.setStyle(Q.Styles.LABEL_FONT_SIZE, 10);
  5.     node.setStyle(Q.Styles.LABEL_ANCHOR_POSITION, Q.Position.CENTER_MIDDLE);
  6.     node.setStyle(Q.Styles.LABEL_POSITION, Q.Position.CENTER_MIDDLE);
  7.     node.zIndex = 10;
  8.     if(station.rotate){
  9.         node.image = roundRect;
  10.         node.rotate = station.rotate;
  11.     }else{
  12.         node.image = circle;
  13.     }
  14.     node.setStyle(Q.Styles.SHAPE_FILL_COLOR, "#FFF");
  15.     node.setStyle(Q.Styles.SHAPE_STROKE_STYLE, "#000");
  16.     return node;
  17. }
复制代码

       创建地铁线

       createLine(…)函数用于创建地铁线,使用了节点类型图元,并设置节点主体为路径,函数updateLine(…)用于从站点信息自动生成线路路径

  1. function createLine(line){
  2.     var stations = line.stations;

  3.     var node = graph.createNode(line.name);
  4.     node.stations = stations;
  5.     node.movable = false;
  6.     node.setStyle(Q.Styles.LABEL_FONT_SIZE, 50);
  7.     node.setStyle(Q.Styles.LABEL_COLOR, line.color);
  8.     node.setStyle(Q.Styles.LABEL_ANCHOR_POSITION, Q.Position.LEFT_BOTTOM);
  9.     node.setStyle(Q.Styles.LABEL_POSITION, Q.Position.LEFT_TOP);
  10.     node.setStyle(Q.Styles.LAYOUT_BY_PATH, true);
  11.     node.anchorPosition = null;
  12.     node.setStyle(Q.Styles.SHAPE_STROKE, size);
  13.     node.setStyle(Q.Styles.SHAPE_STROKE_STYLE, line.color);

  14.     updateLine(node, true);
  15.     return node;
  16. }
复制代码
  1. function updateLine(line, addListener){
  2.     var path = new Q.Path();
  3.     line.image = path;

  4.     var stations = line.stations;
  5.     var first = true;
  6.     Q.forEach(stations, function(s){
  7.         var station = getStation(s.id || s);
  8.         if(!station){
  9.             return;
  10.         }
  11.         if(addListener){
  12.             addLocationChangeListener(station.stationId, line);
  13.         }
  14.         var location = station.location;
  15.         var x = location.x, y = location.y;
  16.         if(s.yOffset){
  17.             var offset = s.yOffset * size;
  18.             var rotate = station.rotate || 0;
  19.             var sin = Math.sin(rotate);
  20.             var cos = Math.cos(rotate);
  21.             x += cos * offset;
  22.             y += sin * offset;
  23.         }
  24.         if(first){
  25.             first = false;
  26.             path.moveTo(x, y);
  27.         }else{
  28.             path.lineTo(x, y);
  29.         }
  30.     })
  31. }
复制代码

        交互处理

        增加交互处理,监听站点拖动事件,保持地铁路线跟随站点位置变化

  1. graph.interactionDispatcher.addListener(function(evt){
  2.     if(evt.kind != Q.InteractionEvent.ELEMENT_MOVING){
  3.         return;
  4.     }
  5.     var datas = evt.datas;

  6.     Q.forEach(datas, function(data){
  7.         if(!data.stationId){
  8.             return;
  9.         }
  10.         var listeners = stationLocationChangeListeners[data.stationId];
  11.         if(listeners){
  12.             for(var l in listeners){
  13.                 updateLine(listeners[l]);
  14.             }
  15.         }
  16.     });
  17. });
复制代码

在线示例

来源:http://blog.chinaunix.net/uid-29563534-id-4171575.html

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
뷰포트 메타 태그를 사용하여 모바일 장치에서 페이지 스케일링을 제어하려면 어떻게합니까?뷰포트 메타 태그를 사용하여 모바일 장치에서 페이지 스케일링을 제어하려면 어떻게합니까?Mar 13, 2025 pm 08:00 PM

이 기사에서는 Viewport Meta 태그를 사용하여 모바일 장치의 페이지 스케일링을 제어하여 폭과 최적의 응답 성 및 성능을위한 초기 스케일과 같은 설정에 중점을 둡니다. character count : 159

내 HTML5 웹 사이트에 오디오를 추가하는 방법은 무엇입니까?내 HTML5 웹 사이트에 오디오를 추가하는 방법은 무엇입니까?Mar 10, 2025 pm 03:01 PM

이 기사는 & lt; audio & gt를 사용하여 HTML5에 오디오를 포함시키는 방법을 설명합니다. 형식 선택에 대한 모범 사례 (MP3, OGG Vorbis), 파일 최적화 및 재생에 대한 JavaScript 컨트롤을 포함한 요소. 다중 오디오를 사용하는 것을 강조합니다

HTML5 및 JavaScript로 대화 형 게임을 만드는 방법은 무엇입니까?HTML5 및 JavaScript로 대화 형 게임을 만드는 방법은 무엇입니까?Mar 10, 2025 pm 06:34 PM

이 기사는 JavaScript를 사용하여 대화식 HTML5 게임을 만드는 자세한 내용입니다. 게임 디자인, HTML 구조, CSS 스타일, JavaScript 로직 (이벤트 처리 및 애니메이션 포함) 및 오디오 통합을 다룹니다. 필수 JavaScript 라이브러리 (Phaser, PI

사용자 입력에 HTML5 양식을 사용하는 방법은 무엇입니까?사용자 입력에 HTML5 양식을 사용하는 방법은 무엇입니까?Mar 10, 2025 pm 02:59 PM

이 기사에서는 HTML5 양식을 작성하고 검증하는 방법을 설명합니다. 그것은 & lt; form & gt; 요소, 입력 유형 (텍스트, 이메일, 번호 등) 및 속성 (필수, 패턴, 최소, 최대). HTML5의 장점은 오래된 방법에 비해 형성됩니다

Geolocation API로 사용자 위치 개인 정보 및 권한을 어떻게 처리합니까?Geolocation API로 사용자 위치 개인 정보 및 권한을 어떻게 처리합니까?Mar 18, 2025 pm 02:16 PM

이 기사는 지리적 위치 API를 사용하여 사용자 위치 개인 정보 및 권한 관리, 권한 요청, 데이터 보안 보장 및 개인 정보 보호법 준수에 대한 모범 사례를 강조하는 것에 대해 설명합니다.

HTML5 페이지 가시성 API를 사용하여 페이지가 표시되는시기를 감지하려면 어떻게합니까?HTML5 페이지 가시성 API를 사용하여 페이지가 표시되는시기를 감지하려면 어떻게합니까?Mar 13, 2025 pm 07:51 PM

이 기사에서는 HTML5 페이지 가시성 API를 사용하여 페이지 가시성을 감지하고 사용자 경험을 향상 시키며 리소스 사용량을 최적화하는 것에 대해 설명합니다. 주요 측면에는 미디어 일시 정지, CPU 부하 감소 및 가시성 변경에 기반한 분석 관리가 포함됩니다.

대화식 사용자 인터페이스에 HTML5 드래그 앤 드롭 API를 어떻게 사용합니까?대화식 사용자 인터페이스에 HTML5 드래그 앤 드롭 API를 어떻게 사용합니까?Mar 18, 2025 pm 02:17 PM

이 기사는 HTML5 드래그 앤 드롭 API를 사용하여 대화식 사용자 인터페이스를 생성하고 요소를 드래그 가능하게 만들고 주요 이벤트를 처리하며 사용자 정의 피드백으로 사용자 경험을 향상시키는 방법을 자세히 설명합니다. 또한 일반적인 함정에 대해 설명합니다

클라이언트와 서버 간의 양방향 통신에 HTML5 WebSockets API를 어떻게 사용합니까?클라이언트와 서버 간의 양방향 통신에 HTML5 WebSockets API를 어떻게 사용합니까?Mar 12, 2025 pm 03:20 PM

이 기사에서는 실시간, 양방향 클라이언트 서버 커뮤니케이션을위한 HTML5 WebSockets API를 설명합니다. 클라이언트 측 (JavaScript) 및 서버 측 (Python/Flask) 구현에 대해 자세히 설명하여 확장 성, 상태 관리,

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구