Android Studio делится пользовательским видом изображения через намерение не работает - PullRequest
1 голос
/ 21 марта 2019

У меня возникают некоторые проблемы при попытке поделиться пользовательским представлением в одном из моих действий через социальные сети (Facebook и т. Д.) Нажатием кнопки, однако при нажатии кнопки ничего не происходит, и Logcat не показывает никаких ошибок. Пользовательский вид рисунка на холсте. Ниже мой код:

public class GraphActivity extends AppCompatActivity {
    DrawGraphTest drawGraphTest;

    private Button shareImage;

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_graph);
        drawGraphTest = (DrawGraphTest)findViewById(R.id.drawGraphTest);

        shareImage = (Button) findViewById(R.id.btnShare);
        shareImage.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v) {
                share(drawGraphTest);
            }
        });
    }

    @SuppressLint("SetWorldReadable")
    public void share(View view){
        Bitmap bitmap =getBitmapFromView(drawGraphTest);
        try {
            File file = new File(this.getExternalCacheDir(),"myImage.png");
            FileOutputStream fOut = new FileOutputStream(file);
            bitmap.compress(Bitmap.CompressFormat.PNG, 100, fOut);
            fOut.flush();
            fOut.close();
            file.setReadable(true, false);
            final Intent intent = new Intent(Intent.ACTION_SEND);
            intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            intent.putExtra(Intent.EXTRA_STREAM, Uri.fromFile(file));
            intent.setType("image/png");
            startActivity(Intent.createChooser(intent, "Share image via"));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    private Bitmap getBitmapFromView(View view) {
        Bitmap returnedBitmap = Bitmap.createBitmap(view.getWidth(), view.getHeight(),Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(returnedBitmap);
        Drawable bgDrawable =view.getBackground();
        if (bgDrawable!=null) {
            //has background drawable, then draw it on the canvas
            bgDrawable.draw(canvas);
        }   else{
            //does not have background drawable, then draw white background on the canvas
            canvas.drawColor(Color.WHITE);
        }
        view.draw(canvas);
        return returnedBitmap;
    }

}

Мой XML:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".GraphActivity">

    <g.myPackage.DrawGraphTest
        android:id="@+id/drawGraphTest"
        android:layout_width="wrap_content"
        android:layout_height="400dp"
        android:layout_marginStart="8dp"
        android:layout_marginLeft="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginBottom="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.0" />

    <Button
        android:id="@+id/btnShare"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="8dp"
        android:layout_marginBottom="8dp"
        android:text="Button"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.982" />

Я также включил эти разрешения в моем файле Manifest.xml:

<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"/>

При нажатии кнопки Logcat Verbose показывает:

2019-03-21 04:30:26.147 19176-19176/g.companieshouse.companieshouse D/errortag1: android.os.FileUriExposedException: file:///storage/emulated/0/Android/data/g.companieshouse.companieshouse/cache/companieshouse.png exposed beyond app through ClipData.Item.getUri()

Для справки, код, который я пытаюсь реализовать, находится по ссылке ниже, и, поскольку я новичок в Android Studio, я изо всех сил пытаюсь увидеть, где я ошибся в своей реализации, и мог бы действительно использовать некоторую помощь! Единственное отличие, которое я вижу, состоит в том, что в ссылке они открывают представление изображений, тогда как я делюсь пользовательским представлением.

https://www.logicchip.com/share-image-without-saving/

Ответы [ 2 ]

1 голос
/ 21 марта 2019

Исключение, которое выдается, когда приложение предоставляет файл : // Uri другому приложению.

Эта экспозиция не рекомендуется, так как принимающее приложение может не иметь доступа к общему пути. Например, принимающее приложение, возможно, не запросило разрешение Manifest.permission.READ_EXTERNAL_STORAGE во время выполнения, или платформа может совместно использовать Uri через границы профиля пользователя.

Вместо этого приложения должны использовать content: // Uris, чтобы платформа могла расширить временное разрешение для получающего приложения на доступ к ресурсу.

Это выбрасывается только для приложений, нацеленных на Build.VERSION_CODES # N или выше. Приложениям, ориентированным на более ранние версии SDK, разрешено предоставлять общий доступ к файлу : // Uri , но это настоятельно не рекомендуется.

Возможное решение: android.os.FileUriExposedException: файл: ///storage/emulated/0/test.txt, доступный за пределами приложения через Intent.getData ()

0 голосов
/ 21 марта 2019

если версия для Android> m, получить URI необходимо через FileProvider ,, как это

fun getUri(file: File): Uri? {
     try {
         return if (Build.VERSION.SDK_INT > Build.VERSION_CODES.M) {
         FileProvider.getUriForFile(MyApp.instance, MyApp.instance.packageName, file)
     } else {
         Uri.fromFile(file)
     }
     } catch (e: Exception) {
        e.printStackTrace()
     }
     return null
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...