Cambiar#
Introducción#
Los bloques Switch ayudan a los estudiantes a pasar de la programación basada en bloques a la programación basada en texto. Con los bloques Switch, los estudiantes pueden escribir código Python directamente dentro de un proyecto de bloques (comandos, condiciones, valores o definiciones de funciones) mientras continúan desarrollando el resto del proyecto con bloques. Además, los bloques individuales se pueden convertir en sus comandos Python equivalentes.
Para aprender a escribir comandos, métodos y operadores de Python, consulte la API de Python VEX CTE.
Dado que los bloques Switch contienen código Python, la ortografía, la puntuación y la indentación deben ser correctas para que el proyecto se ejecute como se espera.
A continuación se muestra una lista de todos los bloques Switch:
Bloques Switch: Añade código Python a un proyecto de Blocks.
Pila — Proporciona un espacio para escribir comandos de Python que se ejecutan en secuencia con otros bloques de la pila.
C Block — Provides a space to type Python control code, such as
if,while, orforstatements.C Expandable — Provides a space to type Python control code with multiple branches, such as
if,elif, orelse.Boolean — Provides a space to type Python code that returns
TrueorFalse.Reportero — Proporciona un espacio para escribir código Python que devuelve un valor.
Sombrero — Proporciona un espacio para definir una función de Python.
Pila#
El bloque Stack proporciona un espacio para escribir comandos de Python que se ejecutan en secuencia con otros bloques de la pila.
[] :: custom-switch
Un bloque Stack puede contener una o varias líneas de código Python.
cuando empezó :: hat events
[Move the 6-Axis Arm to a standard position at the start of the project.]
[arm.move_to(120, 120, 75, False)] :: custom-switch
Bloque C#
The C Block provides a space to type Python control code, such as if, while, or for statements. Blocks placed inside the C Block run as part of that Python control structure.
if [] :: custom-switch
fin
El código de control Python que se puede utilizar en un bloque C incluye:
cuando empezó :: hat events
[Check if the 6-Axis Arm can move to a position.]
if [if not arm.can_arm_reach_to(0, 0, 0):] :: custom-switch
imprimir [The 6-Axis Arm can't move to this position.] en la consola ◀ y coloque el cursor en la siguiente fila
fin
C Expandible#
The C Expandable block provides a space to type Python control code with multiple branches, such as if, elif, or else. Additional branches can be added by selecting the plus arrow.
if [] :: custom-switch-expand
fin
El código de control Python que se puede utilizar en un bloque C Expandible incluye:
cuando empezó
[Check if the 6-Axis Arm can or can't move to a position.]
if [if not arm.can_arm_reach_to(0, 0, 0):] :: custom-switch-expand
imprimir [The 6-Axis Arm can't move to this position.] en la consola ◀ y coloque el cursor en la siguiente fila
else [else:] :: custom-switch-expand
imprimir [The 6-Axis Arm can move to this position.] en la consola ◀ y coloque el cursor en la siguiente fila
fin
Booleano#
The Boolean block provides a space to type Python code that returns True or False. It can be placed inside blocks with hexagonal inputs.
<[] :: custom-switch>
Un bloque booleano puede contener una condición de Python.
<[bumper_a.is_pressed()] :: custom-switch>
Un bloque booleano también puede utilizar operadores lógicos:
<[bumper_a.is_pressed() or bumper_b.is_pressed()] :: custom-switch>
Un bloque booleano puede utilizar operadores de comparación para comparar valores:
Greater than:
>Less than:
<Equal to:
==Other comparison operators include
<=,!=, and>=
<[drivetrain.get_heading()> 100] :: custom-switch>
cuando empezó
[Check if the 6-Axis Arm can move to a position.]
si <no <[arm.can_arm_reach_to(0, 0, 0)] :: custom-switch>> entonces
imprimir [The 6-Axis Arm can't move to this position.] en la consola ◀ y coloque el cursor en la siguiente fila
fin
Reportero#
El bloque Reportero proporciona un espacio para escribir código Python que devuelve un valor. Se puede colocar dentro de bloques con entradas circulares.
([] :: custom-switch)
Un bloque Reporter puede contener código Python que devuelve un valor.
([arm.get_y()] :: custom-switch)
Los operadores matemáticos se pueden utilizar en un bloque Reportero:
([arm.get_y() + 45] :: custom-switch)
cuando empezó
[Display the current y-position while the 6-Axis Arm moves.]
mover [brazo v] a la posición x:(-100) y:(200) z:(100) [mm v] ◀ y no esperes
repetir hasta <[brazo v] ya termino de moverme?>
imprimir ([arm.get_y()] :: custom-switch) en la consola ◀ y coloque el cursor en la siguiente fila
esperar [0.25] segundos
fin
Sombrero#
El bloque Hat proporciona un espacio para definir una función de Python. Los bloques que se adjuntan debajo de Hat se convierten en el cuerpo de esa función.
[] :: hat custom-switch
Escriba la definición de una función Python en el bloque Hat. Los parámetros van dentro de los paréntesis. Si la función no usa parámetros, deje los paréntesis vacíos.
[def function_name(parameter):] :: hat custom-switch
[def increment_y_100():] :: hat custom-switch
[Create a function to increment the 6-Axis Arm.]
incrementar la posición [brazo v] en x:[0] y:[100] z:[0] [mm v] ▶
cuando empezó :: hat events
[increment_y_100()] :: custom-switch