Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/takusemba/spotlight
Android Library that lights items for tutorials or walk-throughs etc...
https://github.com/takusemba/spotlight
android android-app android-library android-ui java spotlight ui ux
Last synced: 5 days ago
JSON representation
Android Library that lights items for tutorials or walk-throughs etc...
- Host: GitHub
- URL: https://github.com/takusemba/spotlight
- Owner: TakuSemba
- License: apache-2.0
- Created: 2017-07-02T06:42:18.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-12-03T07:25:18.000Z (about 2 years ago)
- Last Synced: 2025-01-17T00:00:08.805Z (5 days ago)
- Topics: android, android-app, android-library, android-ui, java, spotlight, ui, ux
- Language: Kotlin
- Size: 1.93 MB
- Stars: 3,635
- Watchers: 46
- Forks: 364
- Open Issues: 30
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Spotlight
![Build Status](https://app.bitrise.io/app/bcf0d555e7b41eb2/status.svg?token=2wvl_JilEbg6HB3B1tfKpA&branch=master)
![Download](https://api.bintray.com/packages/takusemba/maven/spotlight/images/download.svg)
![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)
![API](https://img.shields.io/badge/API-14%2B-brightgreen.svg?style=flat)## Gradle
```groovy
dependencies {
implementation 'com.github.takusemba:spotlight:x.x.x'
}
```## Usage
```kt
val spotlight = Spotlight.Builder(this)
.setTargets(firstTarget, secondTarget, thirdTarget ...)
.setBackgroundColor(R.color.spotlightBackground)
.setDuration(1000L)
.setAnimation(DecelerateInterpolator(2f))
.setContainer(viewGroup)
.setOnSpotlightListener(object : OnSpotlightListener {
override fun onStarted() {
Toast.makeText(this@MainActivity, "spotlight is started", Toast.LENGTH_SHORT).show()
}
override fun onEnded() {
Toast.makeText(this@MainActivity, "spotlight is ended", Toast.LENGTH_SHORT).show()
}
})
.build()
```If you want to show Spotlight immediately, you have to wait until views are laid out.
```kt
// with core-ktx method.
view.doOnPreDraw { Spotlight.Builder(this)...start() }
```
## Target
Create a Target to add Spotlight.Target is a spot to be casted by Spotlight. You can add multiple targets to Spotlight.
```kt
val target = Target.Builder()
.setAnchor(100f, 100f)
.setShape(Circle(100f))
.setEffect(RippleEffect(100f, 200f, argb(30, 124, 255, 90)))
.setOverlay(layout)
.setOnTargetListener(object : OnTargetListener {
override fun onStarted() {
makeText(this@MainActivity, "first target is started", LENGTH_SHORT).show()
}
override fun onEnded() {
makeText(this@MainActivity, "first target is ended", LENGTH_SHORT).show()
}
})
.build()
```
## Start/Finish Spotlight
```kt
val spotlight = Spotlight.Builder(this)...start()spotlight.finish()
```## Next/Previous/Show Target
```kt
val spotlight = Spotlight.Builder(this)...start()spotlight.next()
spotlight.previous()
spotlight.show(2)
```## Custom Shape
`Shape` defines how your target will look like.
[Circle](https://github.com/TakuSemba/Spotlight/blob/master/spotlight/src/main/java/com/takusemba/spotlight/shape/Circle.kt) and [RoundedRectangle](https://github.com/TakuSemba/Spotlight/blob/master/spotlight/src/main/java/com/takusemba/spotlight/shape/RoundedRectangle.kt) shapes are already implemented, but if you want your custom shape, it's arhivable by implementing `Shape` interface.```kt
class CustomShape(
override val duration: Long,
override val interpolator: TimeInterpolator
) : Shape {override fun draw(canvas: Canvas, point: PointF, value: Float, paint: Paint) {
// draw your shape here.
}
}
```## Custom Effect
`Effect` allows you to decorates your target.
[RippleEffect](https://github.com/TakuSemba/Spotlight/blob/master/spotlight/src/main/java/com/takusemba/spotlight/effet/RippleEffect.kt) and [FlickerEffect](https://github.com/TakuSemba/Spotlight/blob/master/spotlight/src/main/java/com/takusemba/spotlight/effet/FlickerEffect.kt) shapes are already implemented, but if you want your custom effect, it's arhivable by implementing `Effect` interface.```kt
class CustomEffect(
override val duration: Long,
override val interpolator: TimeInterpolator,
override val repeatMode: Int
) : Effect {override fun draw(canvas: Canvas, point: PointF, value: Float, paint: Paint) {
// draw your effect here.
}
}
```## Sample
Clone this repo and check out the [app](https://github.com/TakuSemba/Spotlight/tree/master/app) module.## Author
* **Taku Semba**
* **Github** - (https://github.com/takusemba)
* **Twitter** - (https://twitter.com/takusemba)
* **Facebook** - (https://www.facebook.com/takusemba)## Licence
```
Copyright 2017 Taku Semba.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.
```