Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mahozad/comshot

Capture screenshot of Composables and Views (multiplatform)
https://github.com/mahozad/comshot

android capture-screenshots compose-multiplatform jetpack jetpack-compose kotlin kotlin-multiplatform kotlin-multiplatform-library kotlin-multiplatform-sample screenshot screenshot-utility

Last synced: about 1 month ago
JSON representation

Capture screenshot of Composables and Views (multiplatform)

Awesome Lists containing this project

README

        

[![Kotlin version]][Kotlin release]
[![Compose Multiplatform version]][Compose Multiplatform release]
[![Latest Maven Central release]][Library on Maven Central]




# Comshot
Multiplatform library to take/capture screenshot/snapshot/picture/image of @Composables (and also Android Views).

⚠️⚠️ This is very experimental and tested only on Windows and Android. ⚠️⚠️
⚠️⚠️ It may not be suited for use in production code. ⚠️⚠️

## Usage

```kotlin
implementation("ir.mahozad.multiplatform:comshot:0.3.0")
```

- Android (Composable)
You need to pass your activity to `captureToImage`. Also, it should be called from the Main aka UI thread (see its KDoc for more information).
```kotlin
@Composable
fun Activity.MyComposable() {
val activity = this
var screenshot by remember { mutableStateOf(null) }
val composable: @Composable () -> Unit = remember {
@Composable {
Row {
Text(text = "Hello")
Text(text = "Meow!")
}
}
}
// You can also render your composable simply like this:
// composable()
Column {
Button(onClick = { screenshot = captureToImage(activity, composable) }) {
Text(text = "Capture")
}
screenshot?.let {
Image(
bitmap = it,
modifier = Modifier.width(200.dp),
contentDescription = null
)
}
}
}
```
- Android (View)
```kotlin
val view = findViewById(R.id.myTextView)
val screenshot = captureToImage(view)
// If you want Bitmap:
val androidBitmap = screenshot.asAndroidBitmap()
```
- Other targets
```kotlin
@Composable
fun MyComposable() {
var screenshot by remember { mutableStateOf(null) }
val composable: @Composable () -> Unit = remember {
@Composable {
Row {
Text(text = "Hello")
Text(text = "Meow!")
}
}
}
// You can also render your composable simply like this:
// composable()
Column {
Button(onClick = { screenshot = captureToImage(composable) }) {
Text(text = "Capture")
}
screenshot?.let {
Image(
bitmap = it,
modifier = Modifier.width(200.dp),
contentDescription = null
)
}
}
}
```

## Related
- Capturable : https://github.com/PatilShreyas/Capturable
- Compose ScreenshotBox: https://github.com/SmartToolFactory/Compose-Screenshot
- Generate bitmap from composable: https://github.com/JohannRosenberg/bitmap-from-composable
- Generate JPEG from composable: https://github.com/Vipul12Thawre/JetCapture
- https://developer.android.com/studio/preview/compose-screenshot-testing
- https://developer.android.com/reference/androidx/test/espresso/screenshot/ViewInteractionCapture

[Kotlin version]: https://img.shields.io/badge/Kotlin-2.0.0-303030.svg?labelColor=303030&logo=
[Compose Multiplatform version]: https://img.shields.io/badge/Compose_Multiplatform-1.6.11-303030.svg?labelColor=303030&logo=
[Latest Maven Central release]: https://img.shields.io/maven-central/v/ir.mahozad.multiplatform/comshot?label=Maven%20Central&labelColor=303030&logo=
[Kotlin release]: https://github.com/JetBrains/kotlin/releases/tag/v2.0.0
[Compose Multiplatform release]: https://github.com/JetBrains/compose-multiplatform/releases/tag/v1.6.11
[Library on Maven Central]: https://repo1.maven.org/maven2/ir/mahozad/multiplatform/comshot/0.3.0/