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 de VEX VR.
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ó
[Drive forward 400 mm.]
[drivetrain.drive_for(FORWARD, 400, MM)] :: 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:
ifwhilefor
cuando empezó
[Continuously drive until the bumper is pressed.]
unidad [adelante v]
para siempre
if [if bumper.pressed():] :: custom-switch
imprimir [Bumper was pressed!] ▶
deja de conducir
fin
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:
ifelifelsewhilefor
cuando empezó
[Continuously move forward until the bumper is pressed.]
para siempre
if [if bumper.pressed():] :: custom-switch-expand
imprimir [Bumper was pressed!] ▶
deja de conducir
else [else:] :: custom-switch-expand
unidad [adelante v]
fin
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.pressed()] :: custom-switch>
Un bloque booleano también puede utilizar operadores lógicos:
andornot
<[bumper.pressed() or distance.found_object()] :: 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.heading()> 100] :: custom-switch>
cuando empezó
[Turn right until the Distance Sensor finds an object.]
turno [derecha v]
para siempre
si <[distance.found_object()] :: custom-switch> entonces
imprimir [Object found!] ▶
deja de conducir
fin
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.
([drivetrain.heading()] :: custom-switch)
Los operadores matemáticos se pueden utilizar en un bloque Reportero:
Addition:
+Subtraction:
-Division:
/Multiplication:
*
([drivetrain.heading() + 45] :: custom-switch)
cuando empezó
[Print the robot's heading plus 45 degrees.]
imprimir ([drivetrain.heading() + 45] :: custom-switch) ▶
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 drive_400():] :: hat custom-switch
[Define a custom function using a Hat block.]
unidad [adelante v] para (400) [mm v] ▶
cuando empezó
[drive_400()] :: custom-switch