Difference between revisions of "A Technical overview of Second Life"

From Second Life Wiki
Jump to navigation Jump to search
Line 21: Line 21:
and the distance between them is
and the distance between them is
   float d = [[llVecDist]]( p1, p2 );
   float d = [[llVecDist]]( p1, p2 );
===Finding the position===
LSL has a function that returns the current position
  vector p = [[llGetPos]]();
This function returns the world coordinates for the object it is in.  Note that if the object is an attachment to an avatar, it gives the avatar's position, not the object itself.


===Local coordinates===
===Local coordinates===

Revision as of 16:58, 15 May 2007

Intro

Many activities in SL, especially ones related to content creation, require some technical knowledge. This includes Building using prims, Scripting using LSL, and other activities such as creating clothing and textures, though perhaps to a lesser degree.

Positions and Vectors

Every place in SL has a unique position. Look at the top of your viewer screen to see the current position of your Avatar in the current region, for example Ross/19.5/245.6/51.3. This means you are in the Ross region, 19.5 meters east of the leftmost edge, 245.6 meters north of the bottom edge, and 51.3 meters up from the bottom (which might be both underground and underwater). In LSL, positions are usually stored in a data structure called a vector, and might look like

  vector pos = < 19.5, 245.6, 51.3 >; 

The Southwest corner of every region is 0/0/0. The positions in a region relative to that corner are sometimes called world, region, global, or sim coordinates. We will talk about local coordinates in a minute. In World coordinates, the first number is always East, the second is always North, and the third is always Up, though negative numbers can also be used to mean West, South, and Down.

Given the position pos above, you can find other points. Exactly 10 meters East would be

vector p1 = pos + <10, 0, 0 >;

Five meters below would be

vector p2 = pos - < 0, 0, -5 >;

Given two points, p1 and p2, a point exactly halfway between them is

vector halfway = (p1 + p2)/2;

and the distance between them is

 float d = llVecDist( p1, p2 );

Finding the position

LSL has a function that returns the current position

 vector p = llGetPos();

This function returns the world coordinates for the object it is in. Note that if the object is an attachment to an avatar, it gives the avatar's position, not the object itself.

Local coordinates

An object or an avatar in SL always has some position in World coordinates, but it also has local coordinates as well. The local position of an object is always < 0, 0, 0 >. This might seem boring, because it is, but there are also the directions to consider. The x-direction is considered the front of the object, the y-direction is left, and the z-direction is up. You can see the x, y, and z directions in the Edit window, just select some object and the Local coordinates (not World). The red arrow is, by definition, front. In local coordinates, < 1.5, 0, 0 > is 1.5 meters in front of the object, and <0, -1, 0> is 1 meter below, all in local coordinates.

Of course, you need to be able to convert from local to world, and from world to local. We will see how to do this as soon as we talk about rotations.

Basic Rotations

Imagine an object that looks like an airplane. The airplane is pointing in some direction (duh!) and has some roll around the direction it is pointing. SL uses a rotation to describe the pointing and the roll. You can get the rotation of an object (such as our arirplane) like this

 rotation r = llGetRot();

One rotation is called the ZERO_ROTATION, which is nose (local front) pointing exactly East, the left wing (local left) pointing exactly North, and the top (local up) of the airplane pointing exactly Up. You can make your object point this way using

 llSetRot( ZERO_ROTATION );

LSL Fundamentals

Physics, Force, and Movement

Non-physical Movement