CircuitPython 5.0.0 Alpha 1 Released! — @adafruit @CircuitPython

This is an Alpha Release

This is alpha release number 1 of CircuitPython 5.0.0. Alpha releases are meant for testing. Download this release from circuitpython.org. Use the latest stable 4.x release when first starting with CircuitPython.

When you find a bug please check the current known issues and file an issue if something isn’t already known.

5.0.0

5.0.0 is the latest major revision of CircuitPython. It features many improvements and enhancements to displayio, including grayscale and e-paper displays, extensive additions and changes to BLE support, and PWM audio support.

Installation

To install follow the instructions in our new Welcome to CircuitPython! guide. To install the latest libraries, see this page in that guide.

Try the latest version of the Mu editor for creating and editing your CircuitPython programs and for easy access to the CircuitPython serial connection (the REPL).

Most builds are available as both UF2 and bin files here along with test builds.

New Features, Updates, and Fixes since 4.1.0

  • displayio has been extensively improved and extended. Thanks @tannewt. Other contributors also noted.
    • Add support for monochrome and grayscale displays.
    • Add support for many kinds of e-paper/e-ink displays
    • Add support for I2C displays such as OLED displays.
    • The displayio refresh API has been revamped to be simpler. This is an incompatible change.
    • Clean up display when terminal starts starts. Thanks @brentru.
    • Add fill_row() and add rotation property. Thanks @dastels.
  • BLE support has had extensive additions and changes. Thanks @dhalbert.
    • Add Central support: scan for advertisements and act as a service client. (Central and Scanner).
    • A Peripheral can now discover services provided by a central, and act as a BLE client in addition to being a server.
    • Descriptors can now be discovered and specified.
    • Attribute data lengths can now be specified.
    • Add security support, including legacy pairing and encryption, and attribute security. Bonding implementation is in progress.
    • The default CIRCUITPY device name is now CIRCUITPYxxxx, where xxxx is the last four hex digits of the address, allowing multiple devices to be distinguished.
    • The bleio module has been renamed to _bleio to indicate that it is meant to be used only for writing BLE libraries, and that its API may change between CircuitPython minor versions. There are many incompatible changes since 4.0.0. The _bleio API is a work in progress and will change as 5.0.0 progresses. Please use the latest pre-release adafruit_ble library for end-user BLE programming. The adafruit_ble library is evolving too but will hide underlying changes in _bleio.
  • Audio changes and fixes:
    • Add PWMAudioOut to provide audio output on nRF boards. Thanks @jepler.
    • Fix Audio DMA hangs. Thanks @jepler.
    • Move Mixer, RawSample, and WaveFile to the new module audiocore. However, for backwards compatibility, they are still available in audioio. They will be removed from audioio in 6.0.0. Thanks @jepler.
    • Allow using a pre-allocated buffer in WaveFile. Thanks @deshipu.
  • The generic touchio support implemented for nRF is now available for all boards without specialized touch support, notably SAMD51 boards. Thanks @nickzoic and @dhalbert.
  • Add I2C.writeto_then_readfrom(). Deprecate stop= arg. Thanks @tannewt. All applicable libraries were updated to take advantage of this change. Thanks @kattni, @caternuson, and @jerryneedell for testing all these changes on hardware.
  • Fix a bug on nRF boards without 32Khz crystals. Thanks @bmeisels and @dhalbert.
  • Fix a pin validation bug in rotaryio. Thanks @dhalbert.
  • Update to latest version of TinyUSB. Thanks @hathach for continuing improvements and fixes to TinyUSB.
  • Fix potential crashes in time methods. Thanks @jepler.
  • Fix USB hangs while using adafruit_hid. Thanks @jepler.
  • Enable LTO compilation on nRF boards. Thanks @jepler.
  • Build feature enhancements to support minimal build when working on a port. Thanks @hierophect.
  • Add scaling support and fix some bugs to _stage. Thanks @deshipu.
  • Fix nRF timer definitions. Thanks @ntavish.
  • Add on_next_reset() to nRF build. Thanks jepler.
  • Add more Pinyin translations. Thanks @hexthat.
  • Automate support matrix (which boards support which modules) in documentations. Thanks @sommersoft.
  • Make sure new board definitions are being built. Thanks @C47D.
  • Update Arch Linux gcc installation instructions. Thanks @AnthonyDiGirolamo.
  • The continuous integration builds have been moved from Travis to GitHub actions. More simultaneous jobs are available, speeding up the builds considerably. This does not affect the code, but speeds up the PR cycle. Thanks @tannewt.

New and Improved Boards

Breaking Changes from 4.x!

  • See above, especially in displayio, bleio (now _bleio), and audioio.

Known Issues

See https://github.com/adafruit/circuitpython/issues.

Thanks

Thank you to all who used, tested, contributed, helped out, and participated on GitHub and/or Discord:
@clininja, @anecdata, @AnthonyDiGirolamo, @arturo182, @ATMakersBill, @bmeisels, @brentru, @C47D, @caternuson, @CedarGroveStudios, @charlesburnaford, @dastels, @Ddbricetti, @DaveP, @deshipu, @devoh, @dhalbert, @fede2, @hathach, @hexthat, @hierophect, @hybotics, @jasonp, @jepler, @jerryneedell, @Josh, @JP, @kattni, @kevinjwalters, @klardotsh, @ladyada, @madbodger, @MakerMelissa, @matthewnewberg, @MikeB, @MrCertainly, @mytechnotalent, @nickzoic, @ntavish, @ntoll, @oldcrow, @pt, @reply2jh, @rhooper, @s-light, @sajattack, @siddacious, @sommersoft, @TammyMakesThings, @tannewt, @TG-Techie, @wallarug and surely more we have missed. Join us on the Discord chat to collaborate.

Documentation

Documentation is available in readthedocs.io.

Here are all the changes since 4.1.0.

This release is based on MicroPython 1.9.4 @25ae98f. Support upstream MicroPython by purchasing a PyBoard (from Adafruit here).

Troubleshooting

Check out this guide for info on common problems with CircuitPython. If you are still having issues, then post to the Adafruit Support Forums and join Discord.


Adafruit publishes a wide range of writing and video content, including interviews and reporting on the maker market and the wider technology world. Our standards page is intended as a guide to best practices that Adafruit uses, as well as an outline of the ethical standards Adafruit aspires to. While Adafruit is not an independent journalistic institution, Adafruit strives to be a fair, informative, and positive voice within the community – check it out here: adafruit.com/editorialstandards

Join Adafruit on Mastodon

Adafruit is on Mastodon, join in! adafruit.com/mastodon

Stop breadboarding and soldering – start making immediately! Adafruit’s Circuit Playground is jam-packed with LEDs, sensors, buttons, alligator clip pads and more. Build projects with Circuit Playground in a few minutes with the drag-and-drop MakeCode programming site, learn computer science using the CS Discoveries class on code.org, jump into CircuitPython to learn Python and hardware together, TinyGO, or even use the Arduino IDE. Circuit Playground Express is the newest and best Circuit Playground board, with support for CircuitPython, MakeCode, and Arduino. It has a powerful processor, 10 NeoPixels, mini speaker, InfraRed receive and transmit, two buttons, a switch, 14 alligator clip pads, and lots of sensors: capacitive touch, IR proximity, temperature, light, motion and sound. A whole wide world of electronics and coding is waiting for you, and it fits in the palm of your hand.

Have an amazing project to share? The Electronics Show and Tell is every Wednesday at 7:30pm ET! To join, head over to YouTube and check out the show’s live chat and our Discord!

Join us every Wednesday night at 8pm ET for Ask an Engineer!

Join over 38,000+ makers on Adafruit’s Discord channels and be part of the community! http://adafru.it/discord

CircuitPython – The easiest way to program microcontrollers – CircuitPython.org


New Products – Adafruit Industries – Makers, hackers, artists, designers and engineers! — NEW PRODUCT – Half Height / Low Profile MX-Compatible Key Switches – 12 pack – Outemu GTMX

Python for Microcontrollers – Adafruit Daily — Python on Microcontrollers Newsletter: Diving into the Raspberry Pi RP2350, Python Survey Results and more! #CircuitPython #Python #micropython @ThePSF @Raspberry_Pi

EYE on NPI – Adafruit Daily — EYE on NPI Maxim’s Himalaya uSLIC Step-Down Power Module #EyeOnNPI @maximintegrated @digikey

Adafruit IoT Monthly — IoT Vulnerability Disclosure, Decorative Dorm Lights, and more!

Maker Business – Adafruit Daily — A look at Boeing’s supply chain and manufacturing process

Electronics – Adafruit Daily — Function Generator Outputs

Get the only spam-free daily newsletter about wearables, running a "maker business", electronic tips and more! Subscribe at AdafruitDaily.com !



1 Comment

  1. Will displayio use a different amount of memory now? More or less?

Sorry, the comment form is closed at this time.