Difference between revisions of "Landmark2slurl"
m (Replaced <source> with <syntaxhighlight>) |
m (Added this to LSL Examples!) |
||
Line 1: | Line 1: | ||
{{LSL Header}} | {{LSL Header}} | ||
Landmarks retrieved via LSL from an object's [[inventory]] will only have ''global'' coordinates in it (plus the landmark's inventory name, like all assets), which are retrieved through an (expensive) [[dataserver]] call. In order to create a SLURL from the landmark (as the viewer does with the '''Copy to SLURL''' option), first we need to figure out the region's position in the grid, then look up its name, and use the remainder as local coordinates. | |||
Unfortunately, at the time of writing, there is no LSL function to retrieve the region's name, based on its grid coordinates. The only alternative given by us by Linden Lab is to use a (special) capabilities call instead, which can be used via [[llHTTPRequest]]. It was allegedly designed to inject some Javascript on the Map API but works well for our own purposes. | |||
The script below shows how exactly to achieve this and do the calculations right (i.e., without any rounding errors). | |||
<syntaxhighlight lang="lsl2"> | <syntaxhighlight lang="lsl2"> | ||
// Click to print | // Click to print SLURL for every landmark in inventory. | ||
// Uses llRequestInventoryData() to get coordinates | // Uses llRequestInventoryData() to get coordinates | ||
// Uses http://wiki.secondlife.com/wiki/Linden_Lab_Official:Map_API_Reference#Region_name_from_global_coordinates to get region name | // Uses http://wiki.secondlife.com/wiki/Linden_Lab_Official:Map_API_Reference#Region_name_from_global_coordinates to get region name | ||
Line 47: | Line 54: | ||
} | } | ||
}</syntaxhighlight> | }</syntaxhighlight> | ||
[[Category:LSL Examples]] |
Latest revision as of 02:16, 26 January 2024
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Landmarks retrieved via LSL from an object's inventory will only have global coordinates in it (plus the landmark's inventory name, like all assets), which are retrieved through an (expensive) dataserver call. In order to create a SLURL from the landmark (as the viewer does with the Copy to SLURL option), first we need to figure out the region's position in the grid, then look up its name, and use the remainder as local coordinates.
Unfortunately, at the time of writing, there is no LSL function to retrieve the region's name, based on its grid coordinates. The only alternative given by us by Linden Lab is to use a (special) capabilities call instead, which can be used via llHTTPRequest. It was allegedly designed to inject some Javascript on the Map API but works well for our own purposes.
The script below shows how exactly to achieve this and do the calculations right (i.e., without any rounding errors).
// Click to print SLURL for every landmark in inventory.
// Uses llRequestInventoryData() to get coordinates
// Uses http://wiki.secondlife.com/wiki/Linden_Lab_Official:Map_API_Reference#Region_name_from_global_coordinates to get region name
integer landmarkIndex;
vector landmarkCoords;
string landmarkRegion;
string landmarkSlurl;
key inventoryRequestId;
key mapRequestId;
requestLandmarkInfo(integer inventoryIndex) {
if (inventoryIndex >= llGetInventoryNumber(INVENTORY_LANDMARK)) return;
landmarkIndex = inventoryIndex;
string landmarkName = llGetInventoryName(INVENTORY_LANDMARK, landmarkIndex);
inventoryRequestId = llRequestInventoryData(landmarkName);
}
default {
touch_start(integer count) {
requestLandmarkInfo(0);
}
dataserver(key requestId, string data) {
if (requestId != inventoryRequestId) return;
if ((vector)data == ZERO_VECTOR) return;
// landmark request
landmarkCoords = llGetRegionCorner() + (vector)data;
// http://wiki.secondlife.com/wiki/Linden_Lab_Official:Map_API_Reference#Region_name_from_global_coordinates
mapRequestId = llHTTPRequest(
"https://cap.secondlife.com/cap/0/b713fe80-283b-4585-af4d-a3b7d9a32492?var=region"
+ "&grid_x=" + (string)((integer)landmarkCoords.x / 256)
+ "&grid_y=" + (string)((integer)landmarkCoords.y / 256), [], "");
}
http_response(key requestId, integer status, list metadata, string body) {
if (requestId != mapRequestId) return;
landmarkRegion = llList2String(llParseString2List(body, ["var region='", "';"], []), 0);
landmarkSlurl = "http://maps.secondlife.com/secondlife/" + llEscapeURL(landmarkRegion) +
"/" + (string)((integer)landmarkCoords.x % 256) +
"/" + (string)((integer)landmarkCoords.y % 256) +
"/" + (string)((integer)landmarkCoords.z);
llOwnerSay(llGetInventoryName(INVENTORY_LANDMARK, landmarkIndex) + ": "
+ landmarkSlurl + " <nolink>" + landmarkSlurl + "</nolink>");
requestLandmarkInfo(landmarkIndex + 1);
}
}