10

テキスト ファイルをクリックして開くと、Android システムからインテントを受け取るように設計されたテキスト リーダー アプリがあります。しかし、私のアプリはシステムによってポップアップされたリストにありません。以下は私のコードです:

マニフェスト

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

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

<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:label="@string/app_name"
android:name=".BroadcastReceiverTest1Activity" >
<intent-filter >
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>

<receiver android:name="MyBroadcastReceiver"> 
<intent-filter> 
<action android:name="android.intent.action.ACTION_VIEW" /> 
<action android:name="android.intent.action.ACTION_EDIT" /> 
<action android:name="android.intent.action.ACTION_PICK" /> 
<data android:scheme="file" /> 
<data android:mimeType="*/*" /> 
<data android:pathPattern=".*\\.txt" />    
<data android:host="*" /> 
</intent-filter> 
</receiver> 

</application>

</manifest>

私の拡張BroadcastReceiver

public final class MyBroadcastReceiver extends BroadcastReceiver {
private String TAG = "MyBroadcastReceiver";

@Override
public void onReceive(Context context, Intent intent) {
// TODO Auto-generated method stub
Intent i = new Intent(context, BroadcastReceiverTest1Activity.class);
i.putExtra("URI", intent.getData());
context.startActivity(i);
Log.d(TAG, "Leaving onReceived...");
}
}

ブロードキャスト レシーバーによって開かれる私のアクティビティ

public class BroadcastReceiverTest1Activity extends Activity {

private String uri ="";
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
final Intent intent = getIntent();

final String action = intent.getAction();

if(Intent.ACTION_VIEW.equals(action)){
uri = intent.getStringExtra("URI");
TextView textView = (TextView)findViewById(R.id.textView);
textView.setText(uri);

}

}
}

ありがとう!

4

3 に答える 3

17

アプリをファイル拡張子に関連付ける必要があります。これを行うには、これらの2行をインテントフィルター内に追加します。

<data android:scheme="file" />
<data android:mimeType="*/*"/>
<data android:pathPattern=".*\\.pdf" />

そして、あなたのマニフェストは次のようになります

<activity name="com.your.activity">
    <intent-filter>
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />
        <data android:scheme="file" />
        <data android:mimeType="*/*" />
        <data android:pathPattern=".*\\.txt" />
    </intent-filter>
</activity>

<data android:scheme="file" />=>これは、ファイルがhttpなどからではなくローカルでなければならないことを定義します

<data android:mimeType="*/*" />=>任意のmimeタイプに一致

<data android:pathPattern=".*\\.txt" />=>ここで、一致させる拡張子を指定します

この助けを願っています

于 2012-06-22T09:12:56.160 に答える
8

HERO の疑似コードを詳しく説明すると、これは効果的に機能します。

<manifest>次のように変更します。

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

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

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:label="@string/app_name"
            android:name=".BroadcastReceiverTest1Activity" >
            <intent-filter >

                <action android:name="android.intent.action.VIEW" />
                <category android:name="android.intent.category.DEFAULT" />
                <category android:name="android.intent.category.BROWSABLE" />
                <data android:scheme="file" />
                <data android:mimeType="*/*" />
                <data android:pathPattern=".*\\.txt" />
            </intent-filter> 
        </activity>
    </application>
</manifest>

放送受信機を落としてください。不要です。

BroadcastReceiverTest1Activity クラスを変更します (メイン アクティビティである必要はありません。以下のボーナスを参照してください)。

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
public class BroadcastReceiverTest1Activity extends Activity {
    private String TAG = "TagOpenTxt";
    private String uri ="";
    private Uri uri2;
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);
        final Intent intent = getIntent();  
        final String action = intent.getAction();

        if(Intent.ACTION_VIEW.equals(action)){
            //uri = intent.getStringExtra("URI");
            uri2 = intent.getData();
            uri = uri2.getEncodedPath() + "  complete: " + uri2.toString();
            TextView textView = (TextView)findViewById(R.id.textView);
            textView.setText(uri);
            // now you call whatever function your app uses 
            // to consume the txt file whose location you now know 
        } else {
            Log.d(TAG, "intent was something else: "+action);
        }
    }
}

TXT ファイルのインテント リスナーを効果的に作成しました。これは、ユーザーが使用することを決定した場合にアプリを呼び出します (ユーザーが以前にファイル タイプ TXT を別のアプリに関連付けていない限り...)。

インテントをキャッチするためにアプリがアクティブである必要はありません。インストールすると、システムはそれを、選択した特定の MIME タイプや拡張子の「goto アプリ」の 1 つとして認識します (MIME タイプで関連付けるよりも簡単ではありません)。

ボーナス: 別の MAIN アクティビティを持つことができ、BroadcastReceiver が呼び出されると、アプリケーションに影響を与えることなく、アプリケーションと同じサンドボックス内で実行されます (MAIN アクティビティのonResumeメソッドでそれを実装する必要があります)。

テキストデータを静的変数に読み込むことができます[ずさん]または、たとえばアプリや電話のシャットダウンに関係なく、永続的で安全なSQLiteデータベースに配置できます。

アクティビティが自己終了し、レイアウト/ウィンドウを起動することさえない可能性があります。これは、txt ファイルがアプリによって正しく完全に消費されたことをユーザーが確認したい場合には、一種の奇妙なことです。

于 2013-03-21T18:35:07.920 に答える
4

フィルタ属性を使用して、ブロードキャストレシーバーではなくACTIVITYを登録する必要があります。

于 2012-06-22T08:49:52.717 に答える