2006-11-04 00:41:11 +00:00
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
2006-12-19 23:13:04 +00:00
|
|
|
using System.Threading;
|
2006-11-04 00:41:11 +00:00
|
|
|
|
|
|
|
|
using IA_SimpleInventory;
|
|
|
|
|
using IA_ImageTool;
|
|
|
|
|
|
|
|
|
|
using libsecondlife;
|
|
|
|
|
using libsecondlife.InventorySystem;
|
|
|
|
|
using libsecondlife.AssetSystem;
|
|
|
|
|
|
|
|
|
|
namespace IA_MultiImageUpload
|
|
|
|
|
{
|
2006-12-19 23:13:04 +00:00
|
|
|
class MultiImageUpload
|
2006-11-04 00:41:11 +00:00
|
|
|
{
|
2006-12-19 23:13:04 +00:00
|
|
|
private SecondLife _Client;
|
|
|
|
|
private ManualResetEvent ConnectedSignal = new ManualResetEvent(false);
|
|
|
|
|
|
2006-11-04 00:41:11 +00:00
|
|
|
protected string ImageDirectory;
|
|
|
|
|
|
2006-12-19 23:13:04 +00:00
|
|
|
static void Main(string[] args)
|
2006-11-04 00:41:11 +00:00
|
|
|
{
|
|
|
|
|
if (args.Length < 4)
|
|
|
|
|
{
|
|
|
|
|
MultiImageUpload.Usage();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
string fullpath = Path.GetFullPath(args[3]);
|
|
|
|
|
|
|
|
|
|
if (!Directory.Exists(fullpath))
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("Directory does not exist: " + fullpath);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MultiImageUpload app = new MultiImageUpload( fullpath );
|
2006-12-19 23:13:04 +00:00
|
|
|
if (app.Connect(args[0], args[1], args[2]))
|
|
|
|
|
{
|
|
|
|
|
if (app.ConnectedSignal.WaitOne(TimeSpan.FromMinutes(1), false))
|
|
|
|
|
{
|
|
|
|
|
app.doStuff();
|
|
|
|
|
app.Disconnect();
|
|
|
|
|
}
|
|
|
|
|
}
|
2006-11-04 00:41:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public MultiImageUpload(string dir)
|
|
|
|
|
{
|
|
|
|
|
ImageDirectory = dir;
|
2006-12-19 23:13:04 +00:00
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_Client = new SecondLife();
|
|
|
|
|
_Client.Network.OnConnected += new NetworkManager.ConnectedCallback(Network_OnConnected);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
|
|
|
|
// Error initializing the client
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
Console.WriteLine(e.ToString());
|
|
|
|
|
}
|
|
|
|
|
|
2006-11-04 00:41:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void Usage()
|
|
|
|
|
{
|
|
|
|
|
System.Console.WriteLine("MultiImageUpload [FirstName] [LastName] [Password] [Directory]");
|
|
|
|
|
}
|
|
|
|
|
|
2006-12-19 23:13:04 +00:00
|
|
|
protected void doStuff()
|
2006-11-04 00:41:11 +00:00
|
|
|
{
|
2006-12-19 23:13:04 +00:00
|
|
|
InventoryFolder iFolder = _Client.Inventory.getFolder("Textures");
|
2006-11-04 00:41:11 +00:00
|
|
|
iFolder = iFolder.CreateFolder(Helpers.GetUnixTime().ToString());
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("Uploading images:");
|
|
|
|
|
|
|
|
|
|
string[] files = Directory.GetFiles(ImageDirectory, "*.tif");
|
|
|
|
|
|
|
|
|
|
int filesUploaded = 0;
|
|
|
|
|
foreach (string file in files)
|
|
|
|
|
{
|
|
|
|
|
byte[] j2cdata = null;
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
j2cdata = KakaduWrap.ReadJ2CData(file);
|
|
|
|
|
} catch ( Exception e )
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine(e.Message);
|
|
|
|
|
}
|
|
|
|
|
if ( j2cdata != null )
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine(file);
|
|
|
|
|
iFolder.NewImage(Path.GetFileName(file), "ImageTool Upload", j2cdata);
|
|
|
|
|
|
|
|
|
|
if (++filesUploaded >= 20)
|
|
|
|
|
{
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2006-12-19 23:13:04 +00:00
|
|
|
void Network_OnConnected(object sender)
|
|
|
|
|
{
|
|
|
|
|
ConnectedSignal.Set();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected bool Connect(string FirstName, string LastName, string Password)
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("Attempting to connect and login to SecondLife.");
|
|
|
|
|
|
|
|
|
|
// Setup Login to Second Life
|
|
|
|
|
Dictionary<string, object> loginReply = new Dictionary<string, object>();
|
|
|
|
|
|
|
|
|
|
// Login
|
|
|
|
|
if (!_Client.Network.Login(FirstName, LastName, Password, "MultiImageUpload", "static.sprocket@gmail.com"))
|
|
|
|
|
{
|
|
|
|
|
// Login failed
|
|
|
|
|
Console.WriteLine("Error logging in: " + _Client.Network.LoginError);
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Login was successful
|
|
|
|
|
Console.WriteLine("Login was successful.");
|
|
|
|
|
Console.WriteLine("AgentID: " + _Client.Network.AgentID);
|
|
|
|
|
Console.WriteLine("SessionID: " + _Client.Network.SessionID);
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected void Disconnect()
|
|
|
|
|
{
|
|
|
|
|
// Logout of Second Life
|
|
|
|
|
Console.WriteLine("Request logout");
|
|
|
|
|
_Client.Network.Logout();
|
|
|
|
|
}
|
2006-11-04 00:41:11 +00:00
|
|
|
}
|
|
|
|
|
}
|