OsGetInertiaData

From OpenSimulator

(Difference between revisions)
Jump to: navigation, search
(Add exemple)
Line 17: Line 17:
 
     touch_start(integer n)
 
     touch_start(integer n)
 
     {
 
     {
         list buffer =osGetInertiaData();
+
        string text;
 +
         list buffer = osGetInertiaData();
 
         float mass = llList2Float(buffer, 0);
 
         float mass = llList2Float(buffer, 0);
 
         vector center = llList2Vector(buffer, 1);
 
         vector center = llList2Vector(buffer, 1);
 
         vector Idiag = llList2Vector(buffer, 2);
 
         vector Idiag = llList2Vector(buffer, 2);
 
         vector Ioffdiag = llList2Vector(buffer, 3);
 
         vector Ioffdiag = llList2Vector(buffer, 3);
        string text;
 
 
         text += "\n• The total mass of the linkset is " + (string)mass;
 
         text += "\n• The total mass of the linkset is " + (string)mass;
 
         text += "\n• The center of mass offset relative to root prim is " + (string)center;
 
         text += "\n• The center of mass offset relative to root prim is " + (string)center;

Revision as of 17:08, 20 February 2019

list osGetInertiaData()
returns a list:

[
float mass, // the total mass of the linkset
vector center, // the center of mass offset relative to root prim
vector Idiag, // diagonal elements of inertia
vector Ioffdiag // off diagonal elements of inertia
]

mass maybe -1 if inertia data is invalid or not avaiable

Caution ! Only supported by ubOde for now

Threat Level This function does not do a threat level check
Permissions Use of this function is always allowed by default
Extra Delay 0 seconds
Example(s)
// Example of osGetInertiaData
 
default
{
    state_entry()
    {
        llSetStatus(STATUS_PHYSICS, TRUE);
        llSetObjectName("osGetInertiaData");
    }
 
    touch_start(integer n)
    {
        string text;
        list buffer = osGetInertiaData();
        float mass = llList2Float(buffer, 0);
        vector center = llList2Vector(buffer, 1);
        vector Idiag = llList2Vector(buffer, 2);
        vector Ioffdiag = llList2Vector(buffer, 3);
        text += "\n• The total mass of the linkset is " + (string)mass;
        text += "\n• The center of mass offset relative to root prim is " + (string)center;
        text += "\n• Diagonal elements of inertia is " + (string)Idiag;
        text += "\n• Off diagonal elements of inertia is " + (string)Ioffdiag;
        llSay(PUBLIC_CHANNEL, text);
    }
}
Notes
This function was added in 0.9.0.1


Personal tools
General
About This Wiki