When generating a Warp3D texture, set the detailTexture[i] variable on resize from the JPEG2000 original rather than only saving it to disk.
This appears to be the cause of the warp 3d exception seen when starting a new region for the first time. Subsequent starts were okay because resized saved bitmap was correctly retrieved from disk. Should fix http://opensimulator.org/mantis/view.php?id=5204 and http://opensimulator.org/mantis/view.php?id=52720.7.4.1
parent
2954ceccae
commit
ec6a195e40
|
@ -111,6 +111,9 @@ namespace OpenSim.Region.CoreModules.World.Warp3DMap
|
||||||
asset = assetService.GetCached(cacheID.ToString());
|
asset = assetService.GetCached(cacheID.ToString());
|
||||||
if (asset != null)
|
if (asset != null)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[TERRAIN SPLAT]: Got asset service cached terrain texture {0} {1}", i, asset.ID);
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
using (System.IO.MemoryStream stream = new System.IO.MemoryStream(asset.Data))
|
using (System.IO.MemoryStream stream = new System.IO.MemoryStream(asset.Data))
|
||||||
|
@ -129,6 +132,9 @@ namespace OpenSim.Region.CoreModules.World.Warp3DMap
|
||||||
asset = assetService.Get(textureIDs[i].ToString());
|
asset = assetService.Get(textureIDs[i].ToString());
|
||||||
if (asset != null)
|
if (asset != null)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[TERRAIN SPLAT]: Got cached original JPEG2000 terrain texture {0} {1}", i, asset.ID);
|
||||||
|
|
||||||
try { detailTexture[i] = (Bitmap)CSJ2K.J2kImage.FromBytes(asset.Data); }
|
try { detailTexture[i] = (Bitmap)CSJ2K.J2kImage.FromBytes(asset.Data); }
|
||||||
catch (Exception ex)
|
catch (Exception ex)
|
||||||
{
|
{
|
||||||
|
@ -138,14 +144,12 @@ namespace OpenSim.Region.CoreModules.World.Warp3DMap
|
||||||
|
|
||||||
if (detailTexture[i] != null)
|
if (detailTexture[i] != null)
|
||||||
{
|
{
|
||||||
Bitmap bitmap = detailTexture[i];
|
|
||||||
|
|
||||||
// Make sure this texture is the correct size, otherwise resize
|
// Make sure this texture is the correct size, otherwise resize
|
||||||
if (bitmap.Width != 256 || bitmap.Height != 256)
|
if (detailTexture[i].Width != 256 || detailTexture[i].Height != 256)
|
||||||
{
|
{
|
||||||
using (Bitmap origBitmap = bitmap)
|
using (Bitmap origBitmap = detailTexture[i])
|
||||||
{
|
{
|
||||||
bitmap = ImageUtils.ResizeImage(origBitmap, 256, 256);
|
detailTexture[i] = ImageUtils.ResizeImage(origBitmap, 256, 256);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,7 +157,7 @@ namespace OpenSim.Region.CoreModules.World.Warp3DMap
|
||||||
byte[] data;
|
byte[] data;
|
||||||
using (System.IO.MemoryStream stream = new System.IO.MemoryStream())
|
using (System.IO.MemoryStream stream = new System.IO.MemoryStream())
|
||||||
{
|
{
|
||||||
bitmap.Save(stream, ImageFormat.Png);
|
detailTexture[i].Save(stream, ImageFormat.Png);
|
||||||
data = stream.ToArray();
|
data = stream.ToArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,6 +189,9 @@ namespace OpenSim.Region.CoreModules.World.Warp3DMap
|
||||||
{
|
{
|
||||||
if (detailTexture[i] == null)
|
if (detailTexture[i] == null)
|
||||||
{
|
{
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[TERRAIN SPLAT]: Generating solid colour for missing texture {0}", i);
|
||||||
|
|
||||||
// Create a solid color texture for this layer
|
// Create a solid color texture for this layer
|
||||||
detailTexture[i] = new Bitmap(256, 256, PixelFormat.Format24bppRgb);
|
detailTexture[i] = new Bitmap(256, 256, PixelFormat.Format24bppRgb);
|
||||||
using (Graphics gfx = Graphics.FromImage(detailTexture[i]))
|
using (Graphics gfx = Graphics.FromImage(detailTexture[i]))
|
||||||
|
|
Loading…
Reference in New Issue