Skip to main content

How to Take Screenshot of Current activity and Share Options

Sometimes we have to share the Report or Final receipt Screen  from the Current Application  .In this scenario we take screenshot of Current activity and then share this as image file using sharing Options . So lets move to the Coding Part without wasting time .


1:  public class MainActivity extends AppCompatActivity {  
2:    File imagePath;  
3:    @Override  
4:    protected void onCreate(Bundle savedInstanceState) {  
5:      super.onCreate(savedInstanceState);  
6:      setContentView(R.layout.activity_main);  
7:      getSupportActionBar().setDisplayHomeAsUpEnabled(true);  
8:      ImageView imageView=(ImageView)findViewById(R.id.share);  
9:      imageView.setOnClickListener(new View.OnClickListener() {  
10:        @Override  
11:        public void onClick(View v) {  
12:          Bitmap bitmap = takeScreenshot();  
13:          saveBitmap(bitmap);  
14:          shareIt();  
15:        }  
16:      });  
17:    }  
18:    public Bitmap takeScreenshot() {  
19:      View rootView = findViewById(android.R.id.content).getRootView();  
20:      rootView.setDrawingCacheEnabled(true);  
21:      return rootView.getDrawingCache();  
22:    }  
23:    public void saveBitmap(Bitmap bitmap) {  
24:      imagePath = new File(Environment.getExternalStorageDirectory() + "/screenshot.png");  
25:      FileOutputStream fos;  
26:      try {  
27:        fos = new FileOutputStream(imagePath);  
28:        bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos);  
29:        fos.flush();  
30:        fos.close();  
31:      } catch (FileNotFoundException e) {  
32:        Log.e("GREC", e.getMessage(), e);  
33:      } catch (IOException e) {  
34:        Log.e("GREC", e.getMessage(), e);  
35:      }  
36:    }  
37:    private void shareIt() {  
38:      Uri uri = FileProvider.getUriForFile(MainActivity.this, BuildConfig.APPLICATION_ID + ".provider",imagePath);  
39:      Intent sharingIntent = new Intent(android.content.Intent.ACTION_SEND);  
40:      sharingIntent.setType("image/*");  
41:      String shareBody = "Please Find the screenshot.";  
42:      sharingIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, "Your Message Here ");  
43:      sharingIntent.putExtra(android.content.Intent.EXTRA_TEXT, shareBody);  
44:      sharingIntent.putExtra(Intent.EXTRA_STREAM, uri);  
45:      startActivity(Intent.createChooser(sharingIntent, "Share via"));  
46:    }  
47:    @Override  
48:    public boolean onOptionsItemSelected(MenuItem item) {  
49:      switch (item.getItemId())  
50:      {  
51:        case android.R.id.home:  
52:          finish();  
53:          return true;  
54:      }  
55:      return super.onOptionsItemSelected(item);  
56:    }  
57:  }  

Thank You !! And Keep coding and Sharing knowledge !

Comments

Popular posts from this blog

How to Download Apk file from Url and Install Programmatically

In this post we learn about download apk file from server or website and then install it Programmatically in Phone. Sometimes we have to download external apk file from server and then install if downloading successfully finished.For this we use AsyncTask class  for background process. So here is Code Snippet for this task.Lets Start :- Before this we have to add these Permissions in Manifest.xml file : <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> DownloadNewVersion.java class DownloadNewVersion extends AsyncTask<String,Integer,Boolean> { @Override protected void onPreExecute() { super.onPreExecute(); bar = new ProgressDialog(getActivity()); bar.setCancelable(false); bar.setMessage("Downl...

Auto read OTP using SMS User Consent API in Android

Some times ago Google Play restricts the use of high risk or sensitive permissions, including the SMS or Call Log permission groups. It means you have to justify why you are taking SMS or other high risk or sensitive permissions for your application .For this you may be required to complete the Permissions Declaration Form and receive approval from Google Play. Before this every app even who does not have any purpose for taking SMS or other high sensitive permissions in their app ,They was taking these permissions from users and this is a kind of security beach.  For solution of this problem Google introduce SMS User Consent API . The SMS User Consent API complements the SMS Retriever API by allowing an app to prompt the user to grant access to the content of a single SMS message. When a user gives consent, the app will then have access to the entire message body to automatically complete SMS verification. If your appeal for SMS permission is rejected by Google team you can u...

How to open pdf file url using webview in Android

 Sometimes we have requirement of showing pdf file in our Android Application. Although there are many third party gradle dependencies available online by which you can show your pdf file easily but one of the major drawback of using these libraries are they will increase you apk size .In some cases they will increase apk size upto ~14 MB. Alternatively you can access and show pdf file using assets and from storage options. This can take less size than any third party library. Here we use pdf using url and if you directly open your pdf file url in webview you will get no result because it will start downoad if you open this link in any web browser.  So in this article we will learn how we can open our pdf url using webview and without using any third party library. So lets Start step by Step:- Lets Suppose you have a pdf file url something like   http://yourwebsite.com/files/mydocumentfile.pdf Step 1: So we you this pdf file url to embed in our webview .First of all you h...