android - ConstraintLayout 内容形状在滚动时改变

标签 android json android-recyclerview android-constraintlayout

我使用 constarintLayout 作为我的 recycleView 的容器,并且我根据 json(检索到的数据)填充我的项目。

所以我在这里做了一些技巧,如果我检索到的 json 包含一个特定值,我必须让我的约束布局中的一些项目消失并调整其他项目的大小。

一切正常,但是当我向下滚动和向上滚动时,更改值回到我不需要的旧雕像。

例如: 这个标记的行有不同的自定义形状 enter image description here

当向下滚动并再次向上滚动时,该行丢失了修改后的形状: enter image description here

这是我的 constraintLayout.xml:

<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="wrap_content"
android:layout_marginLeft="5dp"
android:layout_marginRight="5dp"
android:layout_marginTop="20dp"
android:clickable="true"
android:focusable="true"
android:paddingLeft="5dp"
android:paddingRight="5dp"
android:paddingBottom="8dp"
android:paddingTop="8dp"
app:layout_constraintLeft_toRightOf="@+id/article_subtitle"
tools:layout_editor_absoluteY="27dp"
android:id="@+id/containerDetailsItem">


<TextView
    android:id="@+id/technicalName"
    style="@style/TextAppearance.AppCompat.Subhead"
    android:layout_width="141dp"
    android:layout_height="wrap_content"
    android:layout_marginRight="15dp"
    android:layout_marginTop="5dp"
    android:gravity="right"
    android:maxLines="1"
    android:paddingLeft="5dp"
    android:textColor="@color/white"
    android:textSize="@dimen/text_main"
    app:layout_constraintRight_toLeftOf="@+id/thumbnailLayout"
    app:layout_constraintTop_toTopOf="parent" />


<TextView
    android:id="@+id/technicalProfile"
    style="@style/TextAppearance.AppCompat.Body1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="4dp"
    android:layout_marginRight="4dp"
    android:layout_marginTop="30dp"
    android:background="@color/white"
    android:drawableRight="@drawable/account_circle"
    android:gravity="center"
    android:maxLines="1"
    android:text="الملف الشخصي"
    android:padding="4dp"
    android:textColor="@color/background"
    app:layout_constraintHorizontal_bias="1.0"
    app:layout_constraintHorizontal_weight=".1"
    app:layout_constraintLeft_toLeftOf="parent"
    app:layout_constraintRight_toLeftOf="@+id/technicalAge"
    app:layout_constraintTop_toTopOf="parent" />

<TextView
    android:id="@+id/technicalExperince"
    style="@style/TextAppearance.AppCompat.Body1"
    android:layout_width="137dp"
    android:layout_height="wrap_content"
    android:layout_marginRight="19dp"
    android:layout_marginTop="0dp"
    android:maxLines="1"
    android:textColor="@color/white"
    app:layout_constraintRight_toLeftOf="@+id/thumbnailLayout"
    app:layout_constraintTop_toBottomOf="@+id/technicalExperince" />

<TextView
    android:id="@+id/technicalAge"
    style="@style/TextAppearance.AppCompat.Body1"
    android:layout_width="139dp"
    android:layout_height="wrap_content"
    android:layout_marginBottom="2dp"
    android:layout_marginRight="17dp"
    android:layout_marginTop="2dp"
    android:foregroundGravity="right"
    android:gravity="right"
    android:maxLines="1"
    android:textColor="@color/white"
    app:layout_constraintBottom_toTopOf="@+id/technicalExperince"
    app:layout_constraintHorizontal_weight=".2"
    app:layout_constraintRight_toLeftOf="@+id/thumbnailLayout"
    app:layout_constraintTop_toBottomOf="@+id/technicalName"
    app:layout_constraintVertical_bias="0.0" />


<RelativeLayout
    android:id="@+id/thumbnailLayout"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="-36dp"
    android:layout_marginRight="-1dp"
    android:paddingBottom="5dp"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintRight_toRightOf="parent">

    <de.hdodenhof.circleimageview.CircleImageView
        android:id="@+id/thumbnail"
        android:layout_width="75dp"
        android:layout_height="75dp"
        android:layout_marginRight="5dp"
        android:layout_marginTop="0dp"
        android:background="@drawable/unselected"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</RelativeLayout>

这里是布局项目更改的示例:

 if (mCursor.getString(ArticleLoader.Query.TYPE).equals("2")) {
            holder.ageView.setTypeface(font);
            holder.ageView.setText("\uf0ce" + " office"  );
            holder.experinceView.setVisibility(View.GONE);
            holder.nameView.setTextSize(23);

            //holder.constraintView.setBackgroundColor(getResources().getColor(R.color.office_color));
        }
        if (mCursor.getString(ArticleLoader.Query.TYPE).equals("1")) {
            holder.ageView.setTypeface(font);
            holder.ageView.setText( "\uf19c" + " company"  );
            holder.experinceView.setVisibility(View.GONE);
            holder.nameView.setTextSize(23);
            //holder.constraintView.setBackgroundColor(getResources().getColor(R.color.company_color));
        }

因此,仅当检索到的名为 type 的数据等于特定值时,我才编辑此数据。

如果 type 不等于特定的 type 我让它以正常形状出现。

我的适配器:

    private class Adapter extends RecyclerView.Adapter<ViewHolder> {


        public Adapter(Cursor cursor) {
            mCursor = cursor;
        }

        @Override
        public long getItemId(int position) {
            mCursor.moveToPosition(position);
            return mCursor.getLong(ArticleLoader.Query._ID);
        }


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

            View view = getLayoutInflater().inflate(R.layout.list_item_profiles_vertical, parent, false);
            final ViewHolder vh = new ViewHolder(view);
            view.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    startActivity(new Intent(Intent.ACTION_VIEW,
                            ItemsContract.Items.buildItemUri(getItemId(vh.getAdapterPosition()))));
                    try {

                        int i = Integer.parseInt((String) mCursor.getString(ArticleLoader.Query.SERVER_ID));
                        Log.i(TAG, "bindViews: " + i);
                        i = i + 1;
                        Config.BASE_URL = new URL("http:/json/users?user=" + mCursor.getString(ArticleLoader.Query.SERVER_ID));
                        startService(new Intent(DisplaysActivity.this, CurrentService.class));
                        Log.i(TAG, "onCreateDisplay: "  + mCursor.getString(ArticleLoader.Query.SERVER_ID));
                        Log.i(TAG, "onClick: "  + Config.BASE_URL);
                    } catch (MalformedURLException e) {
                        e.printStackTrace();
                    }

                }
            });
            return vh;
        }

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

            holder.ageView.setTypeface(typeface);
            mCursor.moveToPosition(position);
            holder.nameView.setText(mCursor.getString(ArticleLoader.Query.NAME));
            if (mCursor.getString(ArticleLoader.Query.TYPE).equals("2")) {
                holder.profileIcon.setTypeface(font);
                holder.ageView.setTypeface(font);
                holder.ageView.setText("  مكتب" );
                holder.ageView.setTextSize(17);
                holder.profileIcon.setText("\uf0f7");
                holder.experinceView.setVisibility(View.GONE);
                holder.nameView.setTextSize(23);
                //holder.constraintView.setBackgroundColor(getResources().getColor(R.color.office_color));
            }
            if (mCursor.getString(ArticleLoader.Query.TYPE).equals("1")) {
                holder.profileIcon.setTypeface(font);
                holder.ageView.setTypeface(font);
                holder.ageView.setText(" شركة");
                holder.ageView.setTextSize(17);
                holder.profileIcon.setText("\uf0f7");
                holder.experinceView.setVisibility(View.GONE);
                holder.nameView.setTextSize(23);
                //holder.constraintView.setBackgroundColor(getResources().getColor(R.color.company_color));
            }
            if (mCursor.getString(ArticleLoader.Query.TYPE).equals("3")){
                holder.profileIcon.setVisibility(View.GONE);
                holder.ageView.setTypeface(typeface);
            }

            if (mCursor.getString(ArticleLoader.Query.TYPE).equals("3") && mCursor.getString(ArticleLoader.Query.STATUE).equals("1")){
                holder.ageView.setText(mCursor.getString(ArticleLoader.Query.AGE) + " سنة" + " / " + "متاح ");
            }else if(mCursor.getString(ArticleLoader.Query.TYPE).equals("3") && mCursor.getString(ArticleLoader.Query.STATUE).equals("0")){
                holder.ageView.setText(mCursor.getString(ArticleLoader.Query.AGE) + " سنة" + " / " + "غير متاح ");
            }else if (mCursor.getString(ArticleLoader.Query.TYPE).equals("3")){
                holder.ageView.setText(mCursor.getString(ArticleLoader.Query.AGE) + " سنة");
            }

//            holder.dateView.setText(DateUtils.getRelativeTimeSpanString(
//                    mCursor.getLong(ArticleLoader.Query.PUBLISHED_DATE),
//                    System.currentTimeMillis(), DateUtils.HOUR_IN_MILLIS,
//                    DateUtils.FORMAT_ABBREV_ALL).toString() + "قبل");
            holder.experinceView.setText(mCursor.getString(ArticleLoader.Query.EXPERINCE) + " سنوات خبرة" + " / " + mCursor.getString(ArticleLoader.Query.CITY));
            if (mCursor.getString(ArticleLoader.Query.THUMB_URL).length() > 5) {
                Picasso.with(getApplicationContext()).load(mCursor.getString(ArticleLoader.Query.THUMB_URL)).into(holder.thumbnailView);
            } else {
                Picasso.with(getApplicationContext()).load("http:logo.png").into(holder.thumbnailView);
            }


            holder.nameView.setTypeface(typeface);

            holder.experinceView.setTypeface(typeface);
            holder.technicalProfile.setTypeface(typeface);

        }

        @Override
        public int getItemCount() {
            if (mCursor.getCount() < 1){
                Toast.makeText(DisplaysActivity.this, "لا يوجد محتوى", Toast.LENGTH_SHORT).show();
            }
            return mCursor.getCount();
        }
    }

这工作正常但我的滚动问题,如果我向下滚动并再次向上滚动更改的项目效果消失了, 这是错误还是什么?

最佳答案

我认为问题出在您正在使消失的观点上。 View 被回收,假设设置了 View #12,以便将图像设置为 gone。我们还假设 #12 被回收以显示数据库中的不同行,并且该行要求图像可见或不可见 gone。 View #12 中的图像,因为它已被回收,所以仍然消失,除非您明确地使其可见。换句话说,循环 View 中的所有信息都保持不变,直到您更改它。这适用于数据和任何 View 属性。很容易记住更改数据而不是 View 属性。

如果 View 需要可见,我建议您添加代码以明确地使 View 可见。

用下面的开头两行试试你的 onBindViewHolder() 看看它是否有帮助:

holder.experinceView.setVisibility(View.VISIBLE);
holder.profileIcon.setVisibility(View.VISIBLE);

关于android - ConstraintLayout 内容形状在滚动时改变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43961363/

相关文章:

5.2 中带引号转义的 PHP Json 编码?

json - 尝试解析 JSON 数据以放入另一个 JSON url 来解析更多数据

json - 将 JSON 数据存储到变量中

android - 带有 StaggeredGridLayoutManager 的 RecyclerView,图像从 Glide 加载

java - 从中心项开始我的 RecyclerView 水平旋转木马

android - 将 Doclava 与 Ant 和 Android 一起使用

java - SharedPreferences 会覆盖其他值吗?

android - 如果内容高度高于显示,工具栏内的内容不会折叠/滚动

安卓兼容性 - micromax funbook

java - 如何在 Java 中更改字符串