Moved script engine os* commands to OSSL_BuilIn_Commands.cs and OSSL_BuilIn_Commands_Interface.cs where they belong.
parent
a5bf229cbd
commit
8a13edb115
|
@ -52,11 +52,11 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
{
|
{
|
||||||
// private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
// private static readonly log4net.ILog m_log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
private ScriptEngineBase.ScriptEngine m_ScriptEngine;
|
internal ScriptEngineBase.ScriptEngine m_ScriptEngine;
|
||||||
private SceneObjectPart m_host;
|
internal SceneObjectPart m_host;
|
||||||
private uint m_localID;
|
internal uint m_localID;
|
||||||
private LLUUID m_itemID;
|
internal LLUUID m_itemID;
|
||||||
private bool throwErrorOnNotImplemented = true;
|
internal bool throwErrorOnNotImplemented = true;
|
||||||
|
|
||||||
public LSL_BuiltIn_Commands(ScriptEngineBase.ScriptEngine ScriptEngine, SceneObjectPart host, uint localID, LLUUID itemID)
|
public LSL_BuiltIn_Commands(ScriptEngineBase.ScriptEngine ScriptEngine, SceneObjectPart host, uint localID, LLUUID itemID)
|
||||||
{
|
{
|
||||||
|
@ -5303,317 +5303,36 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
return new LSL_Types.list();
|
return new LSL_Types.list();
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
// OpenSim functions
|
|
||||||
//
|
|
||||||
|
|
||||||
public int osTerrainSetHeight(int x, int y, double val)
|
internal LLUUID ScriptByName(string name)
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (x > 255 || x < 0 || y > 255 || y < 0)
|
|
||||||
LSLError("osTerrainSetHeight: Coordinate out of bounds");
|
|
||||||
|
|
||||||
if (World.PermissionsMngr.CanTerraform(m_host.OwnerID, new LLVector3(x, y, 0)))
|
|
||||||
{
|
|
||||||
World.Heightmap[x, y] = val;
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public double osTerrainGetHeight(int x, int y)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (x > 255 || x < 0 || y > 255 || y < 0)
|
|
||||||
LSLError("osTerrainGetHeight: Coordinate out of bounds");
|
|
||||||
|
|
||||||
return World.Heightmap[x, y];
|
|
||||||
}
|
|
||||||
|
|
||||||
public int osRegionRestart(double seconds)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (World.PermissionsMngr.CanRestartSim(m_host.OwnerID))
|
|
||||||
{
|
|
||||||
World.Restart((float)seconds);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void osRegionNotice(string msg)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
World.SendGeneralAlert(msg);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void osSetRot(LLUUID target, Quaternion rotation)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (World.Entities.ContainsKey(target))
|
|
||||||
{
|
|
||||||
World.Entities[target].Rotation = rotation;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
LSLError("osSetRot: Invalid target");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetDynamicTextureURL(string dynamicID, string contentType, string url, string extraParams,
|
|
||||||
int timer)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (dynamicID == String.Empty)
|
|
||||||
{
|
|
||||||
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
|
||||||
LLUUID createdTexture =
|
|
||||||
textureManager.AddDynamicTextureURL(World.RegionInfo.RegionID, m_host.UUID, contentType, url,
|
|
||||||
extraParams, timer);
|
|
||||||
return createdTexture.ToString();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//TODO update existing dynamic textures
|
|
||||||
}
|
|
||||||
|
|
||||||
return LLUUID.Zero.ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetDynamicTextureURLBlend(string dynamicID, string contentType, string url, string extraParams,
|
|
||||||
int timer, int alpha)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (dynamicID == String.Empty)
|
|
||||||
{
|
|
||||||
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
|
||||||
LLUUID createdTexture =
|
|
||||||
textureManager.AddDynamicTextureURL(World.RegionInfo.RegionID, m_host.UUID, contentType, url,
|
|
||||||
extraParams, timer, true, (byte) alpha );
|
|
||||||
return createdTexture.ToString();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//TODO update existing dynamic textures
|
|
||||||
}
|
|
||||||
|
|
||||||
return LLUUID.Zero.ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetDynamicTextureData(string dynamicID, string contentType, string data, string extraParams,
|
|
||||||
int timer)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (dynamicID == String.Empty)
|
|
||||||
{
|
|
||||||
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
|
||||||
if (textureManager != null)
|
|
||||||
{
|
|
||||||
LLUUID createdTexture =
|
|
||||||
textureManager.AddDynamicTextureData(World.RegionInfo.RegionID, m_host.UUID, contentType, data,
|
|
||||||
extraParams, timer);
|
|
||||||
return createdTexture.ToString();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//TODO update existing dynamic textures
|
|
||||||
}
|
|
||||||
|
|
||||||
return LLUUID.Zero.ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetDynamicTextureDataBlend(string dynamicID, string contentType, string data, string extraParams,
|
|
||||||
int timer, int alpha)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (dynamicID == String.Empty)
|
|
||||||
{
|
|
||||||
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
|
||||||
if (textureManager != null)
|
|
||||||
{
|
|
||||||
LLUUID createdTexture =
|
|
||||||
textureManager.AddDynamicTextureData(World.RegionInfo.RegionID, m_host.UUID, contentType, data,
|
|
||||||
extraParams, timer, true, (byte) alpha);
|
|
||||||
return createdTexture.ToString();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
//TODO update existing dynamic textures
|
|
||||||
}
|
|
||||||
|
|
||||||
return LLUUID.Zero.ToString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool osConsoleCommand(string command)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
Nini.Config.IConfigSource config = new Nini.Config.IniConfigSource(Application.iniFilePath);
|
|
||||||
if (config.Configs["LL-Functions"] == null)
|
|
||||||
config.AddConfig("LL-Functions");
|
|
||||||
|
|
||||||
if (config.Configs["LL-Functions"].GetBoolean("AllowosConsoleCommand", false))
|
|
||||||
{
|
|
||||||
if (World.PermissionsMngr.CanRunConsoleCommand(m_host.OwnerID))
|
|
||||||
{
|
|
||||||
OpenSim.Framework.Console.MainConsole.Instance.RunCommand(command);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private LLUUID ScriptByName(string name)
|
|
||||||
{
|
{
|
||||||
foreach (TaskInventoryItem item in m_host.TaskInventory.Values)
|
foreach (TaskInventoryItem item in m_host.TaskInventory.Values)
|
||||||
{
|
{
|
||||||
if(item.Type == 10 && item.Name == name)
|
if (item.Type == 10 && item.Name == name)
|
||||||
return item.ItemID;
|
return item.ItemID;
|
||||||
}
|
}
|
||||||
return LLUUID.Zero;
|
return LLUUID.Zero;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ShoutError(string msg)
|
internal void ShoutError(string msg)
|
||||||
{
|
{
|
||||||
llShout(BuiltIn_Commands_BaseClass.DEBUG_CHANNEL,msg);
|
llShout(BuiltIn_Commands_BaseClass.DEBUG_CHANNEL, msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void osSetPrimFloatOnWater(int floatYN)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (m_host.ParentGroup != null)
|
|
||||||
{
|
|
||||||
if (m_host.ParentGroup.RootPart != null)
|
|
||||||
{
|
|
||||||
m_host.ParentGroup.RootPart.SetFloatOnWater(floatYN);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Adam's super super custom animation functions
|
|
||||||
public void osAvatarPlayAnimation(string avatar, string animation)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (World.Entities.ContainsKey(avatar) && World.Entities[avatar] is ScenePresence)
|
|
||||||
{
|
|
||||||
ScenePresence target = (ScenePresence)World.Entities[avatar];
|
|
||||||
target.AddAnimation(avatar, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void osAvatarStopAnimation(string avatar, string animation)
|
internal void NotImplemented(string command)
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
if (World.Entities.ContainsKey(avatar) && World.Entities[avatar] is ScenePresence)
|
|
||||||
{
|
|
||||||
ScenePresence target = (ScenePresence)World.Entities[avatar];
|
|
||||||
target.RemoveAnimation(animation);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//Texture draw functions
|
|
||||||
public string osMovePen(string drawList, int x, int y)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "MoveTo " + x + "," + y + ";";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawLine(string drawList, int startX, int startY, int endX, int endY)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "MoveTo "+ startX+","+ startY +"; LineTo "+endX +","+endY +"; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawLine(string drawList, int endX, int endY)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "LineTo " + endX + "," + endY + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawText(string drawList, string text)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "Text " + text + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawEllipse(string drawList, int width, int height)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "Ellipse " + width + "," + height + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawRectangle(string drawList, int width, int height)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "Rectangle " + width + "," + height + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawFilledRectangle(string drawList, int width, int height)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "FillRectangle " + width + "," + height + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetFontSize(string drawList, int fontSize)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "FontSize "+ fontSize +"; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetPenSize(string drawList, int penSize)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "PenSize " + penSize + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osSetPenColour(string drawList, string colour)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList += "PenColour " + colour + "; ";
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string osDrawImage(string drawList, int width, int height, string imageUrl)
|
|
||||||
{
|
|
||||||
m_host.AddScriptLPS(1);
|
|
||||||
drawList +="Image " +width + "," + height+ ","+ imageUrl +"; " ;
|
|
||||||
return drawList;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void osSetStateEvents(int events)
|
|
||||||
{
|
|
||||||
m_host.setScriptEvents(m_itemID,events);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void NotImplemented(string command)
|
|
||||||
{
|
{
|
||||||
if (throwErrorOnNotImplemented)
|
if (throwErrorOnNotImplemented)
|
||||||
throw new NotImplementedException("Command not implemented: " + command);
|
throw new NotImplementedException("Command not implemented: " + command);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void Deprecated(string command)
|
internal void Deprecated(string command)
|
||||||
{
|
{
|
||||||
throw new Exception("Command deprecated: " + command);
|
throw new Exception("Command deprecated: " + command);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void LSLError(string msg)
|
internal void LSLError(string msg)
|
||||||
{
|
{
|
||||||
throw new Exception("LSL Runtime Error: " + msg);
|
throw new Exception("LSL Runtime Error: " + msg);
|
||||||
}
|
}
|
||||||
|
|
|
@ -638,37 +638,6 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
LSL_Types.list llGetParcelDetails(LSL_Types.Vector3 pos, LSL_Types.list param);
|
LSL_Types.list llGetParcelDetails(LSL_Types.Vector3 pos, LSL_Types.list param);
|
||||||
string llStringTrim(string src, int type);
|
string llStringTrim(string src, int type);
|
||||||
LSL_Types.list llGetObjectDetails(string id, LSL_Types.list args);
|
LSL_Types.list llGetObjectDetails(string id, LSL_Types.list args);
|
||||||
//OpenSim functions
|
|
||||||
string osSetDynamicTextureURL(string dynamicID, string contentType, string url, string extraParams, int timer);
|
|
||||||
string osSetDynamicTextureURLBlend(string dynamicID, string contentType, string url, string extraParams,
|
|
||||||
int timer, int alpha);
|
|
||||||
string osSetDynamicTextureData(string dynamicID, string contentType, string data, string extraParams, int timer);
|
|
||||||
string osSetDynamicTextureDataBlend(string dynamicID, string contentType, string data, string extraParams,
|
|
||||||
int timer, int alpha);
|
|
||||||
double osTerrainGetHeight(int x, int y);
|
|
||||||
int osTerrainSetHeight(int x, int y, double val);
|
|
||||||
int osRegionRestart(double seconds);
|
|
||||||
void osRegionNotice(string msg);
|
|
||||||
bool osConsoleCommand(string Command);
|
|
||||||
void osSetParcelMediaURL(string url);
|
|
||||||
void osSetPrimFloatOnWater(int floatYN);
|
|
||||||
|
|
||||||
// Animation commands
|
|
||||||
void osAvatarPlayAnimation(string avatar, string animation);
|
|
||||||
void osAvatarStopAnimation(string avatar, string animation);
|
|
||||||
|
|
||||||
//texture draw functions
|
|
||||||
string osMovePen(string drawList, int x, int y);
|
|
||||||
string osDrawLine(string drawList, int startX, int startY, int endX, int endY);
|
|
||||||
string osDrawLine(string drawList, int endX, int endY);
|
|
||||||
string osDrawText(string drawList, string text);
|
|
||||||
string osDrawEllipse(string drawList, int width, int height);
|
|
||||||
string osDrawRectangle(string drawList, int width, int height);
|
|
||||||
string osDrawFilledRectangle(string drawList, int width, int height);
|
|
||||||
string osSetFontSize(string drawList, int fontSize);
|
|
||||||
string osSetPenSize(string drawList, int penSize);
|
|
||||||
string osSetPenColour(string drawList, string colour);
|
|
||||||
string osDrawImage(string drawList, int width, int height, string imageUrl);
|
|
||||||
void osSetStateEvents(int events);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,10 +25,22 @@
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Runtime.Remoting.Lifetime;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using System.Threading;
|
||||||
|
using Axiom.Math;
|
||||||
using libsecondlife;
|
using libsecondlife;
|
||||||
|
using OpenSim.Framework;
|
||||||
|
using OpenSim.Framework.Communications;
|
||||||
|
using OpenSim.Region.Environment.Interfaces;
|
||||||
using OpenSim.Region.Environment.Scenes;
|
using OpenSim.Region.Environment.Scenes;
|
||||||
|
using OpenSim.Region.ScriptEngine.Common;
|
||||||
|
using OpenSim.Region.ScriptEngine.Common.ScriptEngineBase;
|
||||||
|
using OpenSim.Region.Environment;
|
||||||
|
using OpenSim.Region.Environment.Modules.LandManagement;
|
||||||
|
//using OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL;
|
||||||
|
|
||||||
namespace OpenSim.Region.ScriptEngine.Common
|
namespace OpenSim.Region.ScriptEngine.Common
|
||||||
{
|
{
|
||||||
|
@ -242,5 +254,289 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
// public double Z;
|
// public double Z;
|
||||||
// public double R;
|
// public double R;
|
||||||
//}
|
//}
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// OpenSim functions
|
||||||
|
//
|
||||||
|
|
||||||
|
public int osTerrainSetHeight(int x, int y, double val)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (x > 255 || x < 0 || y > 255 || y < 0)
|
||||||
|
LSLError("osTerrainSetHeight: Coordinate out of bounds");
|
||||||
|
|
||||||
|
if (World.PermissionsMngr.CanTerraform(m_host.OwnerID, new LLVector3(x, y, 0)))
|
||||||
|
{
|
||||||
|
World.Heightmap[x, y] = val;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public double osTerrainGetHeight(int x, int y)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (x > 255 || x < 0 || y > 255 || y < 0)
|
||||||
|
LSLError("osTerrainGetHeight: Coordinate out of bounds");
|
||||||
|
|
||||||
|
return World.Heightmap[x, y];
|
||||||
|
}
|
||||||
|
|
||||||
|
public int osRegionRestart(double seconds)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (World.PermissionsMngr.CanRestartSim(m_host.OwnerID))
|
||||||
|
{
|
||||||
|
World.Restart((float)seconds);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void osRegionNotice(string msg)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
World.SendGeneralAlert(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void osSetRot(LLUUID target, Quaternion rotation)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (World.Entities.ContainsKey(target))
|
||||||
|
{
|
||||||
|
World.Entities[target].Rotation = rotation;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
LSLError("osSetRot: Invalid target");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetDynamicTextureURL(string dynamicID, string contentType, string url, string extraParams,
|
||||||
|
int timer)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (dynamicID == String.Empty)
|
||||||
|
{
|
||||||
|
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
||||||
|
LLUUID createdTexture =
|
||||||
|
textureManager.AddDynamicTextureURL(World.RegionInfo.RegionID, m_host.UUID, contentType, url,
|
||||||
|
extraParams, timer);
|
||||||
|
return createdTexture.ToString();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//TODO update existing dynamic textures
|
||||||
|
}
|
||||||
|
|
||||||
|
return LLUUID.Zero.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetDynamicTextureURLBlend(string dynamicID, string contentType, string url, string extraParams,
|
||||||
|
int timer, int alpha)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (dynamicID == String.Empty)
|
||||||
|
{
|
||||||
|
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
||||||
|
LLUUID createdTexture =
|
||||||
|
textureManager.AddDynamicTextureURL(World.RegionInfo.RegionID, m_host.UUID, contentType, url,
|
||||||
|
extraParams, timer, true, (byte) alpha );
|
||||||
|
return createdTexture.ToString();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//TODO update existing dynamic textures
|
||||||
|
}
|
||||||
|
|
||||||
|
return LLUUID.Zero.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetDynamicTextureData(string dynamicID, string contentType, string data, string extraParams,
|
||||||
|
int timer)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (dynamicID == String.Empty)
|
||||||
|
{
|
||||||
|
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
||||||
|
if (textureManager != null)
|
||||||
|
{
|
||||||
|
LLUUID createdTexture =
|
||||||
|
textureManager.AddDynamicTextureData(World.RegionInfo.RegionID, m_host.UUID, contentType, data,
|
||||||
|
extraParams, timer);
|
||||||
|
return createdTexture.ToString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//TODO update existing dynamic textures
|
||||||
|
}
|
||||||
|
|
||||||
|
return LLUUID.Zero.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetDynamicTextureDataBlend(string dynamicID, string contentType, string data, string extraParams,
|
||||||
|
int timer, int alpha)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (dynamicID == String.Empty)
|
||||||
|
{
|
||||||
|
IDynamicTextureManager textureManager = World.RequestModuleInterface<IDynamicTextureManager>();
|
||||||
|
if (textureManager != null)
|
||||||
|
{
|
||||||
|
LLUUID createdTexture =
|
||||||
|
textureManager.AddDynamicTextureData(World.RegionInfo.RegionID, m_host.UUID, contentType, data,
|
||||||
|
extraParams, timer, true, (byte) alpha);
|
||||||
|
return createdTexture.ToString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//TODO update existing dynamic textures
|
||||||
|
}
|
||||||
|
|
||||||
|
return LLUUID.Zero.ToString();
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool osConsoleCommand(string command)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
Nini.Config.IConfigSource config = new Nini.Config.IniConfigSource(Application.iniFilePath);
|
||||||
|
if (config.Configs["LL-Functions"] == null)
|
||||||
|
config.AddConfig("LL-Functions");
|
||||||
|
|
||||||
|
if (config.Configs["LL-Functions"].GetBoolean("AllowosConsoleCommand", false))
|
||||||
|
{
|
||||||
|
if (World.PermissionsMngr.CanRunConsoleCommand(m_host.OwnerID))
|
||||||
|
{
|
||||||
|
OpenSim.Framework.Console.MainConsole.Instance.RunCommand(command);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
public void osSetPrimFloatOnWater(int floatYN)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (m_host.ParentGroup != null)
|
||||||
|
{
|
||||||
|
if (m_host.ParentGroup.RootPart != null)
|
||||||
|
{
|
||||||
|
m_host.ParentGroup.RootPart.SetFloatOnWater(floatYN);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adam's super super custom animation functions
|
||||||
|
public void osAvatarPlayAnimation(string avatar, string animation)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (World.Entities.ContainsKey(avatar) && World.Entities[avatar] is ScenePresence)
|
||||||
|
{
|
||||||
|
ScenePresence target = (ScenePresence)World.Entities[avatar];
|
||||||
|
target.AddAnimation(avatar, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void osAvatarStopAnimation(string avatar, string animation)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
if (World.Entities.ContainsKey(avatar) && World.Entities[avatar] is ScenePresence)
|
||||||
|
{
|
||||||
|
ScenePresence target = (ScenePresence)World.Entities[avatar];
|
||||||
|
target.RemoveAnimation(animation);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Texture draw functions
|
||||||
|
public string osMovePen(string drawList, int x, int y)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "MoveTo " + x + "," + y + ";";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawLine(string drawList, int startX, int startY, int endX, int endY)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "MoveTo "+ startX+","+ startY +"; LineTo "+endX +","+endY +"; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawLine(string drawList, int endX, int endY)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "LineTo " + endX + "," + endY + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawText(string drawList, string text)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "Text " + text + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawEllipse(string drawList, int width, int height)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "Ellipse " + width + "," + height + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawRectangle(string drawList, int width, int height)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "Rectangle " + width + "," + height + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawFilledRectangle(string drawList, int width, int height)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "FillRectangle " + width + "," + height + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetFontSize(string drawList, int fontSize)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "FontSize "+ fontSize +"; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetPenSize(string drawList, int penSize)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "PenSize " + penSize + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osSetPenColour(string drawList, string colour)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList += "PenColour " + colour + "; ";
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public string osDrawImage(string drawList, int width, int height, string imageUrl)
|
||||||
|
{
|
||||||
|
m_host.AddScriptLPS(1);
|
||||||
|
drawList +="Image " +width + "," + height+ ","+ imageUrl +"; " ;
|
||||||
|
return drawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void osSetStateEvents(int events)
|
||||||
|
{
|
||||||
|
m_host.setScriptEvents(m_itemID, events);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,5 +33,37 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
{
|
{
|
||||||
public interface OSSL_BuilIn_Commands_Interface
|
public interface OSSL_BuilIn_Commands_Interface
|
||||||
{
|
{
|
||||||
|
//OpenSim functions
|
||||||
|
string osSetDynamicTextureURL(string dynamicID, string contentType, string url, string extraParams, int timer);
|
||||||
|
string osSetDynamicTextureURLBlend(string dynamicID, string contentType, string url, string extraParams,
|
||||||
|
int timer, int alpha);
|
||||||
|
string osSetDynamicTextureData(string dynamicID, string contentType, string data, string extraParams, int timer);
|
||||||
|
string osSetDynamicTextureDataBlend(string dynamicID, string contentType, string data, string extraParams,
|
||||||
|
int timer, int alpha);
|
||||||
|
double osTerrainGetHeight(int x, int y);
|
||||||
|
int osTerrainSetHeight(int x, int y, double val);
|
||||||
|
int osRegionRestart(double seconds);
|
||||||
|
void osRegionNotice(string msg);
|
||||||
|
bool osConsoleCommand(string Command);
|
||||||
|
void osSetParcelMediaURL(string url);
|
||||||
|
void osSetPrimFloatOnWater(int floatYN);
|
||||||
|
|
||||||
|
// Animation commands
|
||||||
|
void osAvatarPlayAnimation(string avatar, string animation);
|
||||||
|
void osAvatarStopAnimation(string avatar, string animation);
|
||||||
|
|
||||||
|
//texture draw functions
|
||||||
|
string osMovePen(string drawList, int x, int y);
|
||||||
|
string osDrawLine(string drawList, int startX, int startY, int endX, int endY);
|
||||||
|
string osDrawLine(string drawList, int endX, int endY);
|
||||||
|
string osDrawText(string drawList, string text);
|
||||||
|
string osDrawEllipse(string drawList, int width, int height);
|
||||||
|
string osDrawRectangle(string drawList, int width, int height);
|
||||||
|
string osDrawFilledRectangle(string drawList, int width, int height);
|
||||||
|
string osSetFontSize(string drawList, int fontSize);
|
||||||
|
string osSetPenSize(string drawList, int penSize);
|
||||||
|
string osSetPenColour(string drawList, string colour);
|
||||||
|
string osDrawImage(string drawList, int width, int height, string imageUrl);
|
||||||
|
void osSetStateEvents(int events);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue