2008-09-26 17:29:19 +00:00
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using OpenMetaverse;
|
|
|
|
|
|
|
|
|
|
namespace OpenMetaverse.TestClient
|
|
|
|
|
{
|
|
|
|
|
public class TexturesCommand : Command
|
|
|
|
|
{
|
|
|
|
|
Dictionary<UUID, UUID> alreadyRequested = new Dictionary<UUID, UUID>();
|
|
|
|
|
bool enabled = false;
|
|
|
|
|
|
|
|
|
|
public TexturesCommand(TestClient testClient)
|
|
|
|
|
{
|
2008-10-09 18:04:06 +00:00
|
|
|
enabled = testClient.ClientManager.GetTextures;
|
|
|
|
|
|
2008-09-26 17:29:19 +00:00
|
|
|
Name = "textures";
|
|
|
|
|
Description = "Turns automatic texture downloading on or off. Usage: textures [on/off]";
|
|
|
|
|
Category = CommandCategory.Objects;
|
|
|
|
|
|
|
|
|
|
testClient.Objects.OnNewPrim += new ObjectManager.NewPrimCallback(Objects_OnNewPrim);
|
|
|
|
|
testClient.Objects.OnNewAvatar += new ObjectManager.NewAvatarCallback(Objects_OnNewAvatar);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override string Execute(string[] args, UUID fromAgentID)
|
|
|
|
|
{
|
|
|
|
|
if (args.Length != 1)
|
|
|
|
|
return "Usage: textures [on/off]";
|
|
|
|
|
|
|
|
|
|
if (args[0].ToLower() == "on")
|
|
|
|
|
{
|
2008-10-09 18:04:06 +00:00
|
|
|
Client.ClientManager.GetTextures = enabled = true;
|
2008-09-26 17:29:19 +00:00
|
|
|
return "Texture downloading is on";
|
|
|
|
|
}
|
|
|
|
|
else if (args[0].ToLower() == "off")
|
|
|
|
|
{
|
2008-10-09 18:04:06 +00:00
|
|
|
Client.ClientManager.GetTextures = enabled = false;
|
2008-09-26 17:29:19 +00:00
|
|
|
return "Texture downloading is off";
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return "Usage: textures [on/off]";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Objects_OnNewAvatar(Simulator simulator, Avatar avatar, ulong regionHandle, ushort timeDilation)
|
|
|
|
|
{
|
|
|
|
|
if (enabled)
|
|
|
|
|
{
|
|
|
|
|
// Search this avatar for textures
|
|
|
|
|
for (int i = 0; i < avatar.Textures.FaceTextures.Length; i++)
|
|
|
|
|
{
|
|
|
|
|
Primitive.TextureEntryFace face = avatar.Textures.FaceTextures[i];
|
|
|
|
|
|
|
|
|
|
if (face != null)
|
|
|
|
|
{
|
|
|
|
|
if (!alreadyRequested.ContainsKey(face.TextureID))
|
|
|
|
|
{
|
|
|
|
|
alreadyRequested[face.TextureID] = face.TextureID;
|
|
|
|
|
|
|
|
|
|
// Determine if this is a baked outfit texture or a normal texture
|
|
|
|
|
ImageType type = ImageType.Normal;
|
|
|
|
|
AppearanceManager.TextureIndex index = (AppearanceManager.TextureIndex)i;
|
|
|
|
|
switch (index)
|
|
|
|
|
{
|
|
|
|
|
case AppearanceManager.TextureIndex.EyesBaked:
|
|
|
|
|
case AppearanceManager.TextureIndex.HeadBaked:
|
|
|
|
|
case AppearanceManager.TextureIndex.LowerBaked:
|
|
|
|
|
case AppearanceManager.TextureIndex.SkirtBaked:
|
|
|
|
|
case AppearanceManager.TextureIndex.UpperBaked:
|
|
|
|
|
type = ImageType.Baked;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2009-05-07 16:10:52 +00:00
|
|
|
Client.Assets.RequestImage(face.TextureID, type, Assets_OnImageReceived);
|
2008-09-26 17:29:19 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Objects_OnNewPrim(Simulator simulator, Primitive prim, ulong regionHandle, ushort timeDilation)
|
|
|
|
|
{
|
|
|
|
|
if (enabled)
|
|
|
|
|
{
|
|
|
|
|
// Search this prim for textures
|
|
|
|
|
for (int i = 0; i < prim.Textures.FaceTextures.Length; i++)
|
|
|
|
|
{
|
|
|
|
|
Primitive.TextureEntryFace face = prim.Textures.FaceTextures[i];
|
|
|
|
|
|
|
|
|
|
if (face != null)
|
|
|
|
|
{
|
|
|
|
|
if (!alreadyRequested.ContainsKey(face.TextureID))
|
|
|
|
|
{
|
|
|
|
|
alreadyRequested[face.TextureID] = face.TextureID;
|
2009-05-07 16:10:52 +00:00
|
|
|
Client.Assets.RequestImage(face.TextureID, ImageType.Normal, Assets_OnImageReceived);
|
2008-09-26 17:29:19 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2009-05-07 16:10:52 +00:00
|
|
|
private void Assets_OnImageReceived(TextureRequestState state, AssetTexture asset)
|
2008-09-26 17:29:19 +00:00
|
|
|
{
|
2009-05-07 16:10:52 +00:00
|
|
|
if (state == TextureRequestState.Finished && enabled && alreadyRequested.ContainsKey(asset.AssetID))
|
2008-09-26 17:29:19 +00:00
|
|
|
{
|
2009-05-07 16:10:52 +00:00
|
|
|
if (state == TextureRequestState.Finished)
|
|
|
|
|
Logger.DebugLog(String.Format("Finished downloading texture {0} ({1} bytes)", asset.AssetID, asset.AssetData.Length));
|
2008-09-26 17:29:19 +00:00
|
|
|
else
|
2009-05-07 16:10:52 +00:00
|
|
|
Logger.Log("Failed to download texture " + asset.AssetID + ": " + state, Helpers.LogLevel.Warning);
|
2008-09-26 17:29:19 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|