Do not handle map event in 3D mode
This commit is contained in:
		| @@ -55,6 +55,7 @@ export const TOGGLELAYERVALUESENABLED = '[Map] ToggleLayerValuesEnabled' | |||||||
| export const GETLAYERVALUE = '[Map] GetLayerValue' | export const GETLAYERVALUE = '[Map] GetLayerValue' | ||||||
| export const GETLAYERVALUESUCCESS = '[Map] GetLayerValueSuccess' | export const GETLAYERVALUESUCCESS = '[Map] GetLayerValueSuccess' | ||||||
| export const TOGGLESHOWDATALAYERSLIDE = '[Map] ToggleShowDataLayerSlide' | export const TOGGLESHOWDATALAYERSLIDE = '[Map] ToggleShowDataLayerSlide' | ||||||
|  | export const SETVIEWSTATE = '[Map] SetViewState' | ||||||
|  |  | ||||||
|  |  | ||||||
| export class Clear implements Action { | export class Clear implements Action { | ||||||
| @@ -323,6 +324,11 @@ export class ToggleShowDataLayerSlide implements Action { | |||||||
|   constructor() {} |   constructor() {} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export class SetViewState implements Action { | ||||||
|  |   readonly type = SETVIEWSTATE; | ||||||
|  |   constructor(public enabled:boolean) {} | ||||||
|  | } | ||||||
|  |  | ||||||
| export type Actions = SetMapState | export type Actions = SetMapState | ||||||
|   | Init |   | Init | ||||||
|   | Clear |   | Clear | ||||||
| @@ -367,5 +373,6 @@ export type Actions = SetMapState | |||||||
|   | GetLayerValueSuccess |   | GetLayerValueSuccess | ||||||
|   | GetLayerValue |   | GetLayerValue | ||||||
|   | SetPeriod |   | SetPeriod | ||||||
|   | ToggleShowDataLayerSlide; |   | ToggleShowDataLayerSlide | ||||||
|  |   | SetViewState; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,10 +27,12 @@ | |||||||
|     <div> |     <div> | ||||||
|  |  | ||||||
|     </div> |     </div> | ||||||
|     <aol-view [zoom]="state.mapState.zoom" [rotation]="state.mapState.rotation"> |     | ||||||
|        <aol-coordinate [x]="state.mapState.xCenter" [y]="state.mapState.yCenter" [srid]="'EPSG:4326'"></aol-coordinate> |       <aol-view [zoom]="state.mapState.zoom" [rotation]="state.mapState.rotation"> | ||||||
|        <fm-map-zoom-to-extent [extent]="state.extent" [animate]="true"></fm-map-zoom-to-extent> |         <aol-coordinate [x]="state.mapState.xCenter" [y]="state.mapState.yCenter" [srid]="'EPSG:4326'"></aol-coordinate> | ||||||
|     </aol-view> |         <fm-map-zoom-to-extent [extent]="state.extent" [animate]="true"></fm-map-zoom-to-extent> | ||||||
|  |      </aol-view>  | ||||||
|  |  | ||||||
|     <aol-interaction-default></aol-interaction-default> |     <aol-interaction-default></aol-interaction-default> | ||||||
|     <aol-interaction-dragrotateandzoom></aol-interaction-dragrotateandzoom> |     <aol-interaction-dragrotateandzoom></aol-interaction-dragrotateandzoom> | ||||||
|     <fm-map-item-layers [itemLayers]="state.baseLayers"></fm-map-item-layers> |     <fm-map-item-layers [itemLayers]="state.baseLayers"></fm-map-item-layers> | ||||||
|   | |||||||
| @@ -94,6 +94,7 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | |||||||
|   public dataLayerSlideValue:number = 50; |   public dataLayerSlideValue:number = 50; | ||||||
|   public dataLayerSlideEnabled = false; |   public dataLayerSlideEnabled = false; | ||||||
|   private visibleAreaBottom = 0; |   private visibleAreaBottom = 0; | ||||||
|  |   private viewEnabled: boolean = true; | ||||||
|    |    | ||||||
|   @ViewChild('map') map; |   @ViewChild('map') map; | ||||||
|   @ViewChild('contentDiv') contentDiv: ElementRef; |   @ViewChild('contentDiv') contentDiv: ElementRef; | ||||||
| @@ -375,6 +376,9 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | |||||||
|       this.dataLayerSlideEnabled=v; |       this.dataLayerSlideEnabled=v; | ||||||
|       this.map.instance.render(); |       this.map.instance.render(); | ||||||
|     }); |     }); | ||||||
|  |     this.store.select(mapReducers.selectGetViewEnabled).subscribe((v) => { | ||||||
|  |       this.viewEnabled = v; | ||||||
|  |     }); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   handleSearchCollapse(event) { |   handleSearchCollapse(event) { | ||||||
| @@ -428,7 +432,7 @@ export class MapComponent implements OnInit, OnDestroy,AfterViewInit { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   handleOnMoveEnd(event) {     |   handleOnMoveEnd(event) {     | ||||||
|     if(this.initialized) { |     if(this.initialized && this.viewEnabled) { | ||||||
|       this.zone.run(() =>{ |       this.zone.run(() =>{ | ||||||
|         console.debug("Move end"); |         console.debug("Move end"); | ||||||
|         var map = event.map; |         var map = event.map; | ||||||
|   | |||||||
| @@ -72,6 +72,7 @@ export interface State { | |||||||
|   layerValuesEnabled:boolean, |   layerValuesEnabled:boolean, | ||||||
|   layerValues: Array<ILayervalue> |   layerValues: Array<ILayervalue> | ||||||
|   showDataLayerSlide:boolean, |   showDataLayerSlide:boolean, | ||||||
|  |   viewEnabled:boolean | ||||||
| } | } | ||||||
|  |  | ||||||
| export const initialState: State = { | export const initialState: State = { | ||||||
| @@ -115,7 +116,8 @@ export const initialState: State = { | |||||||
|   layerValuesY:0, |   layerValuesY:0, | ||||||
|   layerValuesEnabled:false, |   layerValuesEnabled:false, | ||||||
|   layerValues:[], |   layerValues:[], | ||||||
|   showDataLayerSlide:false |   showDataLayerSlide:false, | ||||||
|  |   viewEnabled:true | ||||||
| } | } | ||||||
|  |  | ||||||
| export function reducer(state = initialState, action: mapActions.Actions | commonActions.Actions | RouterNavigationAction): State { | export function reducer(state = initialState, action: mapActions.Actions | commonActions.Actions | RouterNavigationAction): State { | ||||||
| @@ -538,6 +540,10 @@ export function reducer(state = initialState, action: mapActions.Actions | commo | |||||||
|       v.push(a.layervalue); |       v.push(a.layervalue); | ||||||
|       return tassign(state,{layerValues:v}); |       return tassign(state,{layerValues:v}); | ||||||
|     } |     } | ||||||
|  |     case mapActions.SETVIEWSTATE:{ | ||||||
|  |       let a= action as mapActions.SetViewState; | ||||||
|  |       return tassign(state,{viewEnabled:a.enabled}); | ||||||
|  |     } | ||||||
|     case commonActions.ITEMDELETEDEVENT:{ |     case commonActions.ITEMDELETEDEVENT:{ | ||||||
|       let a= action as commonActions.ItemDeletedEvent; |       let a= action as commonActions.ItemDeletedEvent; | ||||||
|       if(state.selectedItem && state.selectedItem.code == a.itemCode) { |       if(state.selectedItem && state.selectedItem.code == a.itemCode) { | ||||||
| @@ -599,6 +605,7 @@ export const getLayerValuesEnabled = (state:State) => state.layerValuesEnabled; | |||||||
| export const getLayerValues = (state:State) => state.layerValues; | export const getLayerValues = (state:State) => state.layerValues; | ||||||
| export const getLayerValuesX = (state:State) => state.layerValuesX; | export const getLayerValuesX = (state:State) => state.layerValuesX; | ||||||
| export const getLayerValuesY = (state:State) => state.layerValuesY; | export const getLayerValuesY = (state:State) => state.layerValuesY; | ||||||
|  | export const getViewEnabled = (state:State) => state.viewEnabled; | ||||||
|  |  | ||||||
|  |  | ||||||
| export const selectMapState = createFeatureSelector<State>(MODULE_NAME); | export const selectMapState = createFeatureSelector<State>(MODULE_NAME); | ||||||
| @@ -632,5 +639,6 @@ export const selectGetLayerValuesEnabled = createSelector(selectMapState,getLaye | |||||||
| export const selectGetLayerValues = createSelector(selectMapState,getLayerValues); | export const selectGetLayerValues = createSelector(selectMapState,getLayerValues); | ||||||
| export const selectGetLayerValuesX = createSelector(selectMapState,getLayerValuesX); | export const selectGetLayerValuesX = createSelector(selectMapState,getLayerValuesX); | ||||||
| export const selectGetLayerValuesY = createSelector(selectMapState,getLayerValuesY); | export const selectGetLayerValuesY = createSelector(selectMapState,getLayerValuesY); | ||||||
|  | export const selectGetViewEnabled = createSelector(selectMapState,getViewEnabled); | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,12 +1,14 @@ | |||||||
| import { NgModule } from '@angular/core'; | import { NgModule } from '@angular/core'; | ||||||
| import { Switch2D3DComponent } from './components/olcs/switch2d3d/switch2d3d.component'; | import { Switch2D3DComponent } from './components/olcs/switch2d3d/switch2d3d.component'; | ||||||
| import { AppCommonModule} from '@farmmaps/common'; | import { AppCommonModule} from '@farmmaps/common'; | ||||||
|  | import { AppCommonMapModule} from '@farmmaps/common-map'; | ||||||
|  |  | ||||||
|  |  | ||||||
| @NgModule({ | @NgModule({ | ||||||
|   declarations: [Switch2D3DComponent], |   declarations: [Switch2D3DComponent], | ||||||
|   imports: [ |   imports: [ | ||||||
|     AppCommonModule |     AppCommonModule, | ||||||
|  |     AppCommonMapModule | ||||||
|   ], |   ], | ||||||
|   exports: [Switch2D3DComponent] |   exports: [Switch2D3DComponent] | ||||||
| }) | }) | ||||||
|   | |||||||
| @@ -4,6 +4,8 @@ import { MapComponent } from 'ngx-openlayers'; | |||||||
| import OLCesium from 'olcs/OLCesium'; | import OLCesium from 'olcs/OLCesium'; | ||||||
| import RasterSynchronizer from 'olcs/RasterSynchronizer'; | import RasterSynchronizer from 'olcs/RasterSynchronizer'; | ||||||
| import VectorSynchronizer from 'olcs/VectorSynchronizer'; | import VectorSynchronizer from 'olcs/VectorSynchronizer'; | ||||||
|  | import { mapReducers,mapActions } from '@farmmaps/common-map'; | ||||||
|  | import { Store } from '@ngrx/store'; | ||||||
|  |  | ||||||
| @Component({ | @Component({ | ||||||
|   selector: 'fm-map3d-switch2d3d', |   selector: 'fm-map3d-switch2d3d', | ||||||
| @@ -20,7 +22,7 @@ export class Switch2D3DComponent { | |||||||
|   private interactions:Interaction[] = []; |   private interactions:Interaction[] = []; | ||||||
|  |  | ||||||
|  |  | ||||||
|   constructor(private map: MapComponent) { |   constructor(private map: MapComponent,private store: Store<mapReducers.State>) { | ||||||
|      |      | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -62,12 +64,14 @@ export class Switch2D3DComponent { | |||||||
|   handleClick(event) { |   handleClick(event) { | ||||||
|     this.enable = !this.enable;  |     this.enable = !this.enable;  | ||||||
|     if(this.enable) { |     if(this.enable) { | ||||||
|  |       this.store.dispatch(new mapActions.SetViewState(false)); | ||||||
|       this.disableInteractions(); |       this.disableInteractions(); | ||||||
|       this.synchronize(); |       this.synchronize(); | ||||||
|       this.ol3d.setEnabled(true); |       this.ol3d.setEnabled(true); | ||||||
|     } else { |     } else { | ||||||
|       this.ol3d.setEnabled(false); |       this.ol3d.setEnabled(false); | ||||||
|       this.enableInteractions(); |       this.enableInteractions(); | ||||||
|  |       this.store.dispatch(new mapActions.SetViewState(true)); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     this.label = this.enable?"2D":"3D";     |     this.label = this.enable?"2D":"3D";     | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user