Skip to content

Latest commit

 

History

History
915 lines (685 loc) · 34.2 KB

README.de_DE.md

File metadata and controls

915 lines (685 loc) · 34.2 KB

Sheets

Sheets Library

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.

Version of Sheets library Codacy code quality of Sheets library GitHub Give this library a star Fork this library Watch this library Follow me on GitHub Share this library on Twitter Follow Maximilian Keppeler on Twitter

Lese in English oder 简体中文.

sheets Library

Übersicht

Erste Schritte

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:

Download

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

Info

Download

Das Info Sheet ermöglicht es dir, Informationen und Warnungen darzustellen.



Als Dialog darstellen

Sheets InfoSheet Dialog
Sheets InfoSheet Dialog
Sheets InfoSheet Dialog
Sheets InfoSheet Dialog


Als BottomSheet darstellen

Sheets InfoSheet
Sheets InfoSheet BottomSheet
Sheets InfoSheet BottomSheet
Sheets InfoSheet BottomSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:info:<aktuelle-version>'
}

Verwendung

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.

Options

Download

Das Options Sheet ermöglicht es dir, eine oder mehrere Optionen auszuwählen.



Als Dialog darstellen Sheets OptionsSheet Dialog



Als BottomSheet darstellen Sheets OptionsSheet BottomSheet



Varianten als Dialog darstellen

Sheets OptionsSheet Dialog
Sheets OptionsSheet
Sheets OptionsSheet




Varianten als BottomSheet darstellen

Sheets OptionsSheet BottomSheet
Sheets OptionsSheet
Sheets OptionsSheet

dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:info:<aktuelle-version>'
}
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:options:<aktuelle-version>'
}

Verwendung

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.

Clock Time

Download

Das Clock Time Sheet ermöglicht es dir, eine Uhrzeit auszuwählen.



Als Dialog darstellen Sheets OptionsSheet Dialog



Als BottomSheet darstellen Sheets OptionsSheet BottomSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:time-clock:<aktuelle-version>'
}

Verwendung

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.

Time

Download

Das Time Sheet ermöglicht es dir, eine Zeit bzw. eine Dauer in einem spezfischen Format auszuwählen.



Als Dialog darstellen Sheets TimeSheet Dialog



Als BottomSheet darstellen Sheets TimeSheet BottomSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:time:<aktuelle-version>'
}

Verwendung

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.

Input

Download

Das Input Sheet ermöglicht es dir, ein Formular mit verschiedenen Eingabemöglichkeiten zu erstellen.



Als Dialog darstellen Sheets InputSheet Dialog



Als BottomSheet darstellen Sheets InputSheet BottomSheet



Showcase some variants as Dialogs

Sheets InputSheet Dialog




Showcase some variants as BottomSheets Sheets InputSheet BottomSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:input:<aktuelle-version>'
}

Verwendung

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.InputTypes.
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.

Calendar

Download

Das Calendar Sheet ermöglicht es dir, ein Datum oder einen Zeitraum auszuwählen.



Als Dialog darstellen Sheets CalendarSheet Dialog



Als BottomSheet darstellen Sheets CalendarSheet BottomSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:calendar:<aktuelle-version>'
}

Verwendung

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.

Color

Download

Das Color Sheet ermöglicht es dir, eine Farbe auszuwählen oder zu erstellen.



Als Dialog darstellen

Sheets ColorSheet Dialog
Sheets ColorSheet Dialog




Als BottomSheet darstellen

Sheets ColorSheet BottomSheet
Sheets ColorSheet BottomSheet

dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:color:<aktuelle-version>'
}

Verwendung

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.

Custom

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.



Als Dialog darstellen Sheets Custom Dialog



Als BottomSheet darstellen Sheets Custom BottomSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:core:<aktuelle-version>'
}

Erste Schritte

Im sample befindet sich ein ausführliches Beispiel, wie man eigenene Sheets erstellt.

  1. Schritt: Erstelle eine Klasse und erweitere diese durch die Klasse Sheet.
class CustomSheet : Sheet() {
  1. 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.

Komponenten

Du kannst auch die gleichen Kompomenenten verwenden, welche die Bibliothek verwendet.

  • SheetTitle
  • SheetContent
  • SheetDigit
  • SheetNumericalInput
  • SheetDivider
  • SheetButton
  • SheetEdit
  • SheetRecyclerView
  • SheetValue

Lottie

Download

Das Lottie Modul ermöglicht es dir, wunderschöne Lottie Animationen im Titelbild darzustellen.



Als Dialog darstellen Sheets InfoSheet

Als BottomSheet darstellen

Sheets InfoSheet
dependencies {
  ...
  implementation 'com.maxkeppeler.sheets:lottie:<aktuelle-version>'
}

Verwendung

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.

Aussehen

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.

Basis

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>

Buttons

Ü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>

Griff

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>

OptionsSheet

Ü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>

InputSheet

Ü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>

Sonstiges

Unterstütze das Projekt

  • 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.

Lizenz

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.