diff options
Diffstat (limited to 'OpenSim/Region/PhysicsModules/ubOdeMeshing')
-rw-r--r-- | OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs | 180 |
1 files changed, 90 insertions, 90 deletions
diff --git a/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs b/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs index 010262f..1233d48 100644 --- a/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs +++ b/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs | |||
@@ -36,7 +36,7 @@ using OpenSim.Region.PhysicsModules.ConvexDecompositionDotNet; | |||
36 | using OpenMetaverse; | 36 | using OpenMetaverse; |
37 | using OpenMetaverse.StructuredData; | 37 | using OpenMetaverse.StructuredData; |
38 | using System.Drawing; | 38 | using System.Drawing; |
39 | using System.Drawing.Imaging; | 39 | using System.Threading; |
40 | using System.IO.Compression; | 40 | using System.IO.Compression; |
41 | using PrimMesher; | 41 | using PrimMesher; |
42 | using log4net; | 42 | using log4net; |
@@ -56,15 +56,15 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
56 | // Setting baseDir to a path will enable the dumping of raw files | 56 | // Setting baseDir to a path will enable the dumping of raw files |
57 | // raw files can be imported by blender so a visual inspection of the results can be done | 57 | // raw files can be imported by blender so a visual inspection of the results can be done |
58 | 58 | ||
59 | private static string cacheControlFilename = "cntr"; | ||
59 | private bool m_Enabled = false; | 60 | private bool m_Enabled = false; |
60 | 61 | ||
61 | public static object diskLock = new object(); | 62 | public static object diskLock = new object(); |
62 | 63 | ||
63 | public bool doMeshFileCache = true; | 64 | public bool doMeshFileCache = true; |
64 | 65 | public bool doCacheExpire = true; | |
65 | public string cachePath = "MeshCache"; | 66 | public string cachePath = "MeshCache"; |
66 | public TimeSpan CacheExpire; | 67 | public TimeSpan CacheExpire; |
67 | public bool doCacheExpire = true; | ||
68 | 68 | ||
69 | // const string baseDir = "rawFiles"; | 69 | // const string baseDir = "rawFiles"; |
70 | private const string baseDir = null; //"rawFiles"; | 70 | private const string baseDir = null; //"rawFiles"; |
@@ -101,10 +101,8 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
101 | if (mesh_config != null) | 101 | if (mesh_config != null) |
102 | { | 102 | { |
103 | useMeshiesPhysicsMesh = mesh_config.GetBoolean("UseMeshiesPhysicsMesh", useMeshiesPhysicsMesh); | 103 | useMeshiesPhysicsMesh = mesh_config.GetBoolean("UseMeshiesPhysicsMesh", useMeshiesPhysicsMesh); |
104 | |||
105 | doConvexPrims = mesh_config.GetBoolean("ConvexPrims",doConvexPrims); | 104 | doConvexPrims = mesh_config.GetBoolean("ConvexPrims",doConvexPrims); |
106 | doConvexSculpts = mesh_config.GetBoolean("ConvexSculpts",doConvexPrims); | 105 | doConvexSculpts = mesh_config.GetBoolean("ConvexSculpts",doConvexPrims); |
107 | |||
108 | doMeshFileCache = mesh_config.GetBoolean("MeshFileCache", doMeshFileCache); | 106 | doMeshFileCache = mesh_config.GetBoolean("MeshFileCache", doMeshFileCache); |
109 | cachePath = mesh_config.GetString("MeshFileCachePath", cachePath); | 107 | cachePath = mesh_config.GetString("MeshFileCachePath", cachePath); |
110 | fcache = mesh_config.GetFloat("MeshFileCacheExpireHours", fcache); | 108 | fcache = mesh_config.GetFloat("MeshFileCacheExpireHours", fcache); |
@@ -115,22 +113,19 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
115 | 113 | ||
116 | CacheExpire = TimeSpan.FromHours(fcache); | 114 | CacheExpire = TimeSpan.FromHours(fcache); |
117 | 115 | ||
118 | lock (diskLock) | 116 | if(String.IsNullOrEmpty(cachePath)) |
117 | doMeshFileCache = false; | ||
118 | |||
119 | if(doMeshFileCache) | ||
119 | { | 120 | { |
120 | if(doMeshFileCache && cachePath != "") | 121 | if(!checkCache()) |
121 | { | 122 | { |
122 | try | 123 | doMeshFileCache = false; |
123 | { | 124 | doCacheExpire = false; |
124 | if (!Directory.Exists(cachePath)) | ||
125 | Directory.CreateDirectory(cachePath); | ||
126 | } | ||
127 | catch | ||
128 | { | ||
129 | doMeshFileCache = false; | ||
130 | doCacheExpire = false; | ||
131 | } | ||
132 | } | 125 | } |
133 | } | 126 | } |
127 | else | ||
128 | doCacheExpire = false; | ||
134 | } | 129 | } |
135 | } | 130 | } |
136 | 131 | ||
@@ -283,7 +278,7 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
283 | { | 278 | { |
284 | List<Coord> convexcoords; | 279 | List<Coord> convexcoords; |
285 | List<Face> convexfaces; | 280 | List<Face> convexfaces; |
286 | if(CreateHull(coords, out convexcoords, out convexfaces) && convexcoords != null && convexfaces != null) | 281 | if(CreateBoundingHull(coords, out convexcoords, out convexfaces) && convexcoords != null && convexfaces != null) |
287 | { | 282 | { |
288 | coords.Clear(); | 283 | coords.Clear(); |
289 | coords = convexcoords; | 284 | coords = convexcoords; |
@@ -565,45 +560,7 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
565 | vs.Clear(); | 560 | vs.Clear(); |
566 | continue; | 561 | continue; |
567 | } | 562 | } |
568 | /* | ||
569 | if (!HullUtils.ComputeHull(vs, ref hullr, 0, 0.0f)) | ||
570 | { | ||
571 | vs.Clear(); | ||
572 | continue; | ||
573 | } | ||
574 | |||
575 | nverts = hullr.Vertices.Count; | ||
576 | nindexs = hullr.Indices.Count; | ||
577 | |||
578 | if (nindexs % 3 != 0) | ||
579 | { | ||
580 | vs.Clear(); | ||
581 | continue; | ||
582 | } | ||
583 | 563 | ||
584 | for (i = 0; i < nverts; i++) | ||
585 | { | ||
586 | c.X = hullr.Vertices[i].x; | ||
587 | c.Y = hullr.Vertices[i].y; | ||
588 | c.Z = hullr.Vertices[i].z; | ||
589 | coords.Add(c); | ||
590 | } | ||
591 | |||
592 | for (i = 0; i < nindexs; i += 3) | ||
593 | { | ||
594 | t1 = hullr.Indices[i]; | ||
595 | if (t1 > nverts) | ||
596 | break; | ||
597 | t2 = hullr.Indices[i + 1]; | ||
598 | if (t2 > nverts) | ||
599 | break; | ||
600 | t3 = hullr.Indices[i + 2]; | ||
601 | if (t3 > nverts) | ||
602 | break; | ||
603 | f = new Face(vertsoffset + t1, vertsoffset + t2, vertsoffset + t3); | ||
604 | faces.Add(f); | ||
605 | } | ||
606 | */ | ||
607 | List<int> indices; | 564 | List<int> indices; |
608 | if (!HullUtils.ComputeHull(vs, out indices)) | 565 | if (!HullUtils.ComputeHull(vs, out indices)) |
609 | { | 566 | { |
@@ -709,38 +666,7 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
709 | vs.Clear(); | 666 | vs.Clear(); |
710 | return true; | 667 | return true; |
711 | } | 668 | } |
712 | /* | ||
713 | if (!HullUtils.ComputeHull(vs, ref hullr, 0, 0.0f)) | ||
714 | return false; | ||
715 | |||
716 | nverts = hullr.Vertices.Count; | ||
717 | nindexs = hullr.Indices.Count; | ||
718 | 669 | ||
719 | if (nindexs % 3 != 0) | ||
720 | return false; | ||
721 | |||
722 | for (i = 0; i < nverts; i++) | ||
723 | { | ||
724 | c.X = hullr.Vertices[i].x; | ||
725 | c.Y = hullr.Vertices[i].y; | ||
726 | c.Z = hullr.Vertices[i].z; | ||
727 | coords.Add(c); | ||
728 | } | ||
729 | for (i = 0; i < nindexs; i += 3) | ||
730 | { | ||
731 | t1 = hullr.Indices[i]; | ||
732 | if (t1 > nverts) | ||
733 | break; | ||
734 | t2 = hullr.Indices[i + 1]; | ||
735 | if (t2 > nverts) | ||
736 | break; | ||
737 | t3 = hullr.Indices[i + 2]; | ||
738 | if (t3 > nverts) | ||
739 | break; | ||
740 | f = new Face(t1, t2, t3); | ||
741 | faces.Add(f); | ||
742 | } | ||
743 | */ | ||
744 | List<int> indices; | 670 | List<int> indices; |
745 | if (!HullUtils.ComputeHull(vs, out indices)) | 671 | if (!HullUtils.ComputeHull(vs, out indices)) |
746 | return false; | 672 | return false; |
@@ -1353,7 +1279,7 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
1353 | } | 1279 | } |
1354 | } | 1280 | } |
1355 | 1281 | ||
1356 | public void FileNames(AMeshKey key, out string dir,out string fullFileName) | 1282 | public void FileNames(AMeshKey key, out string dir, out string fullFileName) |
1357 | { | 1283 | { |
1358 | string id = key.ToString(); | 1284 | string id = key.ToString(); |
1359 | string init = id.Substring(0, 1); | 1285 | string init = id.Substring(0, 1); |
@@ -1470,7 +1396,7 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
1470 | if (!doCacheExpire) | 1396 | if (!doCacheExpire) |
1471 | return; | 1397 | return; |
1472 | 1398 | ||
1473 | string controlfile = System.IO.Path.Combine(cachePath, "cntr"); | 1399 | string controlfile = System.IO.Path.Combine(cachePath, cacheControlFilename); |
1474 | 1400 | ||
1475 | lock (diskLock) | 1401 | lock (diskLock) |
1476 | { | 1402 | { |
@@ -1524,7 +1450,81 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing | |||
1524 | } | 1450 | } |
1525 | } | 1451 | } |
1526 | 1452 | ||
1527 | public bool CreateHull(List<Coord> inputVertices, out List<Coord> convexcoords, out List<Face> newfaces) | 1453 | public bool checkCache() |
1454 | { | ||
1455 | string controlfile = System.IO.Path.Combine(cachePath, cacheControlFilename); | ||
1456 | lock (diskLock) | ||
1457 | { | ||
1458 | try | ||
1459 | { | ||
1460 | if (!Directory.Exists(cachePath)) | ||
1461 | { | ||
1462 | Directory.CreateDirectory(cachePath); | ||
1463 | Thread.Sleep(100); | ||
1464 | FileStream fs = File.Create(controlfile, 4096, FileOptions.WriteThrough); | ||
1465 | fs.Close(); | ||
1466 | return true; | ||
1467 | } | ||
1468 | } | ||
1469 | catch | ||
1470 | { | ||
1471 | doMeshFileCache = false; | ||
1472 | doCacheExpire = false; | ||
1473 | return false; | ||
1474 | } | ||
1475 | finally {} | ||
1476 | |||
1477 | if (File.Exists(controlfile)) | ||
1478 | return true; | ||
1479 | |||
1480 | try | ||
1481 | { | ||
1482 | Directory.Delete(cachePath, true); | ||
1483 | while(Directory.Exists(cachePath)) | ||
1484 | Thread.Sleep(100); | ||
1485 | } | ||
1486 | catch(Exception e) | ||
1487 | { | ||
1488 | m_log.Error("[MESH CACHE]: failed to delete old version of the cache: " + e.Message); | ||
1489 | doMeshFileCache = false; | ||
1490 | doCacheExpire = false; | ||
1491 | return false; | ||
1492 | } | ||
1493 | finally {} | ||
1494 | try | ||
1495 | { | ||
1496 | Directory.CreateDirectory(cachePath); | ||
1497 | while(!Directory.Exists(cachePath)) | ||
1498 | Thread.Sleep(100); | ||
1499 | } | ||
1500 | catch(Exception e) | ||
1501 | { | ||
1502 | m_log.Error("[MESH CACHE]: failed to create new cache folder: " + e.Message); | ||
1503 | doMeshFileCache = false; | ||
1504 | doCacheExpire = false; | ||
1505 | return false; | ||
1506 | } | ||
1507 | finally {} | ||
1508 | |||
1509 | try | ||
1510 | { | ||
1511 | FileStream fs = File.Create(controlfile, 4096, FileOptions.WriteThrough); | ||
1512 | fs.Close(); | ||
1513 | } | ||
1514 | catch(Exception e) | ||
1515 | { | ||
1516 | m_log.Error("[MESH CACHE]: failed to create new control file: " + e.Message); | ||
1517 | doMeshFileCache = false; | ||
1518 | doCacheExpire = false; | ||
1519 | return false; | ||
1520 | } | ||
1521 | finally {} | ||
1522 | |||
1523 | return true; | ||
1524 | } | ||
1525 | } | ||
1526 | |||
1527 | public bool CreateBoundingHull(List<Coord> inputVertices, out List<Coord> convexcoords, out List<Face> newfaces) | ||
1528 | { | 1528 | { |
1529 | convexcoords = null; | 1529 | convexcoords = null; |
1530 | newfaces = null; | 1530 | newfaces = null; |