- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
通常,我不会问这样的问题;我做了我的研究,至少能够在 StackOverflow 上提问之前找出问题所在。但这一次,即使经过彻底研究和一遍又一遍地查看我的代码,我什至无法确定问题所在。因此,对于提出如此广泛的问题,我深表歉意。
我的应用程序中有一些 RecyclerViews(准确地说是 9 个)。其中一个正在工作,八个没有。我一遍又一遍地查看我的代码,但我似乎无法确定问题所在。我将粘贴一个回收器 View 及其适配器的代码。这是我对单个元素的布局:
这是我的单个元素布局的代码(我只是发布它让人们知道ID):
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:background="#0099ff">
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/left_guideline_view"
app:layout_constraintGuide_percent=".12077"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/right_guideline_view"
app:layout_constraintGuide_percent=".87923"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/left_guideline_image_view"
app:layout_constraintGuide_percent=".16908"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/top_guideline_image_view"
app:layout_constraintGuide_percent=".14706"
android:orientation="horizontal"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/left_guideline_text_view"
app:layout_constraintGuide_percent=".37198"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/right_guideline_text_view"
app:layout_constraintGuide_percent=".83"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/top_guideline_text_view_order"
app:layout_constraintGuide_percent=".13235"
android:orientation="horizontal"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/bottom_guideline_text_view_order"
app:layout_constraintGuide_percent=".38235"
android:orientation="horizontal"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/bottom_guideline_text_view_planter"
app:layout_constraintGuide_percent=".61765"
android:orientation="horizontal"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/left_guideline_mark_fulfilled_icon"
app:layout_constraintGuide_percent=".32367"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/right_guideline_mark_fulfilled_icon"
app:layout_constraintGuide_percent=".43961"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/top_guideline_icon"
app:layout_constraintGuide_percent=".74265"
android:orientation="horizontal"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/bottom_guideline_icon"
app:layout_constraintGuide_percent=".96324"
android:orientation="horizontal"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/left_guideline_message_icon"
app:layout_constraintGuide_percent=".58696"
android:orientation="vertical"/>
<androidx.constraintlayout.widget.Guideline
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/right_guideline_message_icon"
app:layout_constraintGuide_percent=".70290"
android:orientation="vertical"/>
<FrameLayout
android:layout_width="0dp"
android:layout_height="0dp"
android:id="@+id/left_border"
android:background="#0099ff"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="@id/left_guideline_view"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent">
<Button
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#0099ff" />
</FrameLayout>
<FrameLayout
android:layout_width="0dp"
android:layout_height="0dp"
android:id="@+id/right_border"
android:background="#0099ff"
app:layout_constraintLeft_toLeftOf="@id/right_guideline_view"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent">
<Button
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#0099ff" />
</FrameLayout>
<FrameLayout
android:layout_width="0dp"
android:layout_height="0dp"
android:id="@+id/middle"
android:paddingTop="8dp"
android:paddingBottom="8dp"
app:layout_constraintLeft_toLeftOf="@+id/left_guideline_view"
app:layout_constraintRight_toRightOf="@id/right_guideline_view"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toBottomOf="parent">
<Button
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/order_planter_message_shape" />
</FrameLayout>
<com.mikhaellopez.circularimageview.CircularImageView
android:layout_width="64dp"
android:layout_height="64dp"
android:id="@+id/image_view"
app:civ_border_color="#ffffff"
app:civ_border_width="1dp"
app:civ_shadow="false"
app:layout_constraintLeft_toLeftOf="@+id/left_guideline_image_view"
app:layout_constraintTop_toTopOf="@+id/top_guideline_image_view" />
<TextView
android:layout_width="0dp"
android:layout_height="0dp"
android:id="@+id/text_view_order"
android:text="# Trees"
android:fontFamily="@font/inter_semibold"
android:textSize="24sp"
android:textColor="#ffffff"
android:textAllCaps="false"
android:gravity="bottom|start"
app:layout_constraintLeft_toLeftOf="@+id/left_guideline_text_view"
app:layout_constraintRight_toRightOf="@+id/right_guideline_text_view"
app:layout_constraintTop_toTopOf="@+id/top_guideline_text_view_order"
app:layout_constraintBottom_toBottomOf="@+id/bottom_guideline_text_view_order"/>
<TextView
android:layout_width="0dp"
android:layout_height="0dp"
android:id="@+id/text_view_planter"
android:text="David Malan, $20"
android:fontFamily="@font/inter_regular"
android:textSize="18sp"
android:textColor="#ffffff"
android:textAllCaps="false"
android:gravity="bottom|start"
app:layout_constraintLeft_toLeftOf="@+id/left_guideline_text_view"
app:layout_constraintRight_toRightOf="@+id/right_guideline_text_view"
app:layout_constraintTop_toTopOf="@+id/bottom_guideline_text_view_order"
app:layout_constraintBottom_toBottomOf="@+id/bottom_guideline_text_view_planter"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/mark_fulfilled_icon"
android:src="@drawable/ic_check_mark"
app:layout_constraintLeft_toLeftOf="@+id/left_guideline_mark_fulfilled_icon"
app:layout_constraintRight_toRightOf="@+id/right_guideline_mark_fulfilled_icon"
app:layout_constraintTop_toTopOf="@+id/top_guideline_icon"
app:layout_constraintBottom_toBottomOf="@+id/bottom_guideline_icon"/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/message_icon"
android:src="@drawable/ic_check_mark"
app:layout_constraintLeft_toLeftOf="@+id/left_guideline_message_icon"
app:layout_constraintRight_toRightOf="@+id/right_guideline_message_icon"
app:layout_constraintTop_toTopOf="@+id/top_guideline_icon"
app:layout_constraintBottom_toBottomOf="@+id/bottom_guideline_icon"/>
</androidx.constraintlayout.widget.ConstraintLayout>
这是我的 RecyclerView 适配器代码:
package com.example.treeapp;
import android.content.Intent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;
import com.mikhaellopez.circularimageview.CircularImageView;
import java.util.List;
public class DonorOrdersAdapter extends RecyclerView.Adapter<DonorOrdersAdapter.DonorOrdersViewHolder> {
public String email;
public static DownloadImageTask downloadImageTask;
public static class DonorOrdersViewHolder extends RecyclerView.ViewHolder {
public CircularImageView imageView;
public TextView orderTextView;
public TextView planterTextView;
public ImageView markFulfilledIcon;
public ImageView messageIcon;
DonorOrdersViewHolder(View view) {
super(view);
imageView = view.findViewById(R.id.image_view);
orderTextView = view.findViewById(R.id.text_view_order);
planterTextView = view.findViewById(R.id.text_view_planter);
markFulfilledIcon = view.findViewById(R.id.mark_fulfilled_icon);
messageIcon = view.findViewById(R.id.message_icon);
downloadImageTask = new DownloadImageTask(imageView);
}
}
DonorOrdersAdapter(String email) {
this.email = email;
}
List<Integer> orders = MainActivity.database.ordersDao().getOrdersByDonor(email);
@NonNull
@Override
public DonorOrdersViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.donor_order, parent, false);
return new DonorOrdersViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull DonorOrdersViewHolder holder, int position) {
final int current = orders.get(position);
final String planterEmail = MainActivity.database.ordersDao().getPlanter(current);
if (MainActivity.database.plantersDao().getImageUrl(planterEmail) != null) {
downloadImageTask.execute(MainActivity.database.plantersDao().getImageUrl(planterEmail));
}
holder.orderTextView.setText(MainActivity.database.ordersDao( ).getTrees(current) + " trees");
holder.planterTextView.setText(MainActivity.database.plantersDao().getName(planterEmail) + ", $" +
MainActivity.database.ordersDao().getPayment(current));
holder.markFulfilledIcon.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent fulfillIntent = new Intent(view.getContext(), ConfirmPaymentActivity.class);
fulfillIntent.putExtra("email", email);
fulfillIntent.putExtra("orderId", current);
view.getContext().startActivity(fulfillIntent);
}
});
holder.messageIcon.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent messageIntent = new Intent(view.getContext(), MessageActivity.class);
messageIntent.putExtra("email", email);
messageIntent.putExtra("peerEmail", planterEmail);
messageIntent.putExtra("archived", 0);
view.getContext().startActivity(messageIntent);
}
});
}
@Override
public int getItemCount() {
return orders.size();
}
}
我正在使用使用房间库的 SQLite 表。这是表格行的代码:
package com.example.treeapp;
import androidx.room.ColumnInfo;
import androidx.room.Entity;
import androidx.room.PrimaryKey;
@Entity(tableName = "Orders")
public class Order {
@PrimaryKey(autoGenerate = true)
public int id;
@ColumnInfo(name = "Donor")
public String donorEmail;
@ColumnInfo(name = "Planter")
public String planterEmail;
@ColumnInfo(name = "Trees")
public int trees;
@ColumnInfo(name = "Payment")
public int payment;
@ColumnInfo(name = "Fulfilled")
public int fulfilled;
}
这是数据访问对象的代码:
package com.example.treeapp;
import androidx.room.Dao;
import androidx.room.Query;
import java.util.List;
@Dao
public interface OrdersDao {
@Query("INSERT INTO Orders (Donor, Planter, Trees, Payment, Fulfilled) VALUES (:donorEmail, :planterEmail, :trees, :payment, 0)")
void create(String donorEmail, String planterEmail, int trees, int payment);
@Query("SELECT Donor FROM Orders WHERE id = :id")
String getDonor(int id);
@Query("SELECT Planter FROM Orders WHERE id = :id")
String getPlanter(int id);
@Query("SELECT Trees FROM Orders WHERE id = :id")
int getTrees(int id);
@Query("SELECT Payment FROM Orders WHERE id = :id")
int getPayment(int id);
@Query("SELECT Fulfilled FROM Orders WHERE id = :id")
int getFulfilled(int id);
@Query("UPDATE Orders SET Fulfilled = 1 WHERE id = :id")
void markFulfilled(int id);
@Query("SELECT id FROM Orders WHERE Donor = :donorEmail AND Fulfilled = 0")
List<Integer> getOrdersByDonor(String donorEmail);
@Query("SELECT id FROM Orders WHERE Planter = :planterEmail AND Fulfilled = 0")
List<Integer> getOrdersToPlanter(String planterEmail);
@Query("SELECT id FROM Orders WHERE Fulfilled = 0")
List<Integer> getUnfulfilledOrders();
}
这是我使用回收器 View 的 Activity 的代码:
package com.example.treeapp;
import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import android.os.Bundle;
public class DonorOrdersActivity extends AppCompatActivity {
private String email;
private RecyclerView recyclerView;
private RecyclerView.Adapter adapter;
private RecyclerView.LayoutManager layoutManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_donor_orders);
email = getIntent().getStringExtra("email");
recyclerView = findViewById(R.id.recycler_view);
adapter = new DonorOrdersAdapter(email);
layoutManager = new LinearLayoutManager(this);
recyclerView.setAdapter(adapter);
recyclerView.setLayoutManager(layoutManager);
}
}
如果有人能够弄清楚我的 RecyclerViews 出了什么问题,请告诉我。
最佳答案
如果你看到你的 logcat,你可以看到 E/RecyclerView: No adapter attached; skipping layout
.所以解决方案是改变这个:
recyclerView.setAdapter(adapter);
recyclerView.setLayoutManager(layoutManager);
对此:
recyclerView.setLayoutManager(layoutManager);
recyclerView.setAdapter(adapter);
关于android - 当编译器没有给出任何错误时,为什么 RecyclerView 不工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63549805/
我最近在/ drawable中添加了一些.gifs,以便可以将它们与按钮一起使用。这个工作正常(没有错误)。现在,当我重建/运行我的应用程序时,出现以下错误: Error: Gradle: Execu
Android 中有返回内部存储数据路径的方法吗? 我有 2 部 Android 智能手机(Samsung s2 和 s7 edge),我在其中安装了一个应用程序。我想使用位于这条路径中的 sqlit
这个问题在这里已经有了答案: What's the difference between "?android:" and "@android:" in an android layout xml f
我只想知道 android 开发手机、android 普通手机和 android root 手机之间的实际区别。 我们不能从实体店或除 android marketplace 以外的其他地方购买开发手
自Gradle更新以来,我正在努力使这个项目达到标准。这是一个团队项目,它使用的是android-apt插件。我已经进行了必要的语法更改(编译->实现和apt->注释处理器),但是编译器仍在告诉我存在
我是android和kotlin的新手,所以请原谅要解决的一个非常简单的问题! 我已经使用导航体系结构组件创建了一个基本应用程序,使用了底部的导航栏和三个导航选项。每个导航选项都指向一个专用片段,该片
我目前正在使用 Facebook official SDK for Android . 我现在正在使用高级示例应用程序,但我不知道如何让它获取应用程序墙/流/状态而不是登录的用户。 这可能吗?在那种情
我在下载文件时遇到问题, 我可以在模拟器中下载文件,但无法在手机上使用。我已经定义了上网和写入 SD 卡的权限。 我在服务器上有一个 doc 文件,如果用户单击下载。它下载文件。这在模拟器中工作正常但
这个问题在这里已经有了答案: What is the difference between gravity and layout_gravity in Android? (22 个答案) 关闭 9
任何人都可以告诉我什么是 android 缓存和应用程序缓存,因为当我们谈论缓存清理应用程序时,它的作用是,缓存清理概念是清理应用程序缓存还是像内存管理一样主存储、RAM、缓存是不同的并且据我所知,缓
假设应用程序 Foo 和 Eggs 在同一台 Android 设备上。任一应用程序都可以获取设备上所有应用程序的列表。一个应用程序是否有可能知道另一个应用程序是否已经运行以及运行了多长时间? 最佳答案
我有点困惑,我只看到了从 android 到 pc 或者从 android 到 pc 的例子。我需要制作一个从两部手机 (android) 连接的 android 应用程序进行视频聊天。我在想,我知道
用于使用 Android 以编程方式锁定屏幕。我从 Stackoverflow 之前关于此的问题中得到了一些好主意,并且我做得很好,但是当我运行该代码时,没有异常和错误。而且,屏幕没有锁定。请在这段代
文档说: android:layout_alignParentStart If true, makes the start edge of this view match the start edge
我不知道这两个属性和高度之间的区别。 以一个TextView为例,如果我将它的layout_width设置为wrap_content,并将它的width设置为50 dip,会发生什么情况? 最佳答案
这两个属性有什么关系?如果我有 android:noHistory="true",那么有 android:finishOnTaskLaunch="true" 有什么意义吗? 最佳答案 假设您的应用中有
我是新手,正在尝试理解以下 XML 代码: 查看 developer.android.com 上的文档,它说“starStyle”是 R.attr 中的常量, public static final
在下面的代码中,为什么当我设置时单选按钮的外观会发生变化 android:layout_width="fill_parent" 和 android:width="fill_parent" 我说的是
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 9
假设我有一个函数 fun myFunction(name:String, email:String){},当我调用这个函数时 myFunction('Ali', 'ali@test.com ') 如何
我是一名优秀的程序员,十分优秀!