Как установить путь к изображению при просмотре изображения в Android
У меня есть следующий код, в котором я получаю идентификатор, имя и путь к изображению.
Я хочу показать этот путь изображения в представлении изображения.
public class AllProductsActivity extends ListActivity {
String pid;
private ProgressDialog pDialog;
// Creating JSON Parser object
JSONParser jParser = new JSONParser();
ArrayList<HashMap<String, String>> productsList;
// url to get all products list
private static String url_all_products = "example.com/files/get_all_products.php";
// JSON Node names
private static final String TAG_SUCCESS = "success";
private static final String TAG_PRODUCTS = "products";
private static final String TAG_PID = "id";
private static final String TAG_NAME = "name";
private static final String TAG_PRICE = "price";
private static final String TAG_IMAGE1 = "image1";
// products JSONArray
JSONArray products = null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.all_products);
// Hashmap for ListView
productsList = new ArrayList<HashMap<String, String>>();
// getting product details from intent
Intent i = getIntent();
// getting product id (pid) from intent
pid = i.getStringExtra(TAG_PID);
// Loading products in Background Thread
new LoadAllProducts().execute();
// Get listview
ListView lv = getListView();
// on seleting single product
// launching Edit Product Screen
lv.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
// getting values from selected ListItem
String pid = ((TextView) view.findViewById(R.id.pid)).getText()
.toString();
// Starting new intent
Intent in = new Intent(getApplicationContext(),
EditProductActivity.class);
// sending pid to next activity
in.putExtra(TAG_PID, pid);
// starting new activity and expecting some response back
startActivityForResult(in, 100);
}
});
}
// Response from Edit Product Activity
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// if result code 100
if (resultCode == 100) {
// if result code 100 is received
// means user edited/deleted product
// reload this screen again
Intent intent = getIntent();
finish();
startActivity(intent);
}
}
@Override
protected void onPreExecute() {
super.onPreExecute();
pDialog = new ProgressDialog(AllProductsActivity.this);
pDialog.setMessage("Loading products. Please wait...");
pDialog.setIndeterminate(false);
pDialog.setCancelable(false);
pDialog.show();
}
protected String doInBackground(String... args) {
// Building Parameters
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("id", pid));
// getting JSON string from URL
JSONObject json = jParser.makeHttpRequest(url_all_products, "GET",
params);
// Check your log cat for JSON reponse
Log.d("All Products: ", json.toString());
try {
// Checking for SUCCESS TAG
int success = json.getInt(TAG_SUCCESS);
if (success == 1) {
// products found
// Getting Array of Products
products = json.getJSONArray(TAG_PRODUCTS);
// looping through All Products
for (int i = 0; i < products.length(); i++) {
JSONObject c = products.getJSONObject(i);
// Storing each json item in variable
String id = c.getString(TAG_PID);
String name = c.getString(TAG_NAME);
String price = c.getString(TAG_PRICE);
String image1 = c.getString(TAG_IMAGE1);
// creating new HashMap
HashMap<String, String> map = new HashMap<String, String>();
// adding each child node to HashMap key => value
map.put(TAG_PID, id);
map.put(TAG_NAME, name);
map.put(TAG_PRICE, price);
map.put(TAG_IMAGE1, image1);
// adding HashList to ArrayList
productsList.add(map);
}
} else {
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
protected void onPostExecute(String file_url) {
// dismiss the dialog after getting all products
pDialog.dismiss();
// updating UI from Background Thread
runOnUiThread(new Runnable() {
public void run() {
/**
* Updating parsed JSON data into ListView
* */
ListAdapter adapter = new SimpleAdapter(
AllProductsActivity.this, productsList,
R.layout.list_row, new String[] { TAG_PID,
TAG_NAME, TAG_PRICE, TAG_IMAGE1 },
new int[] { R.id.pid, R.id.name, R.id.price,
R.id.thumbnail });
// updating Listview
setListAdapter(adapter);
}
});
}
}
}
я прошел image1
путь в списке адаптера, и я взял imageview в XML-файле.
Но я не получил изображения муравья над их.
list_row.xml containg image view:
<ImageView
android:id="@+id/thumbnail"
android:layout_width="80dp"
android:layout_height="80dp"
android:layout_alignParentLeft="true"
android:layout_marginRight="8dp" />
Как я могу показать изображения в режиме просмотра изображений?
8 ответов
Я думаю, что вы собираетесь работать с JSON, и загрузить изображение с сервера,
Если да, то я предлагаю вам использовать любой загрузчик изображений, например, универсальный загрузчик изображений.
Пикассо загрузит изображение в другой ветке, и оно управляет вами:
- заполнитель в то время как изображение все еще загружается
- изменение размера
- обрезка / центрирования / масштабирование
- кэширование (вам не нужно каждый раз загружать изображение)
- это даже делает "исчезновение изображения", которое популярно / нормальное теперь
Это очень просто, вот пример:
Picasso.with(context)
.load(url)
.placeholder(R.drawable.placeholder)
.resize(imgWidth, imgHeight)
.centerCrop()
.into(image);
Вам необходимо выполнить следующие шаги:
1) Вам необходимо реализовать собственный адаптер, который будет заполнять изображение путем ленивой загрузки изображения в соответствии с соответствующим URL-адресом в этой строке.
2) Реализовать LazyLoader, который может загружать изображение и обновлять изображение после его завершения.
3) Вызовите LazyLoading, когда вызывается метод getView вашего пользовательского адаптера.
4) Вызовите свой пользовательский адаптер в OnPostExecute вместо вашего Listadapter
5) ИЛИ, чтобы упростить процесс LazyLoading, используйте код Universal Image Loader.
ImageView imageView=(ImageView)findViewById(R.id.animage);
Uri imageUri = (Uri) intent.getParcelableExtra(Intent.EXTRA_STREAM);
if (imageUri != null) {
String filePath = null;
filePath = imageUri.getPath();
BitmapFactory.Options options = new BitmapFactory.Options();
options.inSampleSize = 8;
Bitmap bitmap = BitmapFactory.decodeFile(filePath,options);
imageView.setImageBitmap(bitmap);
}
Слишком поздно, но, возможно, это может кому-то помочь.
Если вы в порядке, используя некоторую библиотеку загрузки изображений в своем проекте, просто используйте этот пользовательский вид изображения, чтобы разрешить установку URL из xml.
Так как вы можете установить URL из xml, можно напрямую связать переменную ссылки с изображением.
Создать пользовательский вид изображения.
class MyImageView : ImageView {
var url: String = ""
set(value){
field = value
Glide.with(this).load(value).into(this)
}
constructor(context: Context) : super(context)
constructor(context: Context, attrs : AttributeSet) : super(context,attrs){
val array = context.obtainStyledAttributes(attrs, R.styleable.MyImageView)
val url = array.getString(R.styleable.MyImageView_url)
if(url!=null){
Glide.with(this).load(url).into(this)
}
array.recycle()
}
constructor(context: Context, attrs: AttributeSet , defStyleAttr : Int) : super(context, attrs, defStyleAttr)
}
Добавьте это в attr.xml
<declare-styleable name="MyImageView">
<attr name="url" format="string" />
</declare-styleable>
Используйте это в XML
<package.path.MyImageView
android:id="@+id/image_company_logo"
android:scaleType="fitCenter"
android:layout_width="match_parent"
android:layout_height="80dp"
android:contentDescription="logo"
app:url="@{invoice.invoiceLogoLink}"/> //for data binding purpose
Узнайте больше об этом здесь
Вы можете просто использовать Picasso lib, мощную библиотеку для загрузки и кэширования изображений для Android.
Он обеспечивает супер чистый синтаксис, так что вы можете использовать его без каких-либо путаницы.
Например, в вашем адаптере вы попробуйте вот так:
Во-первых, если вы используете SimpleAdapter, ViewBinder - это то, что вы должны знать. Подробности см. http://developer.android.com/reference/android/widget/SimpleAdapter.ViewBinder.html
Затем в setViewValue вашего собственного ViewBinder просто добавьте следующий код:
Picasso.with(context).load(img_path).into(imgView)
Или, если вы настраиваете свой собственный адаптер, добавьте код в функцию getView, которая переопределяется.
Наконец, он показывает изображения на ваших изображениях.
Подробнее о Пикассо: http://square.github.io/picasso/
Universal Image Loader - это еще один ваш выбор, который также имеет количество пользователей. Это более настраиваемый. Смотрите: https://github.com/nostra13/Android-Universal-Image-Loader
Скачайте файл Picasso JAR и сначала добавьте JAR-приложение для сборки Android:
а теперь просто получите свой URL от JSON
if(response.login_data.avtar!=null &&response.login_data.avtar.length()>0) {
String photo=response.login_data.avtar.toString();
infoLog("avatar"+photo);
String url=App.WEB_PHOTO_URL+photo;
infoLog("avatar url"+url);
Picasso.with(HealthProfile.this).load(url).into(img);
}
else {
Picasso.with(HealthProfile.this).load(R.drawable.user).into(img);
}
Вам нужно создать собственный адаптер, накачать вашу строку и извлечь ваш ImageView из макета. Затем вы можете программно настроить свой ImageView следующим образом:
File imgFile = new File(yourImagePath);
if(imgFile.exists()){
Bitmap myBitmap = BitmapFactory.decodeFile(imgFile.getAbsolutePath());
yourImageView.setImageBitmap(myBitmap);
}
Учебник по созданию собственного адаптера: http://www.vogella.com/tutorials/AndroidListView/article.html