gpt4 book ai didi

android - 在 recyclerview 中触摸没有涟漪效应

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:27:26 25 4
gpt4 key购买 nike

我有一个带有四个网格元素 (2*2) 的 recyclerview,其工作方式类似于菜单。但是,当我点击它们时,没有显示涟漪效应。它只是将我带到下一个 Activity ,而没有任何视觉确认 View 已被按下。谁能帮忙?

主要 Activity

public class MainActivity extends AppCompatActivity implements MainMenuAdapter.OnItemClickListener {

Toolbar toolbar;
private static List<ViewModel> tileItems = new ArrayList<>();

static {
tileItems.add(new ViewModel("Activity", "#3F51B5", R.drawable.activity));
tileItems.add(new ViewModel("Profile", "#E91E63", R.drawable.profile));
tileItems.add(new ViewModel("Training", "#FF5722", R.drawable.training));
tileItems.add(new ViewModel("Diet", "#4CAF50", R.drawable.diet));
}

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

final RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
recyclerView.setLayoutManager(new GridLayoutManager(this, 2));
MainAdapter adapter = new MainAdapter(tileItems, MainActivity.this);
recyclerView.setAdapter(adapter);
adapter.setOnItemClickListener(this);


// Toolbar
toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);

}

@Override
public void onBackPressed() {
this.moveTaskToBack(true);
// this.finishAffinity();
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}

@Override public void onItemClick(View view, ViewModel viewModel) {
}
}

主适配器

public class MainAdapter extends RecyclerView.Adapter<MainMenuAdapter.ViewHolder> implements View.OnClickListener {

private List<ViewModel> items;
private OnItemClickListener onItemClickListener;
private Context context;

// Adapter constructor
public MainAdapter(List<ViewModel> items, Context context) {
this.items = items;
this.context = context;
}

public void setOnItemClickListener(OnItemClickListener onItemClickListener) {
this.onItemClickListener = onItemClickListener;
}

@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.main_item, parent, false);
return new ViewHolder(v);
}

@Override
public void onBindViewHolder(ViewHolder viewHolder, int position) {

final ViewModel dataItem = items.get(position);
viewHolder.colorBlock.setBackgroundColor(dataItem.getColor());
viewHolder.menuName.setText(dataItem.getName());
viewHolder.menuIcon.setImageResource(dataItem.getImage());
viewHolder.itemView.setTag(dataItem);
if (dataItem.getActivity() != null) {
viewHolder.colorBlock.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent i = new Intent(context, dataItem.getActivity());
context.startActivity(i);

}
});
}
}

@Override
public int getItemCount() {
return items.size();
}

@Override public void onClick(final View v) {
// Give some time to the ripple to finish the effect
if (onItemClickListener != null) {
new Handler().postDelayed(new Runnable() {
@Override public void run() {
onItemClickListener.onItemClick(v, (ViewModel) v.getTag());
}
}, 200);
}
}

/** This is our ViewHolder class */
public static class ViewHolder extends RecyclerView.ViewHolder {

public TextView menuName;
public View colorBlock;
public ImageView menuIcon;

public ViewHolder(View convertView) {
super(convertView); // Must call super() first

menuName = (TextView) convertView.findViewById(R.id.menuName);
colorBlock = (View) convertView.findViewById(R.id.colorBlock);
menuIcon = (ImageView) convertView.findViewById(R.id.menuItem);
}
}

public interface OnItemClickListener {

void onItemClick(View view, ViewModel viewModel);

}
}

activity_main.xml

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">

<include
android:id="@+id/toolbar"
layout="@layout/toolbar"
android:layout_height="wrap_content"
android:layout_width="match_parent"/>

<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_below="@id/toolbar"
android:layout_width= "match_parent"
android:layout_height = "match_parent" />

</RelativeLayout>

主项目.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:clickable="true"
android:focusable="true"
android:foreground="?android:attr/selectableItemBackground">

<View
android:id="@+id/colorBlock"
android:layout_width="match_parent"
android:layout_height="170dp" />

<ImageView
android:id="@+id/menuItem"
android:layout_width="120dp"
android:layout_height="120dp"
android:layout_centerHorizontal="true"
android:padding="16dp"
/>

<TextView
android:id="@+id/menuName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="16dp"
android:layout_centerHorizontal="true"
android:layout_alignParentBottom="true"
android:textColor="@android:color/white"
android:textSize="16sp"/>
</RelativeLayout>

最佳答案

如果将 main_item.xml 的背景设置为 ?android:selectableItemBackground?selectableItemBackground,就会出现涟漪效果(@Budius 在他的评论中是错误的)。我找到了对第二个的引用。但是,AndroidStudio 警告说它在 com.android.support:design 中是私有(private)的。我的应用程序在尝试使用该私有(private)版本时崩溃了。我猜第一个带有“android:”前缀,瞧,它有效。

也许你不小心设置了android:foreground?我试过了,但没有发现我的 RecyclerView 项目有任何变化。

更新后的 RelativeLayout 将是:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:clickable="true"
android:focusable="true"
android:foreground="?android:attr/selectableItemBackground"
android:background="?android:selectableItemBackground">

我还看到 android:background="?android:attr/selectableItemBackground" 可以启动涟漪。我还会提到 selectableItemBackground 不需要位于 main_item.xml 的根元素上。我在根项目中使用背景颜色,然后在嵌套的 ViewGroup 上设置 selectableItemBackground。

我的答案来自一个不使用 Material 设计 appcompat 的引用框架。我怀疑如果您使用的是 Material 设计 appcompat 支持库,会有不同。

关于android - 在 recyclerview 中触摸没有涟漪效应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31998325/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com