【问题标题】:How to set an image onClick from gridview?如何从gridview设置图像onClick?
【发布时间】:2017-12-27 17:22:04
【问题描述】:

我能够显示在 gridview 中被点击的项目的 ID,但是我想要实现的是,当我点击 Gridview 内的任何图像时,它也会显示为图像,当我使用下面的代码单击任何图像,它只显示 ID,但是当我尝试显示图像本身时,应用程序崩溃并出现 LinearLayout 无法转换为 ImageView

gifts_layout_2.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/fragment_history_menu_bottom"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#ffffff"
android:gravity="center"
android:orientation="vertical"
app:layout_behavior="android.support.design.widget.BottomSheetBehavior">


<ImageView
    android:id="@+id/close"
    android:layout_width="15dp"
    android:layout_height="15dp"
    android:layout_gravity="right"
    android:layout_marginRight="15dp"
    android:layout_marginTop="15dp"
    android:src="@drawable/close" />


<TextView
    android:id="@+id/title"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="5dp"
    android:text="Smiles"
    android:textColor="#000000"
    android:textSize="17sp"
    android:textStyle="bold"
    android:layout_gravity="left"
    android:layout_marginLeft="15dp"/>


<GridView
    android:layout_width="match_parent"
    android:layout_height="150dp"
    android:layout_marginTop="10dp"
    android:numColumns="4"
    android:horizontalSpacing="10dp"
    android:verticalSpacing="10dp"
    android:gravity="center|center_horizontal|center_vertical"
    android:columnWidth="100dp"
    android:stretchMode="columnWidth"
    android:scrollbars="vertical"
    android:scrollbarSize="3dp"
    android:scrollIndicators="left"
    android:id="@+id/grid_view2"
    android:paddingLeft="10dp"
    android:layout_marginBottom="10dp"
    android:layout_gravity="center|center_horizontal|center_vertical"
    android:clipChildren="false"
    android:clipToPadding="false"/>


</LinearLayout>

smiles_items_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="wrap_content"
android:layout_height="wrap_content">

<ImageView android:id="@+id/smile_image_view"
    android:layout_width="45dp"
    android:layout_height="45dp"
    android:layout_gravity="center"/>


</LinearLayout>

BottomSheetDialog_Smiles.java

@Override
public View getView(final int position, View convertView, ViewGroup parent) 
{

final Holder holder = new Holder();
LayoutInflater inflater = (LayoutInflater) 
getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
grid = inflater.inflate(R.layout.smile_items_layout, null);
lottieImage = inflater.inflate(R.layout.activity_streaming2, null);

holder.img = (ImageView) grid.findViewById(R.id.smile_image_view);
holder.img.setImageResource(mThumbIds[position]);

gridView2.setOnItemClickListener(new AdapterView.OnItemClickListener() {

@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long 
l) {
JSONDictionary imageChat = new JSONDictionary();
int imageId = (int) getItem(i);
imageChat.put("message",imageId);
Communicator.getInstance().emit("new chat message", imageChat);
}
});

return grid;
}

【问题讨论】:

  • 您的网格有正确的图像吗?单击网格的一个图像时会发生什么?
  • 确切地说,当图像被点击时,它应该被发送到服务器,因为我正在使用套接字 io,如果我放置一个字符串或一个 int 而不是图像,我可以实现这一点,但是我需要的是显示图像本身
  • 我建议您将新图像托管在片段中,并使用片段转换让图像显示在屏幕上。如果您感到迷茫,我可以发布实际答案
  • 嗯,事情是我能够发送我的代码中显示的图像的 id,所以为了发送图像而不是文本,我是否需要特定的东西?
  • 对不起,我把你的问题弄错了。检查这个答案answer

标签: java android


【解决方案1】:

试试下面的代码,OnItemClick 返回你点击过的视图

gridView2.setOnItemClickListener(new AdapterView.OnItemClickListener() {

@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l){
   ImageView imageView = (ImageView)view;
   //if you want to get image from imageview
   imageView .getDrawable()
  }
});

如果您想从可绘制对象中获取输入流,请使用以下命令:

BitmapDrawable bitmapDrawable = ((BitmapDrawable) drawable);
Bitmap bitmap = bitmapDrawable .getBitmap();
ByteArrayOutputStream stream = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.JPEG, 100, stream);
byte[] imageInByte = stream.toByteArray();
ByteArrayInputStream bis = new ByteArrayInputStream(imageInByte);

已更新

你用两种方式来做

第一种方式: 从xml中删除LinerLayout,使ImageView Parent作为LinerLayout只包含一个视图像这样,如果你使用它,那么不需要更改java代码

smiles_items_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<ImageView
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/smile_image_view"
        android:layout_width="45dp"
        android:layout_height="45dp"
 />

第二种方式

如果你想保持你的xml不变,那么像下面这样更改java代码

 LinearLayout linearLayout= (LinearLayout)view;
 ImageView imageView = (ImageView) linearLayout.getChildAt(0);
 //if you want to get image from imageview
 imageView .getDrawable()

【讨论】:

  • 我已经尝试过您编写的从 imageview 获取图像的代码,但是应用程序崩溃并出现错误 java.lang.ClassCastException: android.widget.LinearLayout cannot be cast to android .widget.ImageView,请帮忙
  • 我已经尝试了 stackoverflow.com/questions/11191040/… 的所有方法,但仍然无法正常工作
  • @O.D 我需要为gridView2 显示您的xml。你在gridView2中膨胀了哪个xml,那是post,哪个内容是你在点击时必须得到的图像
  • 所以你得到smile_image_view这个图像视图对吗?
  • 我试过了,它会出现一些文本,如 android.support.v7.widget.AppCompactImageView(baa77fcV.ED........52,0-187,135#7f080101 app:id/smile_image_view 但没有提供图像本身,当我更改 xml 时它没有提供图像,它完全是空白
猜你喜欢
  • 1970-01-01
  • 2016-02-17
  • 1970-01-01
  • 2014-07-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多