Elegante Dialoge und BottomSheets zur schnellen Verwendung in deiner App. Wähle bereits existierende Sheets (Blätter) aus oder erstelle dein eigenes auf Basis vorhandener Funktionen.
Ein Sheet (Blatt) kann dynamisch entweder als Dialog oder als BottomSheet dargestellt werden. Probiere das sample aus.
In jedem Fall musst du das core
Modul implementieren, welches das Fundament für alle Arten von Sheets ist.
In deiner übergeordneten build.gradle
Datei:
repositories {
...
mavenCentral()
}
In deiner App build.gradle
Datei:
dependencies {
...
implementation 'com.maxkeppeler.sheets:core:<aktuelle-version>'
}
Basisfunktionen
Folgenden Funktionen können von jeder Art von Sheet aufgerufen werden.
Funktion | Aktion |
---|---|
style() | Stelle das Sheet entweder als Dialog oder BottomSheet dar. |
title() | Setzt den Text für den Titel. |
titleColor() | Setze die Farbe für den Titel. |
titleColorRes() | Setze die Farbe für den Titel mit einer Ressource ID. |
withCoverImage() | Fügt ein Titelbild hinzu. |
topStyle() | Setze den Stil für das Titelbild und der Leiste. |
positiveButtonStyle() | Setze den Stil für den positiven Button (Text, Filled, Outlined). |
negativeButtonStyle() | Setze den Stil für den negativen Button (Text, Filled, Outlined). |
withIconButton() | Füge bis zu 3 Icon-Buttons zur oberen Leiste hinzu. |
closeIconButton() | Setze eine eigenen Schließen-Icon-Button. |
displayHandle() | Stelle einen Griff, typisch für BottomSheets, dar. |
displayCloseButton() | Stelle den Schließen-Button dar. |
displayToolbar() | Stelle die obere Leiste dar. (Schließen-Button, Titel, Teiler und weitere Icon-Buttons. |
peekHeight() | Setze die peek-Höhe. (Nur für BottomSheet) |
cornerRadius() | Setze den Radius für die Ecken. |
cornerFamily() | Setze die Familie für die Ecken. (Cut oder rounded) |
borderWidth() | Setze die Breite für den Rand. |
borderColor() | Setze die Farbe für den Rand. |
cancelableOutside() | Definiere, ob das Sheet abgebrochen werden kann, wenn man außerhalb der Fläche klickt. |
onNegative() | Setze den Text und einen Listener für den negativen Button. |
onPositive() | Setze den Text und einen Listener für den positiven Button. |
onDismiss() | Setze einen Listener, der ausgelöst wird, wenn der Dialog beendet wird. |
onCancel() | Setze einen Listener, der ausgelöst wird, wenn der Dialog abgebrochen wird. |
onClose() | Setze einen Listener, der ausgelöst wird, wenn der Dialog geschlossen wird. |
show() | Stelle das Sheet dar. |
Jedes Sheet hat eine Erweiterungsfunktion namens build
und show
.
Benutze build
um ein Sheet aufzubauen und später darzustellen.
val sheet = InfoSheet().build(context) {
// aufbauen
}
sheet.show() // Später darstellen
Benutze show
um ein Sheet aufzubauen und direkt darzustellen.
InfoSheet().show(context) {
// aufbauen
} // darstellen
Das Info
Sheet ermöglicht es dir, Informationen und Warnungen darzustellen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:info:<aktuelle-version>'
}
Ein einfaches InfoSheet kann folgenderweise erstellt werden:
InfoSheet().show(context) {
title("Der Text für den Titel")
content("Der Text für den Inhalt")
onNegative("Nein") {
// Aktion verarbeiten
}
onPositive("Ja") {
// Aktion verarbeiten
}
}
Funktion | Aktion |
---|---|
content() | Setze den Text für den Inhalt. |
drawable() | Setze ein Symbol links vom Inhalt. |
drawableColor() | Setze die Farbe für das Symbol. |
Das Options
Sheet ermöglicht es dir, eine oder mehrere Optionen auszuwählen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:info:<aktuelle-version>'
}
dependencies {
...
implementation 'com.maxkeppeler.sheets:options:<aktuelle-version>'
}
Ein einfaches OptionsSheet kann folgenderweise erstellt werden:
OptionsSheet().show(context) {
title("Der Text für den Titel")
with(
Option(R.drawable.ic_copy, "Kopieren"),
Option(R.drawable.ic_translate, "Übersetzen"),
Option(R.drawable.ic_paste, "Einfügen")
)
onPositive { index: Int, option: Option ->
// Aktion verarbeiten
}
}
Funktion s | Aktion |
---|---|
multipleChoices() | Erlaube mehrere Auswahlmöglichkeiten. |
displayMultipleChoicesInfo() | Stelle Informationen über die Auswahlmöglichkeiten dar. |
maxChoicesStrictLimit() | Setze, dass die maximale Auswahl strikt ist und temporär nicht mehr ausgewählt werden darf. |
minChoices() | Lege die minimum Anzahl an Möglichkeiten fest. |
maxChoices() | Lege die maximale Anzahl an Möglichkeiten fest. |
onPositiveMultiple() | Setze einen Listener für mehrere Auswahlmöglichkeiten. |
displayButtons() | Stelle die Buttons dar und erzwinge einen Button-Klick um die Auswahl zu bestätigen. |
displayMode() | Stelle die Optionen als Liste oder in einem vertikalen oder horizontalen Gitter dar. |
Option
Funktion | Aktion |
---|---|
selected() | Markiere die Option als ausgewählt. |
disable() | Markie die Option als deaktiviert. |
Wichtig: Vorausgewählte Optionen erhöhen automatisch die aktuelle Auswahl, während deaktivierte Optionen die maximale Auswahl verringern.
Das Clock Time
Sheet ermöglicht es dir, eine Uhrzeit auszuwählen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:time-clock:<aktuelle-version>'
}
Ein ClockTimeSheet kann folgenderweise erstellt werden:
ClockTimeSheet().show(context) {
title("Der Text für den Titel")
onPositive { clockTimeInMillis: Long ->
// Vearbeite Aktion
}
}
Funktion | Aktion |
---|---|
format24Hours() | Benutze entweder das 24-Stunden oder 12-Stunden Format. |
currentTime() | Setze die aktuelle Zeit in Millisekunden. |
Das Time
Sheet ermöglicht es dir, eine Zeit bzw. eine Dauer in einem spezfischen Format auszuwählen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:time:<aktuelle-version>'
}
Ein TimeSheet kann folgenderweise erstellt werden:
TimeSheet().show(context) {
title("Der Text für den Titel")
onPositive { durationTimeInMillis: Long ->
// Verarbeite Aktion
}
}
Funktion | Aktion |
---|---|
format() | Setze das Format. (hh:mm:ss, mm:ss, ...) |
currentTime() | Setze die aktuelle Zeit in Sekunden. |
minTime() | Setze die mindest Zeit. |
maxTime()` | Setze die maximale Zeit. |
Das Input
Sheet ermöglicht es dir, ein Formular mit verschiedenen Eingabemöglichkeiten zu erstellen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:input:<aktuelle-version>'
}
Ein einfaches InputSheet kann folgenderweise erstellt werden:
InputSheet()).show(context) {
title("Umfrage")
content("Wir möchten dir einige Fragen zur Nutzung von Streaming-Plattform stellen.")
with(InputEditText {
required())
label("Deine Lieblingsfernsehshow")
hint("The Mandalorian, ...")
validationListener { value -> } // Füge eigene Validationslogik hinzu
changeListener { value -> } // Eingabe-Weert hat sich geändert
resultListener { value -> } // Eingabe-Wert bei Abschluss des Formulars
})
with(InputCheckBox("binge_watching") { // Lese die Werte entweder durch den Index oder einen Schlüssel aus
label("Binge Watching")
text("Ich schaue mir regelmäßig Shows auf Netflix an.")
// ... mehr Optionen
})
with(InputRadioButtons() {
required()
label("Streaming-Plattform nach deiner Wahl")
options(mutableListOf("Netflix", "Amazon", "Andere"))
})
// ... mehr Optionen
onNegative { showToast("InputSheet abgebrochen", "Kein Ergebnis") }
onPositive { result ->
showToastLong("InputSheet Ergebnis", result.toString())
val text = result.getString("0") // Lese Wert durch Index aus
val check = result.getBoolean("binge_watching") // Lese Wert durch Schlüssel aus
}
}
Funktion | Aktion |
---|---|
with() | Füge Eingabemethoden hinzu. |
content() | Setze den Text für die Beschreibung des Formulars. |
Eingabemöglichkeiten:
InputEditText
InputCheckBox
InputRadioButtons
InputSpinner
Input Basisfunktionen
Funktion | Aktion |
---|---|
label() | Setze den Text für die Überschrift. |
drawable() | Setze ein Symbol. |
required() | Markiere Eingabe als notwendig. |
changeListener() | Setze einen Listener, um über Änderungen informiert zu werden. |
resultListener() | Setze einen Listener, um über den finalen Wert informiert zu werden. |
InputEditText
Funktion | Aktion |
---|---|
hint() | Setze den Text für den Hinweis. |
defaultValue() | Setze den Standardtext. |
inputType() | Setze die android.text.InputType s. |
inputFilter() | Setze den android.text.inputFilter |
maxLines() | Setze die maximale Anzahl an Zeilen. |
endIconMode() | Setze den TextInputLayout.EndIconMode . |
endIconActivated() | Aktiviere den EndIconMode. |
passwordVisible() | Mache das Passwort inital sichtbar. |
validationListener() | Validiere den Text mit eigener Logik. |
InputCheckBox
Funktion | Aktion |
---|---|
text() | Setze den Text. |
defaultValue() | Setze den Standardwert. |
InputRadioButtons
Funktion | Aktion |
---|---|
options() | Setze eine Liste von RadioButton Optionen. |
selected() | Setze den Standard-Index. |
InputSpinner
Funktion | Aktion |
---|---|
noSelectionText() | Setze den Text, welcher dargestellt wird, wenn nichts ausgewählt ist. |
options() | Setze eine Liste von Optionen. |
selected() | Setze den Standard-Index. |
Das Calendar
Sheet ermöglicht es dir, ein Datum oder einen Zeitraum auszuwählen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:calendar:<aktuelle-version>'
}
Ein CalendarSheet kann folgenderweise erstellt werden:
CalendarSheet().show(this) {
title("Wann hast du Geburtstag?")
onPositive { dateStart, dateEnd ->
// Verarbeite ergebnis
}
Funktion | Aktion |
---|---|
selectionMode() | Wähle den Auswahl-Modus aus. (Datum oder Zeitraum). |
calendarMode() | Wähle den Kalendar-Ansichtsmodus aus (1-3 Wochen oder Monatsansicht). |
disableTimeline() | Deaktiviere vergangene oder zukünftige Tage. |
rangeYears() | Setze den möglichen Zeitraum in Jahre in die Vergangenheit und Zukunft. |
disable() | Deaktiviere bestimmte Kalendertage mit einem Calendar Objekt. |
displayButtons() | Stelle Buttons dar. |
Das Color
Sheet ermöglicht es dir, eine Farbe auszuwählen oder zu erstellen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:color:<aktuelle-version>'
}
Ein ColorSheet kann folgenderweise erstellt werden:
ColorSheet().show(context) {
title("Background color")
onPositive { color ->
// Use color
}
}
Funktion | Aktion |
---|---|
defaultView() | Setze die Standard-Ansicht (Farbvorlagen oder Farberstellung). |
disableSwitchColorView() | Deaktiviere das Wechseln zwischen den Ansichten. |
defaultColor() | Setze die Standard-Farbe. |
colors() | Setze alle Farbe für die Farbvorlagen-Ansicht. |
disableAlpha() | Deaktiviere Transparenz bei der Farberstellung. |
Mit dem 'core' Modul kannst du auf Basis dieser Bibliothek dein eigenes Sheet (dialog und BottomSheet) erstellen. Alle Basisfunktionen und Anpassmöglichkeiten sind daher automatisch für deine eigenen Implementationen verfügbar.
dependencies {
...
implementation 'com.maxkeppeler.sheets:core:<aktuelle-version>'
}
Im sample
befindet sich ein ausführliches Beispiel, wie man eigenene Sheets erstellt.
- Schritt: Erstelle eine Klasse und erweitere diese durch die Klasse
Sheet
.
class CustomSheet : Sheet() {
- Schritt: Implementiere die Methode
onCreateLayoutView
und gebe dein eigenes Layout zurück.
override fun onCreateLayoutView(): View {
return LayoutInflater.from(activity).inflate(R.layout.sheet_eigenes, null)
}
Alle Basisfunktionen können verwendet werden. Darüber hinaus kannst du nun dieses Sheet mit einer eigenen Logik und eigenem Verhalten nach deinen Wünschen erweitern.
Du kannst auch die gleichen Kompomenenten verwenden, welche die Bibliothek verwendet.
SheetTitle
SheetContent
SheetDigit
SheetNumericalInput
SheetDivider
SheetButton
SheetEdit
SheetRecyclerView
SheetValue
Das Lottie
Modul ermöglicht es dir, wunderschöne Lottie Animationen im Titelbild darzustellen.
dependencies {
...
implementation 'com.maxkeppeler.sheets:lottie:<aktuelle-version>'
}
Du kannst zu jedem Sheet eine Lottie-Animation hinzufügen:
InfoSheet().show(context) {
title("...")
content("...")
...
withCoverLottieAnimation(LottieAnimation {
setAnimation(R.raw.anim_lottie_business_team)
... Bereite die Animation auf
})
...
}
Funktion | Aktion |
---|---|
playCoverAnimation() | Spiele die Animation ab. |
resumeCoverAnimation() | Abspielen der Animation fortsetzen. |
pauseCoverAnimation() | Pausiere die Animation. |
cancelCoverAnimation() | Breche die Animation ab. |
Standardmäßig wechselt die Bibliothek je nach attr textColorPrimary
entweder in den Tag- oder den Nachtmodus.
Standardmäßig wird das colorPrimary
der Aktivität verwendet. Die Standard-highlightColor
wird basierend auf der Farbe sheetPrimaryColor
oder, falls nicht verfügbar, durch colorPrimary
generiert.
Du möchtest verschiedene Hintergrundformen verwenden? Dann überschreiben Sie einfach die Eckfamilie und den Radius.
<item name="sheetCornerRadius">12dp</item>
<item name="sheetCornerFamily">cut</item>
Überschreiben einfach die Grundfarben, wenn due ein anderes Aussehen erzielen möchten.
<item name="sheetPrimaryColor">@color/customPrimaryColor</item>
<item name="sheetHighlightColor">@color/customHighlightColor</item>
<item name="sheetBackgroundColor">@color/customBackgroundColor</item>
<item name="sheetDividerColor">@color/customDividerColor</item>
<item name="sheetIconsColor">@color/customIconsColor</item>
Du kannst den den Ansichtsstil eines Blattes überschreiben. Anstatt die Symbolleiste anzuzeigen, kannst du sie einfach ausblenden und den typische Griff anzeigen.
<item name="sheetDisplayHandle">true</item>
<item name="sheetDisplayToolbar">false</item>
<item name="sheetDisplayCloseButton">false</item>
Ändere das Erscheinungsbild des Titels.
<item name="sheetTitleColor">@color/customTitleTextColor</item>
<item name="sheetTitleFont">@font/font</item>
<item name="sheetTitleLineHeight">@dimen/dimen</item>
<item name="sheetTitleLetterSpacing">value</item>
Ändere das Erscheinungsbild des Inhaltstextes.
<item name="sheetContentColor">@color/customContentTextColor</item>
<item name="sheetContentInverseColor">@color/customContentTextInverseColor</item>
<item name="sheetContentFont">@font/font</item>
<item name="sheetContentLineHeight">@dimen/dimen</item>
<item name="sheetContentLetterSpacing">value</item>
Ändere das Erscheinungsbild der Wertetexte.
<item name="sheetValueTextActiveColor">@color/customValueTextColor</item>
<item name="sheetValueFont">@font/font</item>
<item name="sheetValueLineHeight">@dimen/dimen</item>
<item name="sheetValueLetterSpacing">value</item>
Ändere das Erscheinungsbild der Zifferntasten.
<item name="sheetDigitColor">@color/customDigitTextColor</item>
<item name="sheetDigitFont">@font/font</item>
<item name="sheetDigitLineHeight">@dimen/dimen</item>
<item name="sheetDigitLetterSpacing">value</item>
Überschreibe Erscheinungsbild des Textes eines Buttons.
<item name="sheetButtonTextFont">@font/font</item>
<item name="sheetButtonTextLetterSpacing">value</item>
Überschreibe das gesamte Erscheinungsbild der Buttons (negativer und positiver Button).
<item name="sheetButtonColor">@color/customButtonColor<item>
<item name="sheetButtonTextFont">@font/font<item>
<item name="sheetButtonTextLetterSpacing">value<item>
<item name="sheetButtonCornerRadius">12dp<item>
<item name="sheetButtonCornerFamily">cut<item>
<item name="sheetButtonWidth">match_content/wrap_content<item>
Überschreibe das Erscheinungsbild des negativen Buttons.
<item name="sheetNegativeButtonType">text_button/outlined_button/button<item>
<item name="sheetNegativeButtonCornerRadius">12dp<item>
<item name="sheetNegativeButtonCornerFamily">cut<item>
Überschreibe das Erscheinungsbild des positiven Buttons.
<item name="sheetPositiveButtonType">text_button/outlined_button/button<item>
<item name="sheetPositiveButtonCornerRadius">12dp<item>
<item name="sheetPositiveButtonCornerFamily">cut<item>
Überschreibe das Erscheinungsbild des Rahmens beim Button mit einem Rand.
<item name="sheetButtonOutlinedButtonBorderColor">@color/borderColor<item>
<item name="sheetButtonOutlinedButtonBorderWidth">1dp<item>
Die Familie und der Radius wird für jeden Button übernommen.
Spezifsche Anpassungen Du kannst sogar die Eckenfamilie und den Radius der negativen und positiven Schaltfläche für jede Ecke definieren.
<item name="sheetNegativeButtonBottomLeftCornerRadius">4dp<item>
<item name="sheetNegativeButtonBottomLeftCornerFamily">cut<item>
...
<item name="sheetPositiveButtonBottomRightCornerRadius">8dp<item>
<item name="sheetPositiveButtonBottomRightCornerFamily">rounded<item>
Die Größe und das Aussehen des Griffs können folgendermaßen geändert werden:
<item name="sheetHandleCornerRadius">8dp</item>
<item name="sheetHandleCornerFamily">rounded</item>
<item name="sheetHandleFillColor">?sheetPrimaryColor</item>
<item name="sheetHandleBorderColor">?sheetPrimaryColor</item>
<item name="sheetHandleBorderWidth">1dp</item>
<item name="sheetHandleWidth">42dp</item>
<item name="sheetHandleHeight">4dp</item>
Überschreibe das Erscheinungsbild von ausgewählten Optionen.
<item name="sheetOptionSelectedImageColor">@color/customSelectedOptionImageColor</item>
<item name="sheetOptionSelectedTextColor">@color/customSelectedOptionTextColor</item>
Überschreibe das Erscheinungsbild von deaktivierten Optionen.
<item name="sheetOptionDisabledImageColor">@color/customDisabledOptionImageColor</item>s
<item name="sheetOptionDisabledTextColor">@color/customDisabledOptionImageColor</item>
<item name="sheetOptionDisabledBackgroundColor">@color/customDisabledOptionBackgColor</item>
Überschreibe das Erscheinungsbild des TextInputLayout (wird für den InputEditText verwendet).
<item name="sheetTextInputLayoutCornerRadius">12dp</item>
<item name="sheetTextInputLayoutBottomLeftCornerRadius">12dp</item>
... and for all other corners
<item name="sheetTextInputLayoutEndIconColor">@color/customEndIconColor</item>
<item name="sheetTextInputLayoutHelperTextColor">@color/customHelperTextColor</item>
<item name="sheetTextInputLayoutBoxStrokeColor">@color/customBoxStrokeColor</item>
<item name="sheetTextInputLayoutHintTextColor">@color/customHintTextColor</item>
<item name="sheetTextInputLayoutBoxStrokeErrorColor">@color/customBoxStrokeErrorColor</item>
<item name="sheetTextInputLayoutErrorTextColor">@color/customErrorTextColor</item>
-
Hinterlasse einen Stern und erzähle anderen davon.
-
Watch für Updates und Verbesserungen.
-
Öffne ein Issue wenn du einen Fehler findest.
-
Zeige deine Dankbarkeit und deine Implementation hier.
Copyright 2020 Maximilian Keppeler https://maxkeppeler.com
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.