aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules/Scripting
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules/Scripting')
-rw-r--r--OpenSim/Region/CoreModules/Scripting/DynamicTexture/DynamicTextureModule.cs63
-rw-r--r--OpenSim/Region/CoreModules/Scripting/WorldComm/WorldCommModule.cs4
2 files changed, 37 insertions, 30 deletions
diff --git a/OpenSim/Region/CoreModules/Scripting/DynamicTexture/DynamicTextureModule.cs b/OpenSim/Region/CoreModules/Scripting/DynamicTexture/DynamicTextureModule.cs
index a686a4d..665d7f7 100644
--- a/OpenSim/Region/CoreModules/Scripting/DynamicTexture/DynamicTextureModule.cs
+++ b/OpenSim/Region/CoreModules/Scripting/DynamicTexture/DynamicTextureModule.cs
@@ -553,37 +553,44 @@ namespace OpenSim.Region.CoreModules.Scripting.DynamicTexture
553 ManagedImage managedImage; 553 ManagedImage managedImage;
554 Image image; 554 Image image;
555 555
556 if (OpenJPEG.DecodeToImage(frontImage, out managedImage, out image)) 556 if (!OpenJPEG.DecodeToImage(frontImage, out managedImage, out image) || image == null)
557 return null;
558
559 Bitmap image1 = new Bitmap(image);
560 image.Dispose();
561
562 if (!OpenJPEG.DecodeToImage(backImage, out managedImage, out image) || image == null)
557 { 563 {
558 Bitmap image1 = new Bitmap(image); 564 image1.Dispose();
565 return null;
566 }
559 567
560 if (OpenJPEG.DecodeToImage(backImage, out managedImage, out image)) 568 Bitmap image2 = new Bitmap(image);
561 { 569 image.Dispose();
562 Bitmap image2 = new Bitmap(image);
563 570
564 if (setNewAlpha) 571 if (setNewAlpha)
565 SetAlpha(ref image1, newAlpha); 572 SetAlpha(ref image1, newAlpha);
566 573
567 Bitmap joint = MergeBitMaps(image1, image2); 574 using(Bitmap joint = MergeBitMaps(image1, image2))
575 {
576 image1.Dispose();
577 image2.Dispose();
568 578
569 byte[] result = new byte[0]; 579 byte[] result = new byte[0];
570 580
571 try 581 try
572 { 582 {
573 result = OpenJPEG.EncodeFromImage(joint, true); 583 result = OpenJPEG.EncodeFromImage(joint, true);
574 } 584 }
575 catch (Exception e) 585 catch (Exception e)
576 { 586 {
577 m_log.ErrorFormat( 587 m_log.ErrorFormat(
578 "[DYNAMICTEXTUREMODULE]: OpenJpeg Encode Failed. Exception {0}{1}", 588 "[DYNAMICTEXTUREMODULE]: OpenJpeg Encode Failed. Exception {0}{1}",
579 e.Message, e.StackTrace); 589 e.Message, e.StackTrace);
580 }
581
582 return result;
583 } 590 }
584 }
585 591
586 return null; 592 return result;
593 }
587 } 594 }
588 595
589 public Bitmap MergeBitMaps(Bitmap front, Bitmap back) 596 public Bitmap MergeBitMaps(Bitmap front, Bitmap back)
@@ -592,12 +599,12 @@ namespace OpenSim.Region.CoreModules.Scripting.DynamicTexture
592 Graphics jG; 599 Graphics jG;
593 600
594 joint = new Bitmap(back.Width, back.Height, PixelFormat.Format32bppArgb); 601 joint = new Bitmap(back.Width, back.Height, PixelFormat.Format32bppArgb);
595 jG = Graphics.FromImage(joint); 602 using(jG = Graphics.FromImage(joint))
596 603 {
597 jG.DrawImage(back, 0, 0, back.Width, back.Height); 604 jG.DrawImage(back, 0, 0, back.Width, back.Height);
598 jG.DrawImage(front, 0, 0, back.Width, back.Height); 605 jG.DrawImage(front, 0, 0, back.Width, back.Height);
599 606 return joint;
600 return joint; 607 }
601 } 608 }
602 609
603 private void SetAlpha(ref Bitmap b, byte alpha) 610 private void SetAlpha(ref Bitmap b, byte alpha)
diff --git a/OpenSim/Region/CoreModules/Scripting/WorldComm/WorldCommModule.cs b/OpenSim/Region/CoreModules/Scripting/WorldComm/WorldCommModule.cs
index 68ca2ad..483c25f 100644
--- a/OpenSim/Region/CoreModules/Scripting/WorldComm/WorldCommModule.cs
+++ b/OpenSim/Region/CoreModules/Scripting/WorldComm/WorldCommModule.cs
@@ -559,9 +559,9 @@ namespace OpenSim.Region.CoreModules.Scripting.WorldComm
559 return coll[0].GetHandle(); 559 return coll[0].GetHandle();
560 } 560 }
561 561
562 if (m_curlisteners < m_maxlisteners) 562 lock (m_listeners)
563 { 563 {
564 lock (m_listeners) 564 if (m_curlisteners < m_maxlisteners)
565 { 565 {
566 int newHandle = GetNewHandle(itemID); 566 int newHandle = GetNewHandle(itemID);
567 567