java.lang.Object
com.pi4j.crowpi.components.Component
com.pi4j.crowpi.components.internal.HT16K33
com.pi4j.crowpi.components.SevenSegmentComponent
Implementation of the CrowPi seven-segment display using I2C with Pi4J
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumMapping of segments to their respective bit according to the HT16K33.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionMapping of characters to their respective byte representation.protected static final intDefault I2C bus address for the seven-segment display on the CrowPiprotected static final intDefault I2C device address for the seven-segment display on the CrowPi
- 
Constructor SummaryConstructorsConstructorDescriptionSevenSegmentComponent(com.pi4j.context.Context pi4j) Creates a new seven-segment display component with the default bus and device address.SevenSegmentComponent(com.pi4j.context.Context pi4j, int bus, int device) Creates a new seven-segment display component with a custom bus and device address.
- 
Method SummaryModifier and TypeMethodDescriptionprotected static bytefromSegments(SevenSegmentComponent.Segment... segments) Helper method for creating a raw digit value (byte) from 0-n segments.protected com.pi4j.io.i2c.I2CgetI2C()Returns the created I2C instance for the seven-segment displayprotected bytegetRawDigit(int position) Gets the raw digit at the specified position.voidprint(double d) Prints the given double value to the seven-segment display, automatically setting the decimal point if applicable.voidprint(int i) Prints the given integer value to the seven-segment display.voidPrints the first four letters (or less if applicable) of the given string to the display.voidPrints the hours and minutes of the givenLocalTimeinstance to the seven-segment display.voidsetColon(boolean enabled) Enables or disables the colon symbol of the seven-segment display.voidsetDecimalPoint(int position, boolean enabled) Enables or disables the decimal point at the given digit position.voidsetDigit(int position, char c) Sets the digit at the specified position to the given character.voidsetDigit(int position, int i) Sets the digit at the specified position to the given integer.voidsetDigit(int position, SevenSegmentComponent.Segment... segments) Sets the digit at the specified position to match the given segments.protected voidsetRawDigit(int position, byte value) Sets the raw digit at the specified position.Methods inherited from class com.pi4j.crowpi.components.internal.HT16K33clear, refresh, setBlinkRate, setBrightness, setEnabledMethods inherited from class com.pi4j.crowpi.components.Componentsleep, triggerSimpleEvent
- 
Field Details- 
DEFAULT_BUSprotected static final int DEFAULT_BUSDefault I2C bus address for the seven-segment display on the CrowPi- See Also:
 
- 
DEFAULT_DEVICEprotected static final int DEFAULT_DEVICEDefault I2C device address for the seven-segment display on the CrowPi- See Also:
 
- 
CHAR_BITSETSMapping of characters to their respective byte representation. Each byte is a bitset where each bit specifies if a specific segment should be enabled (1) or disabled (0).
 
- 
- 
Constructor Details- 
SevenSegmentComponentpublic SevenSegmentComponent(com.pi4j.context.Context pi4j) Creates a new seven-segment display component with the default bus and device address.- Parameters:
- pi4j- Pi4J context
 
- 
SevenSegmentComponentpublic SevenSegmentComponent(com.pi4j.context.Context pi4j, int bus, int device) Creates a new seven-segment display component with a custom bus and device address.- Parameters:
- pi4j- Pi4J context
- bus- Bus address
- device- Device address
 
 
- 
- 
Method Details- 
printpublic void print(int i) Prints the given integer value to the seven-segment display. This works by converting the integer into a string and passing it toprint(String). Please note that due to the limitations of the display only the first four digits will be displayed. This will clear the buffer and automatically callHT16K33.refresh()afterwards to immediately display the number.- Parameters:
- i- Integer to display
 
- 
printpublic void print(double d) Prints the given double value to the seven-segment display, automatically setting the decimal point if applicable. This works by converting the double into a string and passing it toprint(String). Please note that due to the limitations of the display only the first four digits will be displayed. This will clear the buffer and automatically callHT16K33.refresh()afterwards to immediately display the number.- Parameters:
- d- Double to display
 
- 
printPrints the hours and minutes of the givenLocalTimeinstance to the seven-segment display. The time will be displayed in 24 hours format as HH:MM with the colon being active for every odd second. This will clear the buffer and automatically callHT16K33.refresh()afterwards to immediately display the time.- Parameters:
- time- Time to display
 
- 
printPrints the first four letters (or less if applicable) of the given string to the display. Additional letters are ignored. Adding a dot after a digit or putting a colon after two digits causes the respective symbols to be displayed too. This will clear the buffer and automatically callHT16K33.refresh()afterwards to immediately display the text.Example: "1.2:34." will print the string "1234" to the display, with decimal point #1 and #4 as well as the colon symbol being set - Parameters:
- s- String which should be printed
 
- 
setColonpublic void setColon(boolean enabled) Enables or disables the colon symbol of the seven-segment display. This will only affect the internal buffer and does not get displayed untilHT16K33.refresh()gets called.- Parameters:
- enabled- Specify if colon should be enabled or disabled.
 
- 
setDecimalPointpublic void setDecimalPoint(int position, boolean enabled) Enables or disables the decimal point at the given digit position. Please note that the decimal point is just an additional belonging to the same digit. This means that overriding the specific digit (e.g. usingsetRawDigit(int, byte)will reset the decimal point. This will only affect the internal buffer and does not get displayed untilHT16K33.refresh()gets called.- Parameters:
- position- Desired position of digit from 0-3.
- enabled- Specify if decimal point should be enabled or disabled.
 
- 
setDigitpublic void setDigit(int position, int i) Sets the digit at the specified position to the given integer. The integer must not contain more than one number, in other words it has to be in the range 0-9. This will only affect the internal buffer and does not get displayed untilHT16K33.refresh()gets called.- Parameters:
- position- Desired position of digit from 0-3.
- i- Single digit number which should be displayed.
 
- 
setDigitpublic void setDigit(int position, char c) Sets the digit at the specified position to the given character. The character must be representable by the seven-segment display, so only a subset of chars is supported. This will only affect the internal buffer and does not get displayed untilHT16K33.refresh()gets called.- Parameters:
- position- Desired position of digit from 0-3.
- c- Character which should be displayed.
 
- 
setDigitSets the digit at the specified position to match the given segments. This will only affect the internal buffer and does not get displayed untilHT16K33.refresh()gets called.- Parameters:
- position- Desired position of digit from 0-3.
- segments- Segments which should be displayed.
 
- 
setRawDigitprotected void setRawDigit(int position, byte value) Sets the raw digit at the specified position. This method will take a byte value which gets processed by the underlying chip. The byte represents a bitset where each bit belongs to a specific segment and decides if its enabled (1) or disabled (0). Valid values can be crafted using thefromSegments(Segment...)method. This will only affect the internal buffer and does not get displayed untilHT16K33.refresh()gets called.- Parameters:
- position- Desired position of digit from 0-3.
- value- Raw byte value to be displayed.
 
- 
getRawDigitprotected byte getRawDigit(int position) Gets the raw digit at the specified position. This method will return the internal byte value of the underlying chip. The byte represents a bitset where each bit belongs to a specific segment and decides if its enabled (1) or disabled (0).- Parameters:
- position- Desired position of digit from 0-3.
- Returns:
- Raw byte value at specified position.
 
- 
getI2Cprotected com.pi4j.io.i2c.I2C getI2C()Returns the created I2C instance for the seven-segment display- Returns:
- I2C instance
 
- 
fromSegmentsHelper method for creating a raw digit value (byte) from 0-n segments. This can be used together with theSevenSegmentComponent.Segmentenumeration to create and display your own digits. All segments passed to this method will be flagged as active and enabled when passed tosetRawDigit(int, byte)- Parameters:
- segments- Segments which should be enabled to together
- Returns:
- Raw digit value as byte
 
 
-