An easy-to-use Android library that will help you to take screenshots of specif views of your app and save them to external storage

?? English | ?? Português (pt-br)

?? English:

An easy to use Library that will help you to take screenshots ? of the views in your app

Step 1. Add the JitPack repository to your build file:

Add it in your root build.gradle at the end of repositories:

	allprojects {
		repositories {
			...
			maven { url 'https://jitpack.io' }
		}
	}

Step 2. Add the dependency

	dependencies {
	        implementation 'com.github.T7Droid:Easy-Screenshot-Library:v1.0.0'
	}

Step 3. Add the permissions in Manifest file:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

Now this is ready for use!

val myImageView = findViewById<View>(R.id.myImageView

//In you Activity or Fragment, instantiate an EasyScreenshot object and pass the 
//parameters you want to it's Builder:

val screenshot: EasyScreenshot = EasyScreenshot.Builder()
    .activity(this)
    .folderName("T7Droid Images") // Defines a name for the folder that will be created in galery;
    .imageFileName("screenshots") //Set a name for the image file;
    .targetViewId(myImageView //Any View you want to take the screenshot;
    .shareAfterScreenshot(true) //Do you want to share just after take the screenshot?
    .build()

screenshot.takeScreenshot()

Methods:

activity(activity: Activity) – The Activity context, you can use “this” inside an Activity, or, if you are inside a Fragment you can use activity, requireActivity, … in Kotlin, and getActivity( ) in Java;

folderName(folder: String ) – For the version before API 29 (Q) it will be the name of the folder that will be created to store the screenshots, for the version above (API 29 Q+) which uses the Scope Storage, it will be the name of the new folder that will be created in the Galery;

imageFileName( ) – Set a name for the image file;

targetViewId(view: View) – Here can will pass any view you want to save as an image in the JPEG format, if you want to take a screenshot of the whole screen (not including ActionBar neither StatusBar) you need only to define an id for the root view of your Activity or Fragment and pass it as a parameter in this method. If you are using View Binding just pass binding.root;

shareAfterScreenshot(share: Boolean) – Set true if you want to imediatelly share the image after taking the screenshot, if you want only to save the image and do not want to share set it as false.

?? Português:

Uma Library fácil de usar que irá lhe permitir tirar screenshots das telas ou Views (ImageViews, TextView, etc), salvar as imagens no seu aplicativo, além de poder compartilhá-lhas!

Não se preocupe mais com ter que verificar a versão do Android, implementar Scoped Storage, solicitação de permissões em tempo de execução…?⌛ veja como usar:

Passo 1. Adicione o repositório do JitPack ao seu projeto.

Adicione a url ao seu arquivo build.gradle (Project) em repositories , ou, no seu arquivo settings.gradle:

	allprojects {
		repositories {
			...
			maven { url 'https://jitpack.io' }
		}
	}

Passo 2. adicione a dependência

	dependencies {
	        implementation 'com.github.T7Droid:Easy-Screenshot-Library:v1.0.0'
	}

Passo 3. Adicione as permissões de leitura e gravação no arquivo Manifest:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

E pronto, é só isso! Agora você já pode usar à vontade ?

Veja alguns parâmetros que podem ser passados para o construtor neste exemplo abaixo:


val myImageView = findViewById<View>(R.id.myImageView)
//Ou binding.myImageView se estiver usando o View Binding

//Na sua aActivity ou Fragment, instancie um objeto EasyScreenshot e passe
//os parâmetros que desejar no seu construtor "EasyScreenshot.Builder()":

val screenshot: EasyScreenshot = EasyScreenshot.Builder()
    .activity(this) // 1°- Activity
    .folderName("T7Droid Images") //2° - Nome para a pasta que será criada na galeria
    .imageFileName("screenshots") //3° - Nome da imagem que será salva
    .targetViewId(myTxtView) //4° - View ou ViewGroup que desejar tirar o screenshot
    .shareAfterScreenshot(true) //5° - Deseja compartilhar após tirar o screenshot?
    .build()

//Após instanciarmos o objeto EasyScreenshot basta usá-lo chamando o método takeScreenshot() :D
screenshot.takeScreenshot()

Os métodos e parâmetros que podem ser passados são:

  • activity( activity: Activity) – Uma Activity, você pode usar “this” se estiver em uma Activity, ou, se estiver dentro de um Fragment poderá passar como parâmetro “activity, requireActivity, etc…” em Kotlin, e “getActivity( )” em Java;

  • folderName(folder: String ) – Para as versões anteriores ao Android 10 (API 29 ou Q) o nome que você passar como parâmetro aqui será o nome da nova pasta que será criada para armazenar seus screenshots. Por outro lado, nas versões Android 10 (API 29 ou Q) e acima, que fazem uso do Scoped Storage, esse será o nome da nova pasta que será criada na galeria do seu dispositivo;

Alguns exemplos de nomes: “Comprovantes”, “Recibos”, ou até o nome do seu próprio aplicativo ?

  • imageFileName( imageName: String) – Nome da imagem que será salva concatenado com a data em que foi tirada.

targetViewId(view: View) – Aqui você irá passar qualquer View ou ViewGroup que desejar salvar como uma imagem no formato JPEG, se você desejar tirar um screenshot de toda a tela (não incluindo nessa versão a ActionBar nem a StatusBar) você precisa apenas definir um id para a View raiz do layout da sua Activity ou Fragment e passá-lo como parâmetro nesse método;

shareAfterScreenshot(share: Boolean) – Defina como true se desejar compartilhar a imagem imediatamente após armazená-la, se você deseja apenas salvar a imagem e não deseja compartilhá-la, defina como false.

Tem alguma dúvida sobre a library? Encontrou algum problema ou tem sugestões de melhorias? Fique à vontade para me contatar.

Contato

www.t7droid@gmail.com

GitHub

View Github