[3dsMax] Introducción Maxscript

1- Introducción.
1.1 – Descripción general de Maxscript. Maxscript es un lenguaje de alto nivel orientado a objetos y de sintaxis muy sencilla. Está pensado para usuarios de 3d Studio Max que no estén familiarizados con la programación. Sus variables son sin tipo y no hay distinción entre mayúsculas y minúsculas.

Este lenguaje no necesita compilador. Todas las instrucciones se llevan a cabo en tiempo de ejecución, podemos utilizar Maxscript y 3d Studio Max al mismo tiempo. Se puede crear un cubo en Maxscript y seguidamente, modificarlo en 3d Studio.

Algunos ejemplos de utilización de este lenguaje pueden ser:[*] creación de escenas complejas que interactivamente serían demasiado complicadas de llevar a cabo.[*] creación de herramientas de proceso por lotes.[*] generación de funciones nuevas para facilitar una determinada tarea.[*] uso de casi todas las funciones de 3d Studio Max.[*] creación de nuevos paneles y ventanas con utilidades para 3d Studio Max.

1.2 – Cómo se accede a Maxscript
Maxscript se encuentra en el panel de herramientas. -6.jpg
En este panel hay una persiana de utilidades, y dentro de ella se puede presionar el botón Maxscript.
-7.jpg -8.jpg

Una vez se haya abierto la persiana de Maxscript podremos acceder a las opciones: abrir oyente, guión nuevo, abrir guión, ejecutar guión y cerrar.[*]abrir oyente: abre la ventana oyente de Maxscript. Si pulsamos esta opción y el oyente está minimizado, o escondido detrás de otra ventana, lo restaurara. Si la cierra y la vuelve a abrir, conserva el texto que había antes de cerrarla.

-9.jpg
[*]guión nuevo: abre un editor en una ventana nueva, donde se puede escribir un nuevo guión en Maxscript[*]abrir guión: al pulsar esta opción se abre un cuadro de diálogo de apertura de archivos en el que el usuario ha de elegir un guión en Maxscript. Una vez escogido el guión se abrirá una ventana editor de Maxscript con el contenido del fichero.[*]ejecutar guión: el usuario escoge un guión en Maxscript y éste se le y se ejecuta. La salida puede verse, dependiendo del tipo de guión, en los visores de 3d Studio Max o bien en la ventana oyente de Maxscript.[*]utilidades: muestra las utilidades de guión disponibles.[*]cerrar: cierra la utilidad Maxscript.

1.3 – Utilización del oyente de Maxscript.

En el oyente se pueden ejecutar comandos y expresiones. Para ejecutarlos, simplemente se escribe el comando o expresión y se pulsa la tecla [enter.

Podemos desplazarnos por el texto del oyente como si fuese un editor normal. También se puede cortar, copiar y pegar el texto seleccionado ([Control-x, [ Control-c, [Control-v) y editar nuevos comandos en medio del texto, o modificar los que ya teníamos y después ejecutarlos.

Para ejecutar comandos en medio del texto, después de editarlos en una línea nueva, se ha de pulsar la tecla [enter del teclado numérico, o bien presionar [mayúsculas – enter. Los resultados se muestran en la misma ventana, bajo el comando o los comandos ejecutados.

Es posible ejecutar bloques de código seleccionándolos previamente y pulsando las teclas [mayúsculas – enter o bien, presionando [enter desde el teclado numérico.

La instrucción [include nombre fichero. Extensión representa el contenido del fichero nombre fichero en el oyente sin ejecutarlo.

Se puede seleccionar el texto y ejecutarlo por trozos.

Podemos trabajar con el oyente de Maxscript y con 3d Studio Max al mismo tiempo.

1.4 – Variables en Maxscript.
Las variables se utilizan para almacenar datos que varían durante la ejecución del programa. En Maxscript no es necesario declarar las variables antes de utilizarlas.

Tenemos dos clases de variables en Maxscript:[*] variables locales: se considerarán variables locales aquellas que se utilicen por primera vez dentro de un bloque o función. En caso contrario, las variables se considerarán globales, sólo son visibles en el bloque o función donde se declaran.[*] su valor se mantiene mientras se está ejecutando la función o el bloque donde se encuentran.[*]variables globales: son visibles en todo el código Maxscript.[*] podemos acceder a ellas desde diferentes utilidades, funciones, etc. Su valor permanece hasta que se sale de 3d Studio Max.

La primera vez que se utiliza una variable Maxscript la inicia como undefined.

Para que el código sea más claro, es recomendable indicar de qué clase son las variables. Para ello, utilizaremos los términos local y global. Nótese que los comentarios en Maxscript van precedidos de 2 guiones – -.
Table border=1 width=100%> <td height=117>[local x = 2, = 3.7
Local y, z, r.

Global texto = hola
Global i = 1, – La declaración continúa en las líneas siguientes.
= 3, que = sin (35)
Local f=g=h=0
En la declaración de variables, podemos definir si son globales o locales, pero no indicamos de qué tipo son. Esto es debido a que las variables son libres de tipo. Las variables pueden cambiar el tipo de valor en las asignaciones. Por ejemplo, en una primera asignación una variable puede ser un entero, y en una segunda asignación, la variable puede ser una cadena de caracteres. Esto no quiere decir que se puedan hacer operación incorrectas. Si tratamos de hacerlas, Maxscript dará un error. Para convertir un tipo de variable en otro tipo utilizaremos la instrucción as de la siguiente forma:
[valor as nuevo_tipo.
Nótese en la imagen siguiente que las salidas de comando en el oyente siempre son de color azul, excepto en los errores.

-10.jpg

1.5 – Operaciones matemáticas en Maxscript.

Cuando introducimos una operación matemática en Maxscript, éste evalúa dicha operación y muestra el resultado en la ventana oyente. Maxscript dispone de las operación matemáticas necesarias para hacer que funcione de forma semejante a una calculadora.

Las expresiones matemáticas están compuestas por operadores (+,-,*.) y por operandos. Un operando matemático puede ser:[*] un nombre de variable, números, etc. Por ejemplo:[*][1 + 3 – Suma ambos números[*][total – 5 – Suma 5 al valor de la variable total[*][total + iva – Suma el valor de la variable total más el valor de la variable iva[*] una llamada a una función. Por ejemplo[*][(gradosaradianes grados:180) + 5 – Llama a la función gradosaradianes pasando [como parámetro 180 grados y al resultado le suma 5.[*]una expresión matemática. Por ejemplo:[*][123 + (total – Iva) – Restamos el contenido de la variable iva al contenido de total y le sumamos el valor 123.

En la tabla siguiente podemos ver las expresiones matemáticas que tiene Maxscript en la figura siguiente tenemos unos ejemplos de expresiones matemáticas en el oyente de Maxscript:
-11.jpg

También se puede utilizar el formato abreviado de asignación del lenguaje c para modificar un valor contenido en una variable. Por ejemplo:
Table border=1 width=100%> formato abreviado de asignación <td>[ x + = 5 – Incrementa en 5 el valor de x.

Y * = 7 – Multiplica por 7 el valor de y.

Z – = 9 – Resta 9 al valor de z.

Que / = 8 – Divide que entre 8.

1.6 – Objetos de 3d Studio Max en Maxscript.

Maxscript puede trabajar con objetos de 3d Studio Max al mismo tiempo que se trabaja con ellos de forma interactiva a través de los botones y paneles. De hecho, los objetos pueden ser creados, transformados, modificados y eliminados desde Maxscript al igual que se hace desde 3d Studio Max.

Los comandos de creación de objetos coinciden con los nombres de estos objetos. Podemos crear una caja tan sólo escribiendo en la ventana oyente el comando [box (), o bien, si tenemos la versión, su equivalente en español [caja (). Una vez escrito, y después de presionar la tecla intro, se crea una caja con los parámetros por defecto. Es recomendable escribir los comandos en inglés, ya que no todos los parámetros que hay se han traducido al español. En este tutorial escribiremos todos los comandos y parámetros en inglés.

Es indiferente si escribimos el comando en mayúsculas y en minúsculas, ya que Maxscript no distingue entre ellos. También se recomienda asignar el objeto a una variable, para hacer más manejable el uso de dicho objeto. Si el objeto creado no se asigna a ninguna variable y queremos referirnos a él utilizaremos el símbolo $ delante del nombre que tiene el objeto en la escena.

Pongamos un ejemplo de creación de una caja de altura 20, anchura 30 y longitud 40. Asignaremos el resultado a la variable primera caja:
-12.jpg
Cuando utilizamos el comando [box con parámetros, se eliminan los paréntesis y en su lugar ponemos los nombres de los parámetros seguidos de los dos puntos y su valor. Los parámetros que se omiten adquieren su valor por defecto.

Cuando Maxscript ha creado la caja devuelve el nombre que tiene dicha caja en la escena (en este caso, el nombre será caja01) y al mismo tiempo indica la posición que tiene la nueva caja en la escena (con las coordenadas x y, z separadas por comas y dentro de corchetes). Maxscript dibuja la caja en la escena. Se puede trabajar con la nueva caja desde 3d Studio Max como si se hubiese creado de forma interactiva. Podemos transformarla, modificarla, eliminarla e incluso deshacer la creación de la caja con el botón deshacer.

Atención: no es lo mismo el nombre que tiene la caja en la escena (caja01) que el nombre de variable en Maxscript (primera caja).

Utilizaremos la variable primera caja para acceder más fácilmente a los parámetros de creación y a las propiedades generales y de transformación:
-13.jpg

En la imagen anterior hay varios ejemplos de modificación de algunos parámetros de la caja. Podemos modificar todos los parámetros del objeto (altura, radio, etc), de nodo (nombre, color,) y de transformación (rotación, posición, etc). Para modificar un valor en un objeto utilizaremos uno de los siguientes esquemas:[*] $nombreobjeto. Parámetro=nuevovalor.[*] nombrevariable. Parámetro=nuevovalor

Donde nombreobjeto sería equivalente a [$caja01 en el ejemplo anterior y nombrevariable equivale a [primera caja.
1.6.1 – Showclass.

Para saber los nombres y tipos de parámetros de un objeto se puede utilizar la función [showclass(). Si escribimos en el oyente de Maxscript sólo el nombre de la función seguido de los dos paréntesis tendremos una lista de todos los objetos de 3dstudio Max y sus parámetros correspondientes. Cada parámetro ira seguido de su tipo.

Lo más normal es que se quiera saber los parámetros de un objeto determinado, sin necesidad de que salgan todos los objetos de 3d Studio Max. Tenemos dos ejemplos de ello en el siguiente recuadro.
Table border=1 width=100%> ejemplos de showclass <td>[showclass box.* – Muestra todos los parámetros de la clase box.

Box(caja) : geometryclass {10,0}
.height(altura) : float.length(longitud) : float.lengthsegs : integer.width(anchura) : float.widthsegs : integer.mapcords : bolean.heightsegs(segmsaltura) : integer.

Ok.
Showclass box.height – Muestra todos los datos del parámetro height.

Box(caja) : geometryclass {10,0}
.height(altura) : float.

Ok.

En el primer ejemplo indicamos con un asterisco que queremos saber todos los parámetros del objeto box. Utilizamos el asterisco como un comodín. Si quisiésemos saber todos los parámetros de los objetos que comenzasen por b sólo tendríamos que poner [showclass b*.* y obtendríamos una lista con ellos. Si por el contrario ya sabemos el parámetro, pero no estamos seguros del tipo que tiene, nos bastara con poner [showclassbox. Nombreparametro.

En el segundo ejemplo de showclass hemos comprobado que el parámetro [height de la clase [box es del tipo [float.

2.1 – Edición y ejecución de guiones en ficheros.

Como se ha comentado en el capítulo 1, en Maxscript se pueden generar nuevas utilidades y funciones para 3d Studio Max. Si queremos conservar los guiones de estas utilidades y funciones tendremos que guardarlos en ficheros, ya que el contenido de la ventana oyente se pierde una vez se cierra el programa. Para ello, en lugar de utilizar el oyente de Maxscript, abriremos un guión nuevo mediante el botón [abrir guión y escribiremos en el editor de guiones nuestro programa en Maxscript.

-14.jpg

Si por el contrario ya tenemos un guión escrito y lo queremos modificar podemos presionar el botón abrir guión o bien mediante la instrucción[ edit nombrefich, ms desde el oyente de Maxscript. Por convención, los ficheros escritos en Maxscript tienen la extensión [.ms.
2.1.1 – Teclas abreviadas.

En este apartado explicaremos todas las teclas de función que se utilizan en Maxscript. No es necesario aprendérselas de memoria, ni mucho menos, pero puede ser útil saber algunas de ellas para ir más rápido y evitar tener que irnos al menú y buscar la función. Se ha de decir que todos los métodos abreviados tienen su equivalente en los menús del oyente y del editor de Maxscript, o sea, que, si no te interesa el tema, puedes pasar al siguiente apartado directamente (confieso que este es un ).

Podemos utilizar teclas abreviadas tanto en el oyente de Maxscript como en el editor de guiones, pero, ojo. Hay un par que tienen significado diferente si las aplicas en un sitio o en otro. También hay abreviaciones específicas para el oyente, y abreviaciones sólo para el editor.

Comencemos primero por las que tienen significado diferente.
Control + s – guardar cómo. Abre un cuadro de diálogo para que el usuario introduzca el nombre del fichero en el que se va a guardar todo el texto activo del oyente, guardar. Guarda el contenido del editor en el fichero actual. Si el fichero no tiene nombre se abrirá un cuadro de diálogo para que el usuario introduzca el nombre que dese.< Ctrl + r – ejecutar guión. Se abre un cuadro de diálogo para que el usuario seleccione un fichero de Maxscript. Una vez seleccionado, se procederá a su ejecución, sitúa el cursor en el lugar donde se había situado anteriormente con un click del botón izquierdo, o en una operación de búsqueda. Esto es un poco complicado de entender. Pongamos un ejemplo. Un usuario ha buscado en su editor la palabra esfera, y ya va por la tercera ocurrencia, pero se da cuenta que la que le interesa es la segunda. Pulsando Ctrl + r se situara en la anterior, que es la que desea.

Otro ejemplo sería cuando un usuario hace click en una posición y luego se va a otro sitio. Podrá recuperar la posición en la que estaba anteriormente el cursor pulsando Ctrl + r – he de comentar que las teclas Ctrl + r en el editor de guiones particularmente no me han funcionado nunca. No sé si es cosa de mi 3d Studio Max o es uno de los muchos errores que tiene nuestro querido Maxscript.

A continuación os muestro otra tabla con funciones exclusivas del editor de guiones:
Table border=1 width=100%> teclas abreviadas exclusivas del editor de guiones <td width=29%>nombre
<td bgcolor= width=71%> significado en editor
Control + e evaluar todo. Evalúa todo el código que hay en el editor de guiones. Es lo mismo que seleccionar todo el texto y pulsar las teclas shift + enter. La ventaja es que no se tiene que seleccionar todo el texto.< Control + click derecho del ratón se muestra un menú con todos los elementos (botones, persianas, etiquetas, funciones, etc). De esta forma es más rápido ir de un sitio a otro. Simplemente se ha de pulsar la tecla Control y hacer un click con el botón derecho del ratón y seleccionar el elemento en el que te quieras posicionar con un click del botón izquierdo. El cursor se posicionara en el lugar que has seleccionado.< para que os hagáis una idea del menú que sale pulsando las teclas Control + click derecho del ratón aquí tenéis un ejemplo:

-15.jpg

La parte izquierda es la que se muestra al pulsar Control + click derecho del ratón. Una vez se ha seleccionado el elemento checkbutton, se muestra la lista de todos los checkbutton que hay en el documento.

La siguiente tabla muestra las teclas abreviadas que tienen el mismo significado tanto en el oyente de Maxscript como en el editor de guiones:
Table border=1 width=100%> teclas abreviadas comunes <td width=17%>nombre
Significado

Control + N nuevo script. Abre una nueva ventana de editor de guiones para que el usuario pueda escribir un nuevo documento de Maxscript.< Control + o abrir script. Se muestra un cuadro de diálogo para que el usuario pueda seleccionar unl documento existente. Una vez seleccionado, se abrirá el documento Maxscript.< Control + z deshacer. Deshace la última modificación que se ha hecho. Sólo tiene memoria para una modificación, o sea, que tened cuidado.< Control + x cortar. El usuario ha de seleccionar una parte del documento y pulsar Control + x. La selección desaparecerá (se copia en el portapapeles), pero el usuario podrá recuperarla situando el cursor a donde quiera que vuelva a aparecer y pulsando Control + v. Control + c copiar. El usuario ha de seleccionar un texto y pulsar Control + c. El texto seleccionado se copiara en el portapapeles. Para copiar de nuevo el texto, se habrá de situar en la posición donde dese y pulsar Control + v. La diferencia con cortar es que en este caso el texto seleccionado no desaparece.< Control + v pegar. Pega el contenido del portapapeles en la posición donde se encuentre el cursor.< Control + a seleccionar todo. Selecciona todo el texto del oyente de Maxscript o del editor de guiones activo en ese momento (donde se encuentre el cursor actualmente).< Control + f buscar. Se abre el cuadro de diálogo para buscar un texto. Control + g buscar siguiente. Repite la última búsqueda y selecciona la siguiente ocurrencia del texto que se ha indicado buscar.< Control + h remplazar. Abre el cuadro de diálogo de reemplazar.< Control + b selecciona el texto entre paréntesis, corchetes y claves. Es útil para saber si has cerrado todos los paréntesis en trozos grandes de código. El usuario tendrá que situar el cursor en cualquier posición que dese y pulsar Control + b.

Por ejemplo: (25 + 4 (345 / 7) -.

Si ponemos el cursor en / y pulsamos Control + b se seleccionara (345 / 7). En cambio, si ponemos el cursor en 8 se seleccionara toda la expresión.
Shift + enter se evalúa todo lo que se ha seleccionado.< Control + y rehacer. Vuelve a rehacer lo que se ha deshecho con Control + z <td height=23 valign=top>Control + i sangría. Pone una sangría en el texto. (equivalente a usar el tabulador).< y esto es todo en cuanto a teclas abreviadas. Ahora que ya os he dado la paliza, podéis ir al apartado siguiente.

2- Programación en Maxscript.
2.2 nombres.

Los nombres en Maxscript se utilizan para definir variables, funciones, parámetros, etc. Un nombre necesariamente ha de empezar por un carácter alfabético o bien, por el carácter _. Después del primer carácter, puede haber cualquier número de caracteres alfanuméricos o el carácter _.

A continuación os muestro algunos ejemplos de nombres que son correctos e incorrectos:
Correctos
Incorrectos
<td valign=top width=20%>[*][ nomcilindro_1[*][ _pos_04[*][ a[*][ var2vértices

<td valign=top width=20%>[*][ 1nomcilindro[*][? Pos_04?[*][ a (7)[*][.var2vértices?

Si por algún motivo necesitamos definir un nombre con caracteres ilegales, como un espacio en blanco, una coma, pondremos el nombre entrecomillado. Aquí tenéis un par de ejemplos.[*] [nombre variable = Pepe[*][ objeto.punto, posición = [2,5,1

3d Studio Max tiene un gran número de nombres que contienen espacios. Podremos utilizar el carácter underscore _ en lugar del espacio. De esta forma nos ahorramos poner un montón de comillas. Las dos instrucciones que se muestran a continuación serán equivalentes:[*] [$cajamesa01.modifiers[#fd 4x4x[*][ $cajamesa01.modifiers[#fd_4x4x

Además, se ha de comentar que los nombres en Maxscript no distinguen entre mayúsculas o minúsculas. Los siguientes nombres serían equivalentes:[*] [nombrevariable[*][ nombrevariable

2.3 cadenas (string) y comentarios.

Las cadenas en Maxscript empiezan y terminan con el símbolo de doble comilla. Estos serían algunos ejemplos de cadenas:[*] hola[*] esto es una cadena

Anteriormente se ha comentado que 3d Studio Max no distingue entre mayúsculas y minúsculas. Esto es cierto salvo en una excepción. La comparación entre dos cadenas sí que hace esta distinción. Como podemos observar en la siguiente figura, no será lo mismo una palabra escrita en minúsculas que la misma palabra en mayúsculas:
-16.jpg

En el ejemplo anterior, el oyente de Maxscript compara el string hola con hola. Podemos ver que el resultado es [false. Esto quiere decir que los dos string son diferentes. (ya que estamos, también podemos observar que el símbolo para hacer comparaciones es [==). En el segundo caso, como los dos string son iguales, el oyente devuelve [true.

Entre las comillas se puede escribir cualquier tipo de caracteres excepto el propio símbolo de comillas dobles. Si se necesita escribir, se habrá de introducir detrás del carácter de escape \. Por ejemplo, para escribir la frase: Antonio me dijo hola el otro día, se tendría que poner de la siguiente forma:[*] Antonio me dijo \hola\ el otro día

Los símbolos que van precedidos del carácter de escape \ son los siguientes:[*] \ : comillas.[*] \\ : carácter \.[*] \n: nueva línea.[*] \r: retorno de carro.[*] \t: tabulación.

Algunas veces necesitaremos introducir comentarios en el código que implementemos. Los comentarios se especificaran mediante dos guiones seguidos. A partir de estos dos guiones –, todo lo que se escriba hasta el final de la línea será considerado como un comentario. Por lo tanto, no podremos introducir ninguna línea de código en la parte derecha de los dos guiones. Ejemplos:[*] – Esto es una línea de comentario.[*] x = x + 1 – A partir de los dos guiones no se representa código

2.4 números.

Maxscript utiliza dos tipos de número:[*] enteros con signo de 32 bits y con complemento de 2 (integer)[*] de coma flotante de precisión sencilla. (float).

Para separar los decimales de los números se utiliza un punto. En los paneles de la versión interactiva de 3d Studio Max en español los decimales van precedidos por una coma en lugar de un punto.

Por ejemplo: cuando creamos una esfera en el panel crear y pulsamos el botón esfera, nos salen algunos parámetros que podemos definir utilizando decimales. Por ejemplo, el radio r.

-17.jpg

En la imagen anterior podemos ver, que en la versión interactiva en español los decimales van precedidos por una coma. En cambio, en la misma versión española, si usamos Maxscript, en lugar de la coma tendremos que introducir un punto.

En la versión inglesa, los decimales en la versión interactiva y en Maxscript van precedidos de un punto. Esto puede generar un poco de confusión y se ha de tener en cuenta.

Ejemplos de números en Maxscript:[*] 10.7[*] 45[*] 7.34[*] 7e-4[*] 45e5

En los dos últimos ejemplos anteriores podemos ver que las potencias de 10 se simbolizan con una e. Para poner 7 * 10-4 (7 por 10 elevado a -4) utilizaremos 7e-4, y para poner 45 * 105 se utilizara 45e5.

Se ha de indicar que los float en Maxscript sólo permiten tener 6 números decimales. A partir del sexto, se redondean. El usuario también ha de saber que si se sobrepasa el rango en los números se producirán errores de desbordamiento imprevisibles.
2.5 expresiones de comparación.

Estas expresiones sirven para comparar diferentes valores de un mismo tipo. Este tipo ha de permitir hacer una comparación. Devuelven como resultado [true si se cumplen las condiciones especificadas o [false en caso contrario. Maxscript tiene las siguientes expresiones booleanas:
Table align=center border=1 width=100%> expresiones booleanas instrucción significado[*][<operando1></operando1> == [<operando2></operando2>[*][<operando1></operando1> .= [<operando2></operando2>[*]<operando1> > <operando2></operando2></operando1>[*]<operando1> < <operando2></operando2></operando1>[*]<operando1> > = <operando2></operando2></operando1>[*]<operando1> < = <operando2></operando2></operando1>[*]operando1 igual a operando2[*]operando1 diferente que operando2[*]operando1 mayor que operando2[*]operando1 menor que operando2[*]operando1 mayor o igual que operando2[*]operando1 menor o igual que operando2

Las expresiones [= = y [.= sirven para todos los tipos de Maxscript. Las restantes sólo sirven para los tipos que aceptan comparaciones.

Por ejemplo:
Table align=center border=1 width=80%> instrucción devuelve ejemplos
/caption> 25 = 33 false, ya que 25 es diferente de 23 true=true true, ya que, cierto es igual a cierto true=false false, ya que, cierto no es igual a falso 25.= 33 true, ya que 25 no es igual a 33 true.= true false, ya que, cierto es igual a cierto, no diferente true.= false true, ya que, cierto es distinto a falso 25 > 33 false, ya que 25 no es mayor que 33 25 < 33 true, ya que 25 es inferior a 33 25 >= 25 true, ya que 25 es igual a 25 25 >= 15 true, ya que 25 es mayor que 15 33 <= 25 false, ya que 33 no es menor o igual que 25
Los operandos pueden ser:[*] expresiones matemáticas.[*] otros operandos (nombres de variables, números, cadenas, etc)[*] una llamada a una función.

La prioridad de las expresiones de comparación es inferior que la de las expresiones matemáticas. Esto quiere decir que en una expresión donde hayan operación matemáticas y de comparación, se ejecutaran primero las operación matemáticas y por último las operación booleanas.
2.6 expresiones lógicas.

Las expresiones lógicas, al igual que las de comparación dan como resultado los valores [true o [false. Se utilizan en expresiones condicionales y combinan en sus operandos expresiones matemáticas y de comparación. Las expresiones lógicas en Maxscript son las siguientes (ordenadas de mayor prioridad a menor prioridad):
Table align=center border=1 width=80%> expresiones lógicas instrucción significado[*]not <operando1></operando1>[*]<operando1> and <operando2></operando2></operando1>[*]<operando1> or <operando2> o</operando2></operando1>[*]negación del operando 1[*]operando1 y operando2[*]operando1 o operando2

Los operandos de las expresiones lógicas han de ser siempre booleanos (devuelven [true o[ false) y pueden ser de los siguientes tipos:[*] operandos (nombres de variables, etc).[*] expresiones de comparación.[*] otras expresiones lógicas.[*] llamadas a funciones.

Como se ha dicho antes, los diferentes operandos de la expresión han de dar como resultado siempre [true o [false, ya que de lo contrario, no se podrá evaluar dicha expresión. Los resultados de las operación con expresiones lógicas son los siguientes:
Instrucción valor devuelto or
False or false false false or true true true or false true true or true true como se puede observar, la expresión lógica [or devuelve [true siempre que uno de los operandos sea true. Únicamente en el caso de que todos los operandos sean [false, devolverá el valor [false.

En el caso de la expresión lógica [and, sólo devolverá el valor [true en el caso de que todos los operandos sean [true. Si por lo menos uno de ellos es [false, devolverá el valor [false.
Instrucción valor devuelto and
False and false false false and true false true and false false true and true true
La expresión lógica [not negara el operando que se encuentre detrás de él. De tal forma que una expresión cierta pasa a ser falsa y al revés.
Not instrucción valor devuelto not false true not true false la prioridad de las expresiones lógicas es inferior a las de comparación y matemáticas. Siempre se ejecutaran en último lugar.

Miniaturas adjuntas
-7.jpg   -8.jpg   -9.jpg   -11.jpg   -12.jpg  

-13.jpg   -10.jpg   -14.jpg   -15.jpg   -16.jpg  

Imágenes adjuntadas
-6.jpg -17.jpg 

Ver más sobre el tema y los comentarios en el foro