Nano Hash - криптовалюты, майнинг, программирование

Совместное использование mp3-файла из папки активов в Whatsapp Android

Я новичок в Android.

Я перепробовал все сообщения на этом форуме. Но не смог добиться успеха. Я пытаюсь поделиться mp3-файлом из папки активов в WhatsApp.

Ниже мой код.

Это мой код в основной деятельности:

package com.example.sharedemo;

import com.example.sharedemo.R;

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;

public class MainActivity extends Activity {
    Button sharebutton;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        sharebutton = (Button) findViewById(R.id.sharebutton1);
        sharebutton.setOnClickListener(new View.OnClickListener() {         
            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub

                Uri theUri = Uri.parse("content://com.example.sharedemo.Assetsprovider/gotShocked.mp3");    
                Intent theIntent = new Intent(Intent.ACTION_SEND);
                theIntent.setType("audio/mp3");
                theIntent.setPackage("com.whatsapp");
                theIntent.putExtra(Intent.EXTRA_STREAM,theUri);
                startActivity(Intent.createChooser(theIntent,"Share using"));
            }
        });
    }
}

Код в ContentProvider:

package com.example.sharedemo;

import java.io.FileNotFoundException;
import java.io.IOException;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.content.res.AssetFileDescriptor;
import android.content.res.AssetManager;
import android.database.Cursor;
import android.net.Uri;
import android.util.Log;

public class Assetsprovider extends ContentProvider {
     @Override
     public AssetFileDescriptor openAssetFile( Uri uri, String mode ) throws FileNotFoundException
     {

             AssetManager am = getContext( ).getAssets( );
            String file_name = uri.getLastPathSegment( );
            // String file_name = uri.getPath();

             if( file_name == null )
                     throw new FileNotFoundException( );
             AssetFileDescriptor afd = null;
             try
             {
                     afd = am.openFd(file_name);
             }
             catch(IOException e)
             {
                     e.printStackTrace( );
             }
             return afd;//super.openAssetFile(uri, mode);
     }
     @Override
     public String getType( Uri p1 )
     {
             // TODO: Implement this method
             return null;
     }

     @Override
     public int delete( Uri p1, String p2, String[] p3 )
     {
             // TODO: Implement this method
             return 0;
     }

     @Override
     public Cursor query( Uri p1, String[] p2, String p3, String[] p4, String p5 )
     {
             // TODO: Implement this method
             return null;
     }

    /* @Override
     public Cursor query( Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder, CancellationSignal cancellationSignal )
     {
             // TODO: Implement this method
             return super.query( uri, projection, selection, selectionArgs, sortOrder, cancellationSignal );
     }*/

     @Override
     public Uri insert( Uri p1, ContentValues p2 )
     {
             // TODO: Implement this method
             return null;
     }

     @Override
     public boolean onCreate( )
     {
             // TODO: Implement this method
             return false;
     }

     @Override
     public int update( Uri p1, ContentValues p2, String p3, String[] p4 )
     {
             // TODO: Implement this method
             return 0;
     }
}

Файл манифеста:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.sharedemo"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="14" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
         <activity
            android:name=".Assetsprovider"
            android:label="@string/app_name" > 
            </activity> 
         <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <provider
        android:name="com.example.sharedemo.Assetsprovider"
        android:authorities="com.example.sharedemo.Assetsprovider"
        android:grantUriPermissions="true"
        android:exported="true" />
    </application>

</manifest>

Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..