2013-05-01 15 views
24

私は、SDカードから選択した画像をデータベースに保存し、この値をImageViewに設定するアプリケーションを開発しています。私は、uriを文字列と文字列に変換する方法をuriに知る必要があります。今私はウリのgetEncodedPath()メソッドを使用しますが、例えば、このコードは動作しません:Uriを文字列と文字列に変換する

ImageView iv=(ImageView)findViewById(R.id.imageView1); 
Uri uri=Uri.parse("/external/images/media/470939"); 
Log.e("uri1", uri.toString()); 
iv.setImageURI(uri); 

そこで私は、データベースにウリを保存し、保存された値から新しいURIを作成することができる方法がわかりません。それを修正するのを手伝ってください。

+0

String mystring="Hello" Uri myUri = Uri.parse(mystring); 

URIをURIに文字列を変換するために、これを試してみてくださいどのようなエラーが出ますか? –

+0

ImageViewのイメージがありません – user2218845

答えて

42

私は、URIを文字列と文字列に変換する方法を知っている必要があります。

StringUriを変換するために使用toString()StringUriに変換する場合は、Uri.parse()を使用してください。

このコードはUriの有効なストリング表記ではありません

を動作しません。 A Uriにはスキームがあり、"/external/images/media/470939"にスキームはありません。

+0

代わりにUri.fromFile()を使用してください.. 時々Uri.parseが問題を作成します.. – AnkitRox

-2

Uriの代わりにDrawableを使用できます。

ImageView iv=(ImageView)findViewById(R.id.imageView1); 
    String pathName = "/external/images/media/470939"; 
    Drawable image = Drawable.createFromPath(pathName); 
    iv.setImageDrawable(image); 

これは機能します。

+0

いいえ –

0

これはMediaProvider、DownloadsProvider、およびExternalStorageProviderからのファイルパスを取得し、非公式のContentProviderメソッドに戻ります。

/** 
* Get a file path from a Uri. This will get the the path for Storage Access 
* Framework Documents, as well as the _data field for the MediaStore and 
* other file-based ContentProviders. 
* 
* @param context The context. 
* @param uri The Uri to query. 
* @author paulburke 
*/ 
public static String getPath(final Context context, final Uri uri) { 

    final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT; 

    // DocumentProvider 
    if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) { 
     // ExternalStorageProvider 
     if (isExternalStorageDocument(uri)) { 
      final String docId = DocumentsContract.getDocumentId(uri); 
      final String[] split = docId.split(":"); 
      final String type = split[0]; 

      if ("primary".equalsIgnoreCase(type)) { 
       return Environment.getExternalStorageDirectory() + "/" + split[1]; 
      } 

      // TODO handle non-primary volumes 
     } 
     // DownloadsProvider 
     else if (isDownloadsDocument(uri)) { 

      final String id = DocumentsContract.getDocumentId(uri); 
      final Uri contentUri = ContentUris.withAppendedId(
        Uri.parse("content://downloads/public_downloads"), Long.valueOf(id)); 

      return getDataColumn(context, contentUri, null, null); 
     } 
     // MediaProvider 
     else if (isMediaDocument(uri)) { 
      final String docId = DocumentsContract.getDocumentId(uri); 
      final String[] split = docId.split(":"); 
      final String type = split[0]; 

      Uri contentUri = null; 
      if ("image".equals(type)) { 
       contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI; 
      } else if ("video".equals(type)) { 
       contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI; 
      } else if ("audio".equals(type)) { 
       contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; 
      } 

      final String selection = "_id=?"; 
      final String[] selectionArgs = new String[] { 
        split[1] 
      }; 

      return getDataColumn(context, contentUri, selection, selectionArgs); 
     } 
    } 
    // MediaStore (and general) 
    else if ("content".equalsIgnoreCase(uri.getScheme())) { 
     return getDataColumn(context, uri, null, null); 
    } 
    // File 
    else if ("file".equalsIgnoreCase(uri.getScheme())) { 
     return uri.getPath(); 
    } 

    return null; 
} 

/** 
* Get the value of the data column for this Uri. This is useful for 
* MediaStore Uris, and other file-based ContentProviders. 
* 
* @param context The context. 
* @param uri The Uri to query. 
* @param selection (Optional) Filter used in the query. 
* @param selectionArgs (Optional) Selection arguments used in the query. 
* @return The value of the _data column, which is typically a file path. 
*/ 
public static String getDataColumn(Context context, Uri uri, String selection, 
     String[] selectionArgs) { 

    Cursor cursor = null; 
    final String column = "_data"; 
    final String[] projection = { 
      column 
    }; 

    try { 
     cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs, 
       null); 
     if (cursor != null && cursor.moveToFirst()) { 
      final int column_index = cursor.getColumnIndexOrThrow(column); 
      return cursor.getString(column_index); 
     } 
    } finally { 
     if (cursor != null) 
      cursor.close(); 
    } 
    return null; 
} 


/** 
* @param uri The Uri to check. 
* @return Whether the Uri authority is ExternalStorageProvider. 
*/ 
public static boolean isExternalStorageDocument(Uri uri) { 
    return "com.android.externalstorage.documents".equals(uri.getAuthority()); 
} 

/** 
* @param uri The Uri to check. 
* @return Whether the Uri authority is DownloadsProvider. 
*/ 
public static boolean isDownloadsDocument(Uri uri) { 
    return "com.android.providers.downloads.documents".equals(uri.getAuthority()); 
} 

/** 
* @param uri The Uri to check. 
* @return Whether the Uri authority is MediaProvider. 
*/ 
public static boolean isMediaDocument(Uri uri) { 
    return "com.android.providers.media.documents".equals(uri.getAuthority()); 
} 
1

あなたは 'それは動作しません' とはどういう意味ですか?文字列

Uri uri; 
String uri_to_string; 
uri_to_string= uri.toString(); 
関連する問題