Получить позицию элемента в центре экрана при прокрутке HorizontalScrollview - PullRequest
0 голосов
/ 28 сентября 2018

Я динамически загрузил несколько (1000) изображений внутри HorizontalcsrollView.Пользователь может прокручивать HorizontalScrollView спереди и сзади.
Что мне нужно, так это найти позицию элемента в центре экрана при прокрутке.БЮР, я начинаю HorizontalScrollView с центра экрана и заканчиваю в центре.
Я пробовал с addOnScrollChangedListener из HorizontalScrollview, но Я не смог получить точное положениецентральный элемент.

Редактировать : Пытался получить положение х и левое положение при прокрутке, но всегда возвращать 0.
Обратите внимание, я установил отступ влево и вправона мой HorizontalScrollView.
Он всегда начинается с центра экрана и заканчивается в центре экрана.

horizontalScrollView1.setOnScrollChangeListener(new View.OnScrollChangeListener() {
    @Override
    public void onScrollChange(View v, int scrollX, int scrollY, int oldScrollX, int oldScrollY) {                      
        int x1 = horizontalScrollView1.getLeft();                          
        int getX=(int)horizontalScrollView1.getX();
    }
});

файл макета

<?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">

    <HorizontalScrollView
        android:id="@+id/horizontalScrollView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_gravity="center_horizontal"
        android:layout_marginBottom="15dp"
        android:fillViewport="true"
        android:scrollbars="none">

        <RelativeLayout
            android:id="@+id/layLandmarks"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content">

            <View
                android:id="@+id/viewWhite"
                android:layout_width="match_parent"
                android:layout_height="10dp"
                android:layout_centerInParent="true"
                android:background="@color/white" />

        </RelativeLayout>
    </HorizontalScrollView>
</RelativeLayout>

Файл класса:

ImageView iv;
RelativeLayout layLandmarks = (RelativeLayout) findViewById(R.id.layLandmarks);
FrameLayout.LayoutParams lp1 = new FrameLayout.LayoutParams(2000, FrameLayout.LayoutParams.WRAP_CONTENT);
layLandmarks.setLayoutParams(lp1);
JSONObject landmarks = jsonObject1.getString("landmarks");
JSONArray jsonArray1 = new JSONArray(landmarks);
for(int j = 0; j<jsonArray1.length();j++){
    JSONObject jsonObject2 = jsonArray1.getJSONObject(0);

    landmarkId = jsonObject2.getString("id");
    landmarkName = jsonObject2.getString("title");
    landmarkDesc = jsonObject2.getString("description");
    latitude = jsonObject2.getDouble("latitude");
    longitude = jsonObject2.getDouble("longitude");
    video_time = jsonObject2.getString("video_time_in_sec");
    //   Log.e("video_time_in_sec", video_time);
    landmarkIcon = jsonObject2.getString("image");
    iv = new ImageView(VideoPreviewWithRecycler.this);
    iv.setId(i);

    Picasso.with(VideoPreviewWithRecycler.this)
            .load(landmarkIcon)
            .resize(40, 45)
            .into(iv);
    params = new RelativeLayout.LayoutParams(40, 45);

    params.topMargin = 0;

    params.leftMargin = Integer.parseInt(video_time);
    params.addRule(RelativeLayout.RIGHT_OF, 0);

    layLandmarks.addView(iv, params);
}

Ответы [ 3 ]

0 голосов
/ 06 октября 2018

Вы можете использовать Recylerview примерно так:

mProductBrowserAdapter = new ProductsAdapterBrowser();
        mRcvLatestProducts.setNestedScrollingEnabled(true);
        mRcvLatestProducts.setHasFixedSize(false);
        StaggeredGridLayoutManager staggeredGridLayoutManager =
                new StaggeredGridLayoutManager(1, LinearLayoutManager.HORIZONTAL);
        mRcvLatestProducts.setLayoutManager(staggeredGridLayoutManager);
        mRcvLatestProducts.addItemDecoratiiiiion(new GridSpacingItemDecoration(1, 0, false));
        mRcvLatestProducts.setAdapter(mProductBrowserAdapter);

и просмотреть для адаптера:

  <android.support.v7.widget.AppCompatImageView
                android:id="@+id/item_product_image_imv"
                android:layout_width="160dp"
                android:layout_height="160dp"
                android:adjustViewBounds="true"
                android:background="@android:color/transparent"
                android:scaleType="fitCenter"
              />

Я рекомендую использовать Glide для загрузки изображения.

dependencies {
  implementation 'com.github.bumptech.glide:glide:4.8.0'
  annotationProcessor 'com.github.bumptech.glide:compiler:4.8.0'
}

https://github.com/bumptech/glide

0 голосов
/ 11 октября 2018

Вы можете использовать PagerSnapHelper с переработкой, это поможет вам вот так

   binding.rvPosts.setLayoutManager(layoutManager);
   SnapHelper snapHelper = new PagerSnapHelper();
   snapHelper.attachToRecyclerView(binding.rvPosts);
   binding.rvPosts.setHasFixedSize(true);
0 голосов
/ 04 октября 2018

Я динамически загрузил несколько (1000) изображений внутри горизонтальной прокрутки.Пользователь может прокручивать горизонтальную прокрутку спереди и сзади.Что мне нужно, так это найти позицию элемента в центре экрана при прокрутке.БЮР, я начинаю горизонтальную прокрутку из центра экрана и заканчиваю в центре.Я попытался с addOnScrollChangedListener от HorizontalScrollview, но не смог получить точное положение центрального элемента.

Вы не должны использовать horizontal scrollview для загрузки такого количества изображений, вызависание устройства, и ваше приложение перестанет отвечать.Scollviews предназначены для загрузки просто текстовых представлений или небольшого количества изображений с низким разрешением, таких как значки.Что вы должны сделать, это использовать Recycler вид и установить горизонтальную ориентацию.

 LinearLayoutManager listManager = new LinearLayoutManager( getActivity(),LinearLayoutManager.HORIZONTAL, false);
    horizontalRecyclerView.setHasFixedSize(false);
    horizontalRecyclerView.setLayoutManager(listManager);
    horizontalRecyclerView.setAdapter(new ContentFileterAdapter());

Затем вы можете добавить viewholder и adapter, которые содержат ваши изображения.Вы также должны использовать библиотеку кэширования, такую ​​как UIL , чтобы загрузить столько изображений

    public static class ViewHolder extends RecyclerView.ViewHolder {
            public ImageView mImageView;
            public ViewHolder(View itemView) {
                super(itemView);
                mImageView=itemView.findViewById(R.id.yourImageView);
            }
        }
private class ImagesAdapter extends RecyclerView.Adapter<ViewHolder>{
        private String[] mImagesPaths;
        public ImagesAdapter(String[] mImagesPaths){
            this.mImagesPaths = mImagesPaths;
          }
        @Override
        public ViewHolder onCreateViewHolder(ViewGroup container, int viewType) {

            return new ViewHolder(LayoutInflater.from(container.getContext()).inflate(R.layout.yourAdapterItemLayout, container, false));
        }

        @Override
        public int getItemViewType(int position) {

            return 0;
        }

        @Override
        public void onBindViewHolder(final ViewHolder holder, int position) {
ImageLoader.getInstance().displayImage(Uri.decode(mImagesPaths[position]), holder.mImageView);}

        @Override
        public int getItemCount() {
            return mImagesPaths.length;
        }
    }

А затем найти свой центр view или положение, которое вы просто называете LinearLayoutManager* 1020.*

int lastindex = listManager.findLastCompletelyVisibleItemPosition();
int firstindex = listManager.findFirstCompletelyVisibleItemPosition();

//The middle visible position
int centerindex = firstindex/2 + lastindex/2 + (firstindex%2 + lastindex%2)/2;

//The middle visible view
View   view=(View)listManager.findViewByPosition(centerindex );
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...