aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Framework/TerrainData.cs125
1 files changed, 31 insertions, 94 deletions
diff --git a/OpenSim/Framework/TerrainData.cs b/OpenSim/Framework/TerrainData.cs
index 976c1f0..c66c1ad 100644
--- a/OpenSim/Framework/TerrainData.cs
+++ b/OpenSim/Framework/TerrainData.cs
@@ -108,12 +108,6 @@ namespace OpenSim.Framework
108 // The dimensions are presumed to be multiples of 16 and, more likely, multiples of 256. 108 // The dimensions are presumed to be multiples of 16 and, more likely, multiples of 256.
109 Compressed2D = 27, 109 Compressed2D = 27,
110 110
111 // as Compressed2D but using ushort[] in place of int16[]
112 Compressed2Du = 28,
113
114 // as Compressed2D but using ushort[] in place of int16[] with Gzip compression
115 Compressed2DuGzip = 29,
116
117 // A revision that is not listed above or any revision greater than this value is 'Legacy256'. 111 // A revision that is not listed above or any revision greater than this value is 'Legacy256'.
118 RevisionHigh = 1234 112 RevisionHigh = 1234
119 } 113 }
@@ -373,21 +367,12 @@ namespace OpenSim.Framework
373 { 367 {
374 case DBTerrainRevision.Variable2DGzip: 368 case DBTerrainRevision.Variable2DGzip:
375 FromCompressedTerrainSerializationV2DGZip(pBlob); 369 FromCompressedTerrainSerializationV2DGZip(pBlob);
376 m_log.DebugFormat("{0} HeightmapTerrainData create from Gzip Compressed2D (unsigned shorts) serialization. Size=<{1},{2}>", LogHeader, SizeX, SizeY); 370 m_log.DebugFormat("{0} HeightmapTerrainData create from Variable2DGzip serialization. Size=<{1},{2}>", LogHeader, SizeX, SizeY);
377 break; 371 break;
378 372
379 case DBTerrainRevision.Variable2D: 373 case DBTerrainRevision.Variable2D:
380 FromCompressedTerrainSerializationV2D(pBlob); 374 FromCompressedTerrainSerializationV2D(pBlob);
381 m_log.DebugFormat("{0} HeightmapTerrainData create from Gzip Compressed2D (unsigned shorts) serialization. Size=<{1},{2}>", LogHeader, SizeX, SizeY); 375 m_log.DebugFormat("{0} HeightmapTerrainData create from Variable2D serialization. Size=<{1},{2}>", LogHeader, SizeX, SizeY);
382 break;
383
384 case DBTerrainRevision.Compressed2DuGzip:
385 FromCompressedTerrainSerialization2DuGZip(pBlob);
386 m_log.DebugFormat("{0} HeightmapTerrainData create from Gzip Compressed2D (unsigned shorts) serialization. Size=<{1},{2}>", LogHeader, SizeX, SizeY);
387 break;
388 case DBTerrainRevision.Compressed2Du:
389 FromCompressedTerrainSerialization2D(pBlob);
390 m_log.DebugFormat("{0} HeightmapTerrainData create from Compressed2D (unsigned shorts) serialization. Size=<{1},{2}>", LogHeader, SizeX, SizeY);
391 break; 376 break;
392 case DBTerrainRevision.Compressed2D: 377 case DBTerrainRevision.Compressed2D:
393 FromCompressedTerrainSerialization2D(pBlob); 378 FromCompressedTerrainSerialization2D(pBlob);
@@ -425,7 +410,7 @@ namespace OpenSim.Framework
425 return ret; 410 return ret;
426 } 411 }
427 412
428 // Just create an array of doubles. Presumes the caller implicitly knows the size. 413 // Presumes the caller implicitly knows the size.
429 public void FromLegacyTerrainSerialization(byte[] pBlob) 414 public void FromLegacyTerrainSerialization(byte[] pBlob)
430 { 415 {
431 // In case database info doesn't match real terrain size, initialize the whole terrain. 416 // In case database info doesn't match real terrain size, initialize the whole terrain.
@@ -464,8 +449,6 @@ namespace OpenSim.Framework
464 // int32 sizeY 449 // int32 sizeY
465 // float[,] array 450 // float[,] array
466 451
467 // may have endian issues like older
468
469 public Array ToCompressedTerrainSerializationV2D() 452 public Array ToCompressedTerrainSerializationV2D()
470 { 453 {
471 Array ret = null; 454 Array ret = null;
@@ -493,6 +476,10 @@ namespace OpenSim.Framework
493 { 476 {
494 477
495 } 478 }
479
480 m_log.DebugFormat("{0} V2D {1} bytes",
481 LogHeader, ret.Length);
482
496 return ret; 483 return ret;
497 } 484 }
498 485
@@ -534,7 +521,7 @@ namespace OpenSim.Framework
534 { 521 {
535 522
536 } 523 }
537 m_log.InfoFormat("{0} terrain GZiped to {1} bytes (V2DGzip)", 524 m_log.DebugFormat("{0} V2DGzip {1} bytes",
538 LogHeader, ret.Length); 525 LogHeader, ret.Length);
539 return ret; 526 return ret;
540 } 527 }
@@ -575,20 +562,19 @@ namespace OpenSim.Framework
575 } 562 }
576 ClearTaint(); 563 ClearTaint();
577 564
578 m_log.InfoFormat("{0} Read (compressed2D) heightmap. Heightmap size=<{1},{2}>. Region size=<{3},{4}>. CompFact={5}", 565 m_log.DebugFormat("{0} Read (compressed2D) heightmap. Heightmap size=<{1},{2}>. Region size=<{3},{4}>. CompFact={5}",
579 LogHeader, hmSizeX, hmSizeY, SizeX, SizeY, hmCompressionFactor); 566 LogHeader, hmSizeX, hmSizeY, SizeX, SizeY, hmCompressionFactor);
580 } 567 }
581 } 568 }
582 569
583 // Initialize heightmap from blob consisting of: 570 // Initialize heightmap from blob consisting of:
584 // int32, int32, int32, int32, ushort[] 571 // int32, int32, int32, float[]
585 // where the first int32 is format code, next two int32s are the X and y of heightmap data and 572 // where the first int32 is format code, next two int32s are the X and y of heightmap data
586 // the forth int is the compression factor for the following int16s
587 // This is just sets heightmap info. The actual size of the region was set on this instance's 573 // This is just sets heightmap info. The actual size of the region was set on this instance's
588 // creation and any heights not initialized by theis blob are set to the default height. 574 // creation and any heights not initialized by theis blob are set to the default height.
589 public void FromCompressedTerrainSerialization2Du(byte[] pBlob) 575 public void FromCompressedTerrainSerializationV2D(byte[] pBlob)
590 { 576 {
591 Int32 hmFormatCode, hmSizeX, hmSizeY, hmCompressionFactor; 577 Int32 hmFormatCode, hmSizeX, hmSizeY;
592 try 578 try
593 { 579 {
594 using (MemoryStream mstr = new MemoryStream(pBlob)) 580 using (MemoryStream mstr = new MemoryStream(pBlob))
@@ -598,9 +584,6 @@ namespace OpenSim.Framework
598 hmFormatCode = br.ReadInt32(); 584 hmFormatCode = br.ReadInt32();
599 hmSizeX = br.ReadInt32(); 585 hmSizeX = br.ReadInt32();
600 hmSizeY = br.ReadInt32(); 586 hmSizeY = br.ReadInt32();
601 hmCompressionFactor = br.ReadInt32();
602
603 m_compressionFactor = hmCompressionFactor;
604 587
605 // In case database info doesn't match real terrain size, initialize the whole terrain. 588 // In case database info doesn't match real terrain size, initialize the whole terrain.
606 ClearLand(); 589 ClearLand();
@@ -609,7 +592,7 @@ namespace OpenSim.Framework
609 { 592 {
610 for (int xx = 0; xx < hmSizeX; xx++) 593 for (int xx = 0; xx < hmSizeX; xx++)
611 { 594 {
612 float val = FromCompressedHeight(br.ReadUInt16()); 595 float val = br.ReadSingle();
613 if (xx < SizeX && yy < SizeY) 596 if (xx < SizeX && yy < SizeY)
614 m_heightmap[xx, yy] = val; 597 m_heightmap[xx, yy] = val;
615 } 598 }
@@ -620,59 +603,41 @@ namespace OpenSim.Framework
620 catch (Exception e) 603 catch (Exception e)
621 { 604 {
622 ClearTaint(); 605 ClearTaint();
623 m_log.ErrorFormat("{0} Read (compressed2Dus) terrain error: {1} - terrain may be damaged", 606 m_log.ErrorFormat("{0} 2D error: {1} - terrain may be damaged",
624 LogHeader, e.Message); 607 LogHeader, e.Message);
625 return; 608 return;
626 } 609 }
627 ClearTaint(); 610 ClearTaint();
628 611
629 m_log.InfoFormat("{0} Read compressed2D terrain. Heightmap size=<{1},{2}>. Region size=<{3},{4}>. CompFact={5}", 612 m_log.DebugFormat("{0} V2D Heightmap size=<{1},{2}>. Region size=<{3},{4}>",
630 LogHeader, hmSizeX, hmSizeY, SizeX, SizeY, hmCompressionFactor); 613 LogHeader, hmSizeX, hmSizeY, SizeX, SizeY);
631 614
632 } 615 }
633 616
634 // as above but Gzip compressed 617 // as above but Gzip compressed
635 public void FromCompressedTerrainSerialization2DuGZip(byte[] pBlob) 618 public void FromCompressedTerrainSerializationV2DGZip(byte[] pBlob)
636 { 619 {
637 m_log.InfoFormat("{0} GZip {1} bytes for terrain", 620 m_log.InfoFormat("{0} VD2Gzip {1} bytes input",
638 LogHeader, pBlob.Length); 621 LogHeader, pBlob.Length);
639 byte[] gzipout = null; 622
623 Int32 hmFormatCode, hmSizeX, hmSizeY;
624
640 try 625 try
641 { 626 {
642 using (MemoryStream inputStream = new MemoryStream(pBlob)) 627 using (MemoryStream outputStream = new MemoryStream())
643 { 628 {
644 using (GZipStream decompressionStream = new GZipStream(inputStream, CompressionMode.Decompress)) 629 using (MemoryStream inputStream = new MemoryStream(pBlob))
645 { 630 {
646 using (MemoryStream outputStream = new MemoryStream()) 631 using (GZipStream decompressionStream = new GZipStream(inputStream, CompressionMode.Decompress))
647 { 632 {
648 decompressionStream.Flush(); 633 decompressionStream.Flush();
649 decompressionStream.CopyTo(outputStream); 634 decompressionStream.CopyTo(outputStream);
650 gzipout = outputStream.ToArray();
651 } 635 }
652 } 636 }
653 }
654 }
655 catch
656 {
657 }
658 637
659 FromCompressedTerrainSerialization2Du(gzipout); 638 outputStream.Seek(0, SeekOrigin.Begin);
660 }
661 639
662 // Initialize heightmap from blob consisting of: 640 using (BinaryReader br = new BinaryReader(outputStream))
663 // int32, int32, int32, int32, ushort[]
664 // where the first int32 is format code, next two int32s are the X and y of heightmap data and
665 // the forth int is the compression factor for the following int16s
666 // This is just sets heightmap info. The actual size of the region was set on this instance's
667 // creation and any heights not initialized by theis blob are set to the default height.
668 public void FromCompressedTerrainSerializationV2D(byte[] pBlob)
669 {
670 Int32 hmFormatCode, hmSizeX, hmSizeY, hmCompressionFactor;
671 try
672 {
673 using (MemoryStream mstr = new MemoryStream(pBlob))
674 {
675 using (BinaryReader br = new BinaryReader(mstr))
676 { 641 {
677 hmFormatCode = br.ReadInt32(); 642 hmFormatCode = br.ReadInt32();
678 hmSizeX = br.ReadInt32(); 643 hmSizeX = br.ReadInt32();
@@ -693,46 +658,18 @@ namespace OpenSim.Framework
693 } 658 }
694 } 659 }
695 } 660 }
696 catch (Exception e) 661 catch( Exception e)
697 { 662 {
698 ClearTaint(); 663 ClearTaint();
699 m_log.ErrorFormat("{0} Read (Variable size format) terrain error: {1} - terrain may be damaged", 664 m_log.ErrorFormat("{0} V2DGzip error: {1} - terrain may be damaged",
700 LogHeader, e.Message); 665 LogHeader, e.Message);
701 return; 666 return;
702 } 667 }
703 ClearTaint();
704 668
705 m_log.InfoFormat("{0} Read Variable size format terrain. Heightmap size=<{1},{2}>. Region size=<{3},{4}>", 669 ClearTaint();
670 m_log.DebugFormat("{0} V2DGzip. Heightmap size=<{1},{2}>. Region size=<{3},{4}>",
706 LogHeader, hmSizeX, hmSizeY, SizeX, SizeY); 671 LogHeader, hmSizeX, hmSizeY, SizeX, SizeY);
707 672
708 } 673 }
709 // as above but Gzip compressed
710 public void FromCompressedTerrainSerializationV2DGZip(byte[] pBlob)
711 {
712 m_log.InfoFormat("{0} GZip {1} bytes for terrain",
713 LogHeader, pBlob.Length);
714
715 byte[] gzipout = null;
716 try
717 {
718 using (MemoryStream inputStream = new MemoryStream(pBlob))
719 {
720 using (GZipStream decompressionStream = new GZipStream(inputStream, CompressionMode.Decompress))
721 {
722 using (MemoryStream outputStream = new MemoryStream())
723 {
724 decompressionStream.Flush();
725 decompressionStream.CopyTo(outputStream);
726 gzipout = outputStream.ToArray();
727 }
728 }
729 }
730 }
731 catch
732 {
733 }
734
735 FromCompressedTerrainSerializationV2D(gzipout);
736 }
737 } 674 }
738} 675}