java - 为什么我的 ListView 也显示按钮和编辑文本?

标签 java android android-layout

我的 ListView 显示所有组件。 但我只想显示消息。

这是它的样子的图片...

Loooks very messy The pic

TextView(消息来源)和按钮在下一条消息下方重复。如果我可以在没有 TextView 的情况下使用该功能,我认为会更好。我的意思是,如果该 ListView 直接从网址(谷歌电子表格)。

这是我的脚本。提前致谢

 <?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".Message">


    <TextView
        android:id="@+id/mesaj"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="7dp"
        android:layout_marginEnd="42dp"
        android:textColor="@android:color/white"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="@+id/listviewmes" />
    <EditText
        android:id="@+id/mesajtext"
        android:layout_width="298dp"
        android:layout_height="46dp"
        android:layout_marginStart="16dp"
        android:layout_marginBottom="16dp"
        android:hint="Mesajiniz..."
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toStartOf="@+id/sendbutton"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/mesaj"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="1.0" />

    <Button
        android:id="@+id/sendbutton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginEnd="7dp"
        app:layout_constraintBaseline_toBaselineOf="@+id/mesajtext"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/mesajtext"
        app:layout_constraintTop_toTopOf="parent"/>



    <ListView
        android:id="@+id/listviewmes"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/bck"
        android:theme="@style/ThemeOverlay.AppCompat.Light"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

    </ListView>

</android.support.constraint.ConstraintLayout>




public class Message extends AppCompatActivity {
FirebaseUser fuser;
FirebaseDatabase database;
FirebaseAuth mAuth;
EditText et;
TextView tv;
ProgressDialog pd;
ListView lview;
ListAdapter adaptery;




@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_message);
    database = FirebaseDatabase.getInstance();
    mAuth = FirebaseAuth.getInstance();

    Button sendbtn;
    Toolbar toolbar;


    sendbtn = findViewById(R.id.sendbutton);
    //tv = findViewById(R.id.mesaj);
    et = findViewById(R.id.mesajtext);
    lview = findViewById(R.id.listviewmes);
    getItems();



    sendbtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            addItemToSheet();
            et.getText().clear();

        }
    });
}`

`private void addItemToSheet() {
    final String mesaj = et.getText().toString();

    StringRequest stringRequest = new StringRequest(Request.Method.POST, "MY URL SEND TO GOOGLE SHEET",
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {


                }
            },

            new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {

                }
            }
    ) {
        @Override
        protected Map<String, String> getParams() {
            Map<String, String> parmas = new HashMap<>();
            parmas.put("action", "addItem");
            parmas.put("mesaj", mesaj);

            return parmas;
        }
    };
    int socketTimeOut = 50000;// u can change this .. here it is 50 seconds
    RetryPolicy retryPolicy = new DefaultRetryPolicy(socketTimeOut, 0, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT);
    stringRequest.setRetryPolicy(retryPolicy);

    RequestQueue queue = Volley.newRequestQueue(this);

    queue.add(stringRequest);
}


public void sendMessage(View v) {
    FirebaseUser user = mAuth.getCurrentUser();
    FirebaseDatabase database = FirebaseDatabase.getInstance();
    DatabaseReference myRef = database.getReference();
    UUID uuid = UUID.randomUUID();
    String stuuid = uuid.toString();
    String mesaj = et.getText().toString();


}

private void getItems() {

    pd = ProgressDialog.show(this, "Loading", "please wait", false, true);

    StringRequest stringRequest = new StringRequest(Request.Method.GET, "MY URL MESSAGES GET FROM GOOGLE SHEET",
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    parseItems(response);

                }

            },
            new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {

                }
            }
    );
    int socketTimeOut = 50000;// u can change this .. here it is 50 seconds

    RetryPolicy retryPolicy = new DefaultRetryPolicy(socketTimeOut, 0, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT);
    stringRequest.setRetryPolicy(retryPolicy);

    RequestQueue queue = Volley.newRequestQueue(this);

    queue.add(stringRequest);
}
private void parseItems(String jsonResposnce) {


    ArrayList<HashMap<String, String>> list = new ArrayList<>();
    ArrayList<String>Mesajlar=new ArrayList<String>();



    try {
        JSONObject jobj = new JSONObject(jsonResposnce);
        JSONArray jarray = jobj.getJSONArray("items");


        for (int i = 0; i < jarray.length(); i++) {

            JSONObject jo = jarray.getJSONObject(i);
            String mesaj = jo.getString("mesaj");


            HashMap<String, String> item = new HashMap<>();
            item.put("mesaj", mesaj);

            list.add(item);


        }
    } catch (JSONException e) {
        e.printStackTrace();
    }


    `adaptery = new SimpleAdapter(this,list,R.layout.activity_message,
            new String[]{"mesaj"},new int[]{R.id.mesaj, android.R.layout.simple_list_item_1,list});


    lview.setAdapter(adaptery);
    pd.dismiss();
}}

最佳答案

用户RecyclerView而不是ListView(ListView不释放内存,但RecyclerView是一个工作得更好的ListView),然后在适配器类中你有一个名为MyViewHolder的类,它扩展自RecyclerView.ViewHolder 在此类中,您将在要设置为 RecyclerView 的布局中拥有所有 View 在 Adapetr 类中,您有一个名为: onBindViewHolder 的函数,并具有 MyViewHolder 的输入,您可以在那里隐藏按钮

public void onBindViewHolder(@NonNull MyViewHolder myViewHolder, final int i)
        {
             if(condition)
                myViewHolder.button.setVisibilty(View.GONE); 
        }

这是 myViewHolder

public class MyViewHolder extends RecyclerView.ViewHolder
{
    TextView txt;
    Button btn;
    public MyViewHolder(View itemView)
    {
        super(itemView);
        txt= itemView.findViewById(R.id.txt);
        btn= itemView.findViewById(R.id.btn)
    }
}

我不知道为什么代码中每一行都有一个按钮和一个 EditText ,但是如果 EditText 来自 URL 和用于确认操作的按钮(从 URL 加载数据),则不需要将它们添加到您的代码中列表布局!您应该在 Activity 上方添加一个按钮和一个 EditText,并在它们下方设置一个 RecyclerView

关于java - 为什么我的 ListView 也显示按钮和编辑文本?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56382037/

相关文章:

java - 字符串变量的哈希码唯一性

java - 以单例模式创建对象时,引用返回什么

java - 我们可以使用类型名称作为变量吗

android - 如何在 Fragment - Android 中使用 PlaceAutoCompleteFragment 小部件?

java - GWT 中的单元表

java - 在哪里可以找到关于 http ://www. alibaba.com api 的英文信息?

android - 何时取消订阅

Android 自签名客户端 CA 证书认证失败

android - 在android中,如何在类文件中以编程方式设置抽屉导航标题图像和名称?

android - "Must supply height attribute"错误