Skip to content

Commit

Permalink
docs: Improve descriptions for microphone module.
Browse files Browse the repository at this point in the history
  • Loading branch information
microbit-carlos committed Apr 5, 2024
1 parent acee09a commit d805b37
Showing 1 changed file with 36 additions and 23 deletions.
59 changes: 36 additions & 23 deletions docs/microphone.rst
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ which is lit when the microphone is in use.
Sound events
============
The microphone can respond to a pre-defined set of sound events that are
based on the amplitude and wavelength of the sound.
based on the amplitude and wavelength of the sound.

These sound events are represented by instances of the ``SoundEvent`` class,
accessible via variables in ``microbit.SoundEvent``:
Expand All @@ -33,42 +33,55 @@ Functions

.. py:function:: current_event()
* **return**: the name of the last recorded sound event,
``SoundEvent('loud')`` or ``SoundEvent('quiet')``.
Get the last recorded sound event

:return: The event, ``SoundEvent('loud')`` or ``SoundEvent('quiet')``.

.. py:function:: was_event(event)
* **event**: a sound event, such as ``SoundEvent.LOUD`` or
``SoundEvent.QUIET``.
* **return**: ``true`` if sound was heard at least once since the last
call, otherwise ``false``. ``was_event()`` also clears the sound
event history before returning.
Check if a sound was heard at least once since the last call.

This call clears the sound history before returning.

:param event: The event to check for, such as ``SoundEvent.LOUD`` or
``SoundEvent.QUIET``
:return: ``True`` if sound was heard at least once since the last call,
otherwise ``False``.

.. py:function:: is_event(event)
* **event**: a sound event, such as ``SoundEvent.LOUD`` or
``SoundEvent.QUIET``.
* **return**: ``true`` if sound event is the most recent since the last
call, otherwise ``false``. It does not clear the sound event history.
Check the most recent sound event detected.

This call does not clear the sound event history.

:param event: The event to check for, such as ``SoundEvent.LOUD`` or
``SoundEvent.QUIET``
:return: ``True`` if sound was the most recent heard, ``False`` otherwise.

.. py:function:: get_events()
* **return**: a tuple of the event history. The most recent is listed last.
``get_events()`` also clears the sound event history before returning.
Get the sound event history as a tuple.

This call clears the sound history before returning.

:return: A tuple of the event history with the most recent event last.

.. py:function:: set_threshold(event, value)
* **event**: a sound event, such as ``SoundEvent.LOUD`` or
``SoundEvent.QUIET``.

* **value**: The threshold level in the range 0-255. For example,
``set_threshold(SoundEvent.LOUD, 250)`` will only trigger if the sound is
very loud (>= 250).
Set the threshold for a sound event.

A high threshold means the event will only trigger if the sound is
very loud (>= 250 in the example).

:param event: A sound event, such as ``SoundEvent.LOUD`` or
``SoundEvent.QUIET``.
:param value: The threshold level in the range 0-255.

.. py:function:: sound_level()
* **return**: a representation of the sound pressure level in the range 0 to
255.
Get the sound pressure level.

:return: A representation of the sound pressure level in the range 0 to 255.


Example
Expand All @@ -80,7 +93,7 @@ An example that runs through some of the functions of the microphone API::
# Button A is pressed and a loud or quiet sound *is* heard, printing the
# results. On Button B this test should update the display when a loud or
# quiet sound *was* heard, printing the results. On shake this should print
# the last sounds heard, you should try this test whilst making a loud sound
# the last sounds heard, you should try this test whilst making a loud sound
# and a quiet one before you shake.

from microbit import *
Expand Down

0 comments on commit d805b37

Please sign in to comment.