Example #1
0
 /// <summary>
 /// Constructor.
 /// </summary>
 /// <param name="tile">TerrainTile to be cached.</param>
 public TerrainTileCacheEntry(TerrainTile tile)
 {
     m_terrainTile = tile;
 }
Example #2
0
        /// <summary>
        /// Gets the elevation array for given geographic bounding box and resolution.
        /// </summary>
        /// <param name="north">North edge in decimal degrees.</param>
        /// <param name="south">South edge in decimal degrees.</param>
        /// <param name="west">West edge in decimal degrees.</param>
        /// <param name="east">East edge in decimal degrees.</param>
        /// <param name="samples"></param>
        internal virtual TerrainTile GetElevationArray(double north, double south, double west, double east, int samples)
        {
            TerrainTile res = null;
             res = new TerrainTile(null);
             res.North = north;
             res.South = south;
             res.West = west;
             res.East = east;
             res.SamplesPerTile = samples;
             res.IsInitialized = true;
             res.IsValid = true;

             double latrange = Math.Abs(north - south);
             double lonrange = Math.Abs(east - west);

             float[,] data = new float[samples, samples];
             float scaleFactor = 1.0f / (samples - 1);
             for (int x = 0; x < samples; x++)
             {
            for (int y = 0; y < samples; y++)
            {
               double curLat = north - scaleFactor * latrange * x;
               double curLon = west + scaleFactor * lonrange * y;

               data[x, y] = GetElevationAt(curLat, curLon, 0);
            }
             }
             res.ElevationData = data;

             return res;
        }
Example #3
0
        /// <summary>
        /// Builds a terrain array with specified boundaries
        /// </summary>
        /// <param name="north">North edge in decimal degrees.</param>
        /// <param name="south">South edge in decimal degrees.</param>
        /// <param name="west">West edge in decimal degrees.</param>
        /// <param name="east">East edge in decimal degrees.</param>
        /// <param name="samples"></param>
        public override TerrainTile GetElevationArray(double north, double south, double west, double east,
                                                      int samples)
        {
            TerrainTile res = null;

            if (m_higherResolutionSubsets != null)
            {
                // TODO: Support more than 1 level of higher resolution sets and allow user selections
                foreach (TerrainAccessor higherResSub in m_higherResolutionSubsets)
                {
                    if (!higherResSub.IsOn)
                    {
                        continue;
                    }
                    if (north <= higherResSub.North && south >= higherResSub.South &&
                        west >= higherResSub.West && east <= higherResSub.East)
                    {
                        res = higherResSub.GetElevationArray(north, south, west, east, samples);
                        return(res);
                    }
                }
            }

            res                = new TerrainTile(m_terrainTileService);
            res.North          = north;
            res.South          = south;
            res.West           = west;
            res.East           = east;
            res.SamplesPerTile = samples;
            res.IsInitialized  = true;
            res.IsValid        = true;

            double samplesPerDegree    = (double)samples / (double)(north - south);
            double latrange            = Math.Abs(north - south);
            double lonrange            = Math.Abs(east - west);
            TerrainTileCacheEntry ttce = null;

            float[,] data = new float[samples, samples];

            if (samplesPerDegree < World.Settings.MinSamplesPerDegree)
            {
                res.ElevationData = data;
                return(res);
            }

            double scaleFactor = (double)1 / (samples - 1);

            for (int x = 0; x < samples; x++)
            {
                for (int y = 0; y < samples; y++)
                {
                    double curLat = north - scaleFactor * latrange * x;
                    double curLon = west + scaleFactor * lonrange * y;

                    // Wrap lat/lon to fit range 90/-90 and -180/180 (PM 2006-11-17)
                    if (curLat > 90)
                    {
                        curLat  = 90 - (curLat - 90);
                        curLon += 180;
                    }
                    if (curLat < -90)
                    {
                        curLat  = -90 - (curLat + 90);
                        curLon += 180;
                    }
                    if (curLon > 180)
                    {
                        curLon -= 360;
                    }
                    if (curLon < -180)
                    {
                        curLon += 360;
                    }

                    if (ttce == null ||
                        curLat < ttce.TerrainTile.South ||
                        curLat > ttce.TerrainTile.North ||
                        curLon < ttce.TerrainTile.West ||
                        curLon > ttce.TerrainTile.East)
                    {
                        TerrainTile tt = m_terrainTileService.GetTerrainTile(curLat, curLon, samplesPerDegree);
                        ttce = (TerrainTileCacheEntry)m_tileCache[tt.TerrainTileFilePath];
                        if (ttce == null)
                        {
                            ttce = new TerrainTileCacheEntry(tt);
                            AddToCache(ttce);
                        }
                        if (!ttce.TerrainTile.IsInitialized)
                        {
                            ttce.TerrainTile.Initialize();
                        }
                        ttce.LastAccess = DateTime.Now;
                        if (!tt.IsValid)
                        {
                            res.IsValid = false;
                        }
                    }

                    data[x, y] = ttce.TerrainTile.GetElevationAt(curLat, curLon);
                }
            }
            res.ElevationData = data;

            return(res);
        }
Example #4
0
        /// <summary>
        /// Builds terrain tile containing the specified coordinates.
        /// </summary>
        /// <param name="latitude">Latitude in decimal degrees.</param>
        /// <param name="longitude">Longitude in decimal degrees.</param>
        /// <param name="samplesPerDegree"></param>
        /// <returns>Uninitialized terrain tile (no elevation data)</returns>
        internal TerrainTile GetTerrainTile(double latitude, double longitude, double samplesPerDegree)
        {
            TerrainTile tile = new TerrainTile(this);

             tile.TargetLevel = m_numberLevels - 1;
             for (int i = 0; i < m_numberLevels; i++)
             {
            if (samplesPerDegree <= m_samplesPerTile / (m_levelZeroTileSizeDegrees * Math.Pow(0.5, i)))
            {
               tile.TargetLevel = i;
               break;
            }
             }

             tile.Row = GetRowFromLatitude(latitude, m_levelZeroTileSizeDegrees * Math.Pow(0.5, tile.TargetLevel));
             tile.Col = GetColFromLongitude(longitude, m_levelZeroTileSizeDegrees * Math.Pow(0.5, tile.TargetLevel));
             tile.TerrainTileFilePath = string.Format(CultureInfo.InvariantCulture,
            @"{0}\{4}\{1:D4}\{1:D4}_{2:D4}.{3}",
            m_terrainTileDirectory, tile.Row, tile.Col, m_fileExtension, tile.TargetLevel);
             tile.SamplesPerTile = m_samplesPerTile;
             tile.TileSizeDegrees = m_levelZeroTileSizeDegrees * Math.Pow(0.5, tile.TargetLevel);
             tile.North = -90.0 + tile.Row * tile.TileSizeDegrees + tile.TileSizeDegrees;
             tile.South = -90.0 + tile.Row * tile.TileSizeDegrees;
             tile.West = -180.0 + tile.Col * tile.TileSizeDegrees;
             tile.East = -180.0 + tile.Col * tile.TileSizeDegrees + tile.TileSizeDegrees;

             return tile;
        }
			/// <summary>
			/// Constructor.
			/// </summary>
			/// <param name="tile">TerrainTile to be cached.</param>
			public TerrainTileCacheEntry(TerrainTile tile)
			{
				m_terrainTile = tile;
			}
		/// <summary>
		/// Builds a terrain array with specified boundaries
		/// </summary>
		/// <param name="north">North edge in decimal degrees.</param>
		/// <param name="south">South edge in decimal degrees.</param>
		/// <param name="west">West edge in decimal degrees.</param>
		/// <param name="east">East edge in decimal degrees.</param>
		/// <param name="samples"></param>
		public override TerrainTile GetElevationArray(double north, double south, double west, double east,
			int samples)
		{
			TerrainTile res = null;
			
			if (m_higherResolutionSubsets != null)
			{
				// TODO: Support more than 1 level of higher resolution sets and allow user selections
				foreach (TerrainAccessor higherResSub in m_higherResolutionSubsets)
				{
					if (north <= higherResSub.North && south >= higherResSub.South &&
						west >= higherResSub.West && east <= higherResSub.East)
					{
						res = higherResSub.GetElevationArray(north, south, west, east, samples);
						return res;
					}
				}
			}

			res = new TerrainTile(m_terrainTileService);
			res.North = north;
			res.South = south;
			res.West = west;
			res.East = east;
			res.SamplesPerTile = samples;
			res.IsInitialized = true;
			res.IsValid = true;

			double samplesPerDegree = (double)samples / (double)(north - south);
			double latrange = Math.Abs(north - south);
			double lonrange = Math.Abs(east - west);
			TerrainTileCacheEntry ttce = null;

			float[,] data = new float[samples, samples];

			if(samplesPerDegree < World.Settings.MinSamplesPerDegree)
			{
				res.ElevationData = data;
				return res;
			}

			double scaleFactor = (double)1 / (samples - 1);
			for (int x = 0; x < samples; x++)
			{
				for (int y = 0; y < samples; y++)
				{
					double curLat = north - scaleFactor * latrange * x;
					double curLon = west + scaleFactor * lonrange * y;

                    // Wrap lat/lon to fit range 90/-90 and -180/180 (PM 2006-11-17)
                    if (curLat > 90)
                    {
                        curLat = 90 - (curLat - 90);
                        curLon += 180;
                    }
                    if (curLat < -90)
                    {
                        curLat = -90 - (curLat + 90);
                        curLon += 180;
                    }
                    if (curLon > 180)
                    {
                        curLon -= 360;
                    }
                    if (curLon < -180)
                    {
                        curLon += 360;
                    }

					if (ttce == null ||
						curLat < ttce.TerrainTile.South ||
						curLat > ttce.TerrainTile.North ||
						curLon < ttce.TerrainTile.West ||
						curLon > ttce.TerrainTile.East)
					{
						TerrainTile tt = m_terrainTileService.GetTerrainTile(curLat, curLon, samplesPerDegree);
						ttce = (TerrainTileCacheEntry)m_tileCache[tt.TerrainTileFilePath];
						if (ttce == null)
						{
							ttce = new TerrainTileCacheEntry(tt);
							AddToCache(ttce);
						}
						if (!ttce.TerrainTile.IsInitialized)
							ttce.TerrainTile.Initialize();
						ttce.LastAccess = DateTime.Now;
						if (!tt.IsValid)
							res.IsValid = false;
					}

					data[x, y] = ttce.TerrainTile.GetElevationAt(curLat, curLon);
				}
			}
			res.ElevationData = data;

			return res;
		}
 /// <summary>
 /// Initializes a new instance of the <see cref= "T:WorldWind.Terrain.TerrainDownloadRequest"/> class.
 /// </summary>
 /// <param name="tile"></param>
 /// <param name="owner"></param>
 /// <param name="row"></param>
 /// <param name="col"></param>
 /// <param name="targetLevel"></param>
 public TerrainDownloadRequest(TerrainTile tile, TerrainTileService owner, int row, int col, int targetLevel)
     : base(owner)
 {
     TerrainTile = tile;
     download.Url = String.Format(CultureInfo.InvariantCulture, "{0}?T={1}&L={2}&X={3}&Y={4}", owner.ServerUrl, owner.DataSet, targetLevel, col, row);
 }