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

Update pixel_order default description #168

Merged
merged 2 commits into from
Jan 2, 2025

Conversation

mattcocca
Copy link
Contributor

This PR just changes the documentation to describe how the "default" value of pixel_order changes based on the value of bpp.

Explanation

I was recently going through the Circuit Playground Express Neopixel example with someone and was trying to explain the use of default arguments. Unfortunately the way the Neopixel class is implemented is a bit confusing for this topic.

The docs currently explain that the default value for "pixel_order" is "GRBW" (even though the "class" line shows that the actual default value is None). I was attempting to show that initialization is functionally the same whether you provide the "Default" value or not. However if you provide "GRBW" as the "Default" for a board with bpp set to 3, the code does not function properly anymore. This is because the "true" default value is None as specified in the "class" line, and logic in the library is being used to set the "default" value based on the value of bpp.

Changing the docs is the least intrusive way to make the behavior clearer.

Possible alternative changes

  1. I would be happy to submit a separate PR removing the bpp argument entirely, because it is effectively superseded by the pixel_order argument (Ideally you shouldn't be able to specify a 4 byte pixel order, but only 3 bytes per pixel and vice-versa), but I understand the desire to keep the code backwards compatible (as discussed in #1) and it's been 6 years since then, so backwards compatibility is only a stronger argument now).

  2. Alternatively the code could be changed to enforce that the byte lengths match. Example: if bpp=3 and pixel_order="GRBW" were provided, the init would use "GRB" as the pixel order. Then the default value for pixel_order could be changed to truly be "RGBW". This would also break backwards compatibility, but only in cases where users are specifying mismatching bpp and pixel_order values. But due to the current default value for bpp there are likely many cases where people are specifying pixel_order and not providing a value for bpp, relying on pixel_order to completely override the bpp value (as a result technically specifying mismatching bytes). I think it would be relatively unintrusive to make this change compared to removing bpp but it's probably about just as confusing as the way it is now.

Copy link
Member

@tannewt tannewt left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good. Thanks!

@tannewt tannewt merged commit 23574db into adafruit:main Jan 2, 2025
1 check passed
adafruit-adabot added a commit to adafruit/Adafruit_CircuitPython_Bundle that referenced this pull request Jan 8, 2025
Updating https://github.com/adafruit/Adafruit_CircuitPython_LPS2X to 3.0.9 from 3.0.8:
  > Merge pull request adafruit/Adafruit_CircuitPython_LPS2X#17 from jposada202020/adding_displayio_example
  > Merge pull request adafruit/Adafruit_CircuitPython_LPS2X#18 from ncguk/patch-1

Updating https://github.com/adafruit/Adafruit_CircuitPython_NeoPixel to 6.3.13 from 6.3.12:
  > Merge pull request adafruit/Adafruit_CircuitPython_NeoPixel#168 from mattcocca/pixel_order_docs_update

Updating https://github.com/adafruit/Adafruit_CircuitPython_PCF8574 to 1.0.11 from 1.0.10:
  > Merge pull request adafruit/Adafruit_CircuitPython_PCF8574#9 from FoamyGuy/read_pin_return_bool

Updating https://github.com/adafruit/Adafruit_CircuitPython_WS2801 to 1.0.0 from 0.10.19:
  > Merge pull request adafruit/Adafruit_CircuitPython_WS2801#25 from FoamyGuy/use_pixelbuf
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants