使用 Angular 连接 Google Maps Nativescript 插件 2
Wiring up Google Maps Nativescript plugin with Angular 2
我正在尝试将 Nativescript (https://github.com/dapriett/nativescript-google-maps-sdk) 的 Google 地图插件与 Angular 2 和 {N}-Angular 路由器一起使用。我让它在 Nativescript 中工作,但是一旦我添加了 Angular 2 和路由器,我就无法让地图显示在 UI.
中
由于 <Page>
标签没有进入 Angular2 {N} 组件模板,我不能在 <Page>
上使用 xmlns:maps="nativescript-google-maps-sdk"
命名空间实例化 <maps:mapView>
{N} 组件基础知识页面提供了一些指导,但它无法按照我尝试过的方式工作:https://docs.nativescript.org/ui/ui-with-xml#user-interface-components
关于执行此操作的正确方法有什么想法吗?
app.component.ts
import {Component} from "angular2/core";
import {RouteConfig} from "angular2/router";
import {NS_ROUTER_DIRECTIVES, NS_ROUTER_PROVIDERS} from "nativescript-angular/router";
import {HomeComponent} from "./pages/home/home.component";
@Component({
selector: "app-main",
directives: [NS_ROUTER_DIRECTIVES],
providers: [NS_ROUTER_PROVIDERS],
template: "<page-router-outlet ></page-router-outlet>"
})
@RouteConfig([
{ path: "/home", component: HomeComponent, as: "Home", useAsDefault: true },
])
export class AppComponent {
}
home.html
<stack-layout orientation="vertical">
<label [text]="message"></label>
<mapView [latitude]="latitude" [longitude]="longitude"
[zoom]="zoom" [bearing]="bearing"
[tilt]="tilt" (mapReady)="OnMapReady"
(markerSelect)="onMarkerSelect"
(cameraChanged)="onCameraChanged">
</mapView>
</stack-layout>
home.component.ts
import {Component} from "angular2/core";
var geolocation = require("nativescript-geolocation");
var mapsModule = require("nativescript-google-maps-sdk");
exports.mapView = mapsModule.MapView; //Doesn't work
exports.mapView = new mapsModule.MapView(); //Doesn't work
exports.mapView = mapsModule; //Doesn't work
@Component({
selector: "home",
templateUrl: "pages/home/home.html",
})
export class HomeComponent {
public message:string = "Message set.";
public latitude:number = 30.0;
public longitude:number = -100.0;
public zoom:number = 10;
public bearing:number = 0;
public tilt:number = 0;
constructor() {
this.message = "Home constructed.";
}
OnMapReady(args) { }
onMarkerSelect(args) { }
onCameraChanged(args) { }
}
您需要使用 element-registry
API 注册 mapView
标签名称,例如:
API 尚未记录在案,但我们应该在接下来的几周内解决该问题。
我发现将此插件与 ns angualr 2 一起使用时,我必须手动将 applicationID 添加到 root/platforms/adnroid 下的 build.gradle 文件中:
android{
defaultConfig{
applicationId "org.nativescript.my_app_name"
这是在我使用tns插件后添加nativescript-google-sdk.
否则应用程序构建成功,但部署时不会安装在设备或模拟器上并检查 logcat,我觉得这很奇怪,因为 nativescript 不会让你编辑 build.gradle 文件。现在使用其他答案中的代码效果很好
我正在尝试将 Nativescript (https://github.com/dapriett/nativescript-google-maps-sdk) 的 Google 地图插件与 Angular 2 和 {N}-Angular 路由器一起使用。我让它在 Nativescript 中工作,但是一旦我添加了 Angular 2 和路由器,我就无法让地图显示在 UI.
中由于 <Page>
标签没有进入 Angular2 {N} 组件模板,我不能在 <Page>
上使用 xmlns:maps="nativescript-google-maps-sdk"
命名空间实例化 <maps:mapView>
{N} 组件基础知识页面提供了一些指导,但它无法按照我尝试过的方式工作:https://docs.nativescript.org/ui/ui-with-xml#user-interface-components
关于执行此操作的正确方法有什么想法吗?
app.component.ts
import {Component} from "angular2/core";
import {RouteConfig} from "angular2/router";
import {NS_ROUTER_DIRECTIVES, NS_ROUTER_PROVIDERS} from "nativescript-angular/router";
import {HomeComponent} from "./pages/home/home.component";
@Component({
selector: "app-main",
directives: [NS_ROUTER_DIRECTIVES],
providers: [NS_ROUTER_PROVIDERS],
template: "<page-router-outlet ></page-router-outlet>"
})
@RouteConfig([
{ path: "/home", component: HomeComponent, as: "Home", useAsDefault: true },
])
export class AppComponent {
}
home.html
<stack-layout orientation="vertical">
<label [text]="message"></label>
<mapView [latitude]="latitude" [longitude]="longitude"
[zoom]="zoom" [bearing]="bearing"
[tilt]="tilt" (mapReady)="OnMapReady"
(markerSelect)="onMarkerSelect"
(cameraChanged)="onCameraChanged">
</mapView>
</stack-layout>
home.component.ts
import {Component} from "angular2/core";
var geolocation = require("nativescript-geolocation");
var mapsModule = require("nativescript-google-maps-sdk");
exports.mapView = mapsModule.MapView; //Doesn't work
exports.mapView = new mapsModule.MapView(); //Doesn't work
exports.mapView = mapsModule; //Doesn't work
@Component({
selector: "home",
templateUrl: "pages/home/home.html",
})
export class HomeComponent {
public message:string = "Message set.";
public latitude:number = 30.0;
public longitude:number = -100.0;
public zoom:number = 10;
public bearing:number = 0;
public tilt:number = 0;
constructor() {
this.message = "Home constructed.";
}
OnMapReady(args) { }
onMarkerSelect(args) { }
onCameraChanged(args) { }
}
您需要使用 element-registry
API 注册 mapView
标签名称,例如:
API 尚未记录在案,但我们应该在接下来的几周内解决该问题。
我发现将此插件与 ns angualr 2 一起使用时,我必须手动将 applicationID 添加到 root/platforms/adnroid 下的 build.gradle 文件中:
android{
defaultConfig{
applicationId "org.nativescript.my_app_name"
这是在我使用tns插件后添加nativescript-google-sdk.
否则应用程序构建成功,但部署时不会安装在设备或模拟器上并检查 logcat,我觉得这很奇怪,因为 nativescript 不会让你编辑 build.gradle 文件。现在使用其他答案中的代码效果很好