Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/androidbroadcast/viewbindingpropertydelegate
Make work with Android View Binding simpler
https://github.com/androidbroadcast/viewbindingpropertydelegate
android kotlin viewbinding
Last synced: 4 days ago
JSON representation
Make work with Android View Binding simpler
- Host: GitHub
- URL: https://github.com/androidbroadcast/viewbindingpropertydelegate
- Owner: androidbroadcast
- License: apache-2.0
- Created: 2020-05-02T19:42:27.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2025-02-13T07:07:10.000Z (8 days ago)
- Last Synced: 2025-02-16T20:04:57.027Z (4 days ago)
- Topics: android, kotlin, viewbinding
- Language: Kotlin
- Homepage: https://proandroiddev.com/make-android-view-binding-great-with-kotlin-b71dd9c87719
- Size: 638 KB
- Stars: 1,456
- Watchers: 18
- Forks: 102
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
Awesome Lists containing this project
README
# ViewBindingPropertyDelegate
Make work with [Android View Binding](https://d.android.com/topic/libraries/view-binding) simpler. The library:
- manages ViewBinding lifecycle and clears the reference to it to prevent memory leaks
- eliminates the need to keep nullable references to Views or ViewBindings
- creates ViewBinding lazilyThe library comes in two variants: with and without reflection. The artifacts are respectively: `vbpd` and `vbpd-reflection`. **Prefer to use the one without reflection for better performance**
## IMPORTANT: Enable ViewBinding before using the library
Each Gradle module in your project where you need to use ViewBinding must be properly configured. Refer to the [official guide](https://d.android.com/topic/libraries/view-binding) on how to do that## Add the library to a project
```kotlin
allprojects {
repositories {
mavenCentral()
}
}dependencies {
// recommended
implementation("dev.androidbroadcast.vbpd:vbpd:2.0.4")
// additional factories that use reflection under hood
implementation("dev.androidbroadcast.vbpd:vbpd-reflection:2.0.4")
}
```## Samples
```kotlin
import javax.swing.text.Viewclass ProfileFragment : Fragment(R.layout.profile) {
// RECOMMENDED
// no reflection API is used under the hood
private val profileBinding: ProfileBinding by viewBinding(ProfileBinding::bind)override fun onViewCreated(view: View) {
super.onViewCreate(view)
with(profileBinding) {
firstName.text = person.name
lastName.text = person.surname
email.text = person.email
}
}override fun onViewDestroyed() {
super.onViewDestroyed()
// profileBinding will be cleared after onViewDestroyed()
}
}
```## Migration from 1.0
You can use 1.X and 2.X in the same project without replacing code
- Replace packages `com.github.kirich1409.viewbindingpropertydelegate` -> `dev.androidbroadcast.vbpd`
- Replace `onViewDestroyed` with moving code to proper lifecycle callback (Fragment.onViewDestroyed(), Activity.onDestroy(), etc.)# License
Copyright 2020-2025 Kirill Rozov
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 athttp://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.