Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

DOCS-2481: Add motor how to #3036

Merged
Binary file not shown.
Binary file added assets/get-started/quickstarts/motor-control.mp4
Binary file not shown.
19 changes: 18 additions & 1 deletion assets/scss/_styles_project.scss
Original file line number Diff line number Diff line change
Expand Up @@ -437,6 +437,7 @@ END MARKETING CSS
border-bottom: black solid 1px;
background: whitesmoke;
padding: 1rem;
overflow: hidden;
}

.expand {
Expand Down Expand Up @@ -1807,4 +1808,20 @@ div .filterable > p {
.usecase-table .tablestep:nth-of-type(even) {
background-color: white;
border-top: 1px solid #dee2e6;
}
}

// Expander styling

details * i.fa-chevron-down {
display: none;
}
details * i.fa-chevron-right {
display: unset;
}

details[open] * i.fa-chevron-down {
display: unset;
}
details[open] * i.fa-chevron-right {
display: none;
}
2 changes: 1 addition & 1 deletion docs/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ outputs:
</a>
</div>
<div class="col hover-card link-with-icon">
<a href="use-cases/capture-sensor-data/" class="noanchor"><div>
<a href="use-cases/collect-sensor-data/" class="noanchor"><div>
<picture><img src="icons/data-analytics.svg" alt="Data Analytics" loading="lazy"></picture>
<p>Capture and sync sensor data</p></div>
</a>
Expand Down
1 change: 1 addition & 0 deletions docs/get-started/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ Learn about the Viam platform by reading our Viam in 3 minutes guide or try it o
{{< cards >}}
{{% card link="/get-started/viam/" %}}
{{% card link="/get-started/try-viam/" %}}
{{% card link="/get-started/quickstarts/control-motor/" %}}
{{< /cards >}}

If you're ready to try it on your own machine, start by installing `viam-server`.
Expand Down
8 changes: 8 additions & 0 deletions docs/get-started/quickstarts/_index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
---
linkTitle: "Quickstarts"
title: "Quickstarts"
weight: 95
type: "docs"
---

If you're just getting started with Viam, these quickstarts will get you started in less than 5 minutes:
191 changes: 191 additions & 0 deletions docs/get-started/quickstarts/control-motor.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,191 @@
---
title: "Control a motor in 2 minutes"
linkTitle: "Control a motor in 2 minutes"
type: "docs"
weight: 30
cost: 75
images: ["/icons/components/motor.svg"]
description: "Use Viam to control a motor's speed and direction in just a few steps."
---

You can use Viam to control a motor's speed and direction directly from [the Viam app](https://app.viam.com/), [the mobile app](/fleet/#the-viam-mobile-app), or [programatically](https://docs.viam.com/build/program/).

### Requirements

- A board with a supported OS installed (such as Raspberry Pi)
- A motor connected to the board
- A motor driver (optional)

Follow these steps to control your motor:

{{< expand "Step 1: Create a machine" >}}

Go to the Viam app and [add a new machine](/cloud/machines/#add-a-new-machine).

![The 'First Location' page on the Viam app with a new machine name in the New machine field and the Add machine button next to the field highlighted.](/fleet/app-usage/create-machine.png)

{{< /expand >}}

{{< expand "Step 2: Configure a Board" >}}

Then, [add a board component](/components/board/), such as a [Raspberry Pi board](/components/board/pi/).

![An example board configuration in the app builder UI. The name (local), type (board) and model (pi) are shown. No other attributes are configured.](/components/board/pi-ui-config.png)

{{< /expand >}}

{{< expand "Step 3: Configure a motor" >}}

[Add a motor component](/components/motor/), such as a [gpio motor](/components/motor/gpio/).
Ensure your motor, motor driver, and board are properly connected.

![The CONFIGURE tab of the Viam app populated with a configured gpio motor.](/components/motor/gpio-config-ui.png)

{{< /expand >}}

{{< expand "Step 4: Choose how you will control the motor" >}}

You can control your motor directly from the Viam app, using the mobile app, or programatically.

1. Control from the app

Navigate to your machine's **CONTROL** tab in the Viam app and use the **Power %** slider to set the motors speed.
Use the **Backwards** and **Forwards** buttons to change the direction.

{{<gif webm_src="/get-started/quickstarts/motor-control.webm" mp4_src="/get-started/quickstarts/motor-control.mp4" alt="Using the slider, Backwards, and Forwards buttons on the Viam app to control the direction and speed of a configured motor" class="aligncenter" min-height="750px">}}

2. Control from the mobile app

You can use [the Viam mobile app](/fleet/#the-viam-mobile-app) to control your motor's speed and direction directly from your smart device.

Open the Viam mobile app and log in to your account.
Select the location where your machine is assigned.
Choose your machine from the list and use the mobile interface to adjust the motor settings.

Select the location that your machine is assigned to from the **Locations** tab.

{{<gif webm_src="/get-started/quickstarts/mobile-app-motor-control.webm" mp4_src="/get-started/quickstarts/mobile-app-motor-control.mp4" alt="Using an example machine on the Viam mobile app to set the direction and speed of a configured motor using the slider on the user interface" max-height="50px" max-width="200px" class="HELLO aligncenter">}}

3. Control programatically

You can use the following code to control the motor's speed and direction using your preferred SDK:

{{< tabs >}}
{{% tab name="Python" %}}

```python
import asyncio

from viam.robot.client import RobotClient
from viam.rpc.dial import Credentials, DialOptions
from viam.components.motor import Motor


async def connect():
opts = RobotClient.Options.with_api_key(
# Replace "<API-KEY>" (including brackets) with your machine's api key
api_key='<API-KEY>',
# Replace "<API-KEY-ID>" (including brackets) with your machine's api
# key id
api_key_id='<API-KEY-ID>'
)
return await RobotClient.at_address(
'my-machine-main.1ye34y6p21.viam.cloud', opts)


async def main():
machine = await connect()

print('Resources:')
print(machine.resource_names)

# motor-1
motor_1 = Motor.from_robot(machine, "motor-1")
# Turn the motor 7.2 revolutions at 60 RPM.
await motor_1.go_for(rpm=60, revolutions=7.2)
print(f"motor-1 is_moving return value: {motor_1_return_value}")

# Don't forget to close the machine when you're done!
await machine.close()


if __name__ == '__main__':
asyncio.run(main())
```

{{% /tab %}}
{{% tab name="Go" %}}

```go
package main

import (
"context"

"go.viam.com/rdk/logging"
"go.viam.com/rdk/robot/client"
"go.viam.com/utils/rpc"
"go.viam.com/rdk/components/motor")

func main() {
logger := logging.NewDebugLogger("client")
machine, err := client.New(
context.Background(),
"my-machine-main.1ye34y6p21.viam.cloud",
logger,
client.WithDialOptions(rpc.WithEntityCredentials(
/* Replace "<API-KEY-ID>" (including brackets) with your machine's api key id */
"<API-KEY-ID>",
rpc.Credentials{
Type: rpc.CredentialsTypeAPIKey,
/* Replace "<API-KEY>" (including brackets) with your machine's api key */
Payload: "<API-KEY>",
})),
)
if err != nil {
logger.Fatal(err)
}

defer machine.Close(context.Background())
logger.Info("Resources:")
logger.Info(machine.ResourceNames())


// motor-1
motor1Component, err:= motor.FromRobot(machine, "motor-1")
if err!=nil {
logger.Error(err)
return
}
// Turn the motor 7.2 revolutions at 60 RPM.
motor1Component.GoFor(context.Background(), 60, 7.2, nil)
if err!=nil {
logger.Error(err)
return
}
logger.Infof("motor-1 IsMoving return value: %+v", motor1ReturnValue)
}
```

{{% /tab %}}
{{< /tabs >}}

{{< /expand >}}

## Next steps

Now that you have made a motor move, explore other components, or related servies:

{{< cards >}}
{{% card link="/components/" %}}
{{% card link="/services/navigation/" %}}
{{% card link="/services/SLAM/" %}}
{{< /cards >}}

To see motors in real-world projects, check out these tutorials:

{{< cards >}}
{{% card link="/tutorials/get-started/confetti-bot/" %}}
{{% card link="/tutorials/get-started/lazy-susan/" %}}
{{% card link="/tutorials/configure/configure-rover/" %}}
{{< /cards >}}
27 changes: 13 additions & 14 deletions layouts/shortcodes/expand.html
Original file line number Diff line number Diff line change
@@ -1,17 +1,16 @@
{{ $_hugo_config := `{ "version": 1 }` }}
<div class="expand">
<div class="expand-label" style="cursor: pointer;" onclick="$h = $(this);$h.next('div').slideToggle(100,function () {$h.children('i').attr('class',function () {return $h.next('div').is(':visible') ? 'fas fa-chevron-down' : 'fas fa-chevron-right';});});">
<details class="expand">
<summary class="expand-label" style="display: block;">
<i style="font-size:x-small;" class="fas fa-chevron-right"></i>
<span>
{{$expandMessage := "Click to expand"}}
<i style="font-size:x-small;" class="fas fa-chevron-down"></i>
<span>
{{- if .IsNamedParams -}}
{{.Get "default" | default $expandMessage}}
{{- else -}}
{{.Get 0 | default $expandMessage}}
{{- end -}}
</span>
{{.Get "default" | default "Click to expand"}}
{{- else -}}
{{.Get 0 | default "Click to expand"}}
{{- end -}}
</span>
</summary>
<div class="expand-content">
{{.Inner | markdownify}}
</div>
<div class="expand-content" style="display: none;">
{{.Inner | safeHTML}}
</div>
</div>
</details>
Binary file not shown.
Binary file not shown.
Loading