如何在带有 android 的视图寻呼机页面中使用滑动手势?

How to use swipe gesture in a view pager#39;s page with android?(如何在带有 android 的视图寻呼机页面中使用滑动手势?)
本文介绍了如何在带有 android 的视图寻呼机页面中使用滑动手势?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要在包含三个页面的应用程序中使用视图寻呼机.

I need to take a view pager in an application which consist of three pages.

我是 android view pager 的新手.

I am new to android view pager.

我在屏幕的后半部分有一个名为 TestSwipingView 的视图,在屏幕的上半部分有另一个视图.

I have one view named TestSwipingView in second half of the screen and another view for the top half of the screen.

如何仅将 TestSwipingView 配置为可滑动?

How do I configure only TestSwipingView as swipe-able?

推荐答案

我就是这样实现的.它也可能给你一些想法.

This is how I implemented it. It may give you some idea too.

第 1 步:在我的主要活动中,我制作了页面适配器并在 onCreate() 中调用它.

Step 1 : In my main activity, I have made my page adapter and called it in onCreate().

public class SomeActivity extends FragmentActivity {

    WebView mWebView;
    private boolean mFromDropdown = false;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.tutorial_activity);

        Window window = getWindow();
        DisplayMetrics metrics = getResources().getDisplayMetrics();
        window.setGravity(Gravity.CENTER);
        int width = (int) (metrics.widthPixels * 1);
        int height = (int) (metrics.heightPixels * .85);
        window.setLayout(width, height);

        mFromDropdown = getIntent().getBooleanExtra("fromDropdown", false);

        MyPagerAdapter adapter = new MyPagerAdapter();
        ViewPager myPager = (ViewPager) findViewById(R.id.pager);
        myPager.setAdapter(adapter);
        myPager.setCurrentItem(0);

    }

第 2 步:这是我的自定义适配器,用于您的示例:

Step2: This is my Custom Adapter for your example:

private class MyPagerAdapter extends PagerAdapter {
            public int getCount() {
                return 3;
            }

            public Object instantiateItem(ViewGroup container, int position) {
                LayoutInflater inflater = (LayoutInflater) container.getContext()
                        .getSystemService(Context.LAYOUT_INFLATER_SERVICE);

                // Using different layouts in the view pager instead of images.

                int resId = -1;

                       //Getting my layout's in my adapter. Three layouts defined.
                switch (position) {
                case 0:
                    resId = R.layout.tutorial1;
                    break;
                case 1:
                    resId = R.layout.tutorial2;
                    break;
                case 2:
                    resId = R.layout.tutorial3;
                    break;

                }

                View view = inflater.inflate(resId, container, false);
                ((ViewPager) container).addView(view, 0);
                return view;
            }

            @Override
            public void destroyItem(ViewGroup container, int position, Object object) {
                container.removeView((View) object);
            }

            @Override
            public boolean isViewFromObject(View view, Object object) {
                return view == object;
            }

        }

    }

第 3 步:我的布局:

Step 3 : My Layouts:

主布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#F3F3F4"
    android:orientation="vertical" >

    <RelativeLayout
        android:id="@+id/tutorial_actionbar"
        android:layout_width="match_parent"
        android:layout_height="48dp" >

        <TextView
            android:id="@+id/tutorial_header"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:gravity="center"
            android:paddingLeft="25dp"
            android:paddingRight="9dp"
            android:text="Your Text"
            android:textColor="#666666"
            android:textSize="16sp" />
    </RelativeLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"
        android:paddingLeft="9dp"
        android:paddingRight="9dp" >
    </android.support.v4.view.ViewPager>

</LinearLayout>

布局放置在 MainLayout 中的 ViewPager 中:

Layout to put inside the ViewPager in MainLayout:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/linearLayout"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="#F3F3F4"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#F3F3F4"
        android:orientation="vertical" >

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="vertical"
            android:padding="18dp" >

            <TextView
                android:id="@+id/tutorialText2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="#F3F3F4"
                android:text="title1_secondscreen"
                android:textColor="#666666"
                android:textSize="16sp"
                android:textStyle="bold" />

            <TextView
                android:id="@+id/tutorialText3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="#F3F3F4"
                android:text="header1_secondscreen"
                android:textColor="#666666"
                android:textSize="16sp" />
        </LinearLayout>

        <ImageView
            android:id="@+id/image2"
            android:layout_width="match_parent"
            android:layout_height="0dip"
            android:layout_weight="0.60"
            android:scaleType="centerInside"
            android:src="@drawable/page2" />

        <TextView
            android:id="@+id/tutorialText4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:background="#F3F3F4"
            android:padding="10dp"
            android:text="footer1_secondscreen"
            android:textColor="#666666"
            android:textSize="32sp" />
    </LinearLayout>

</RelativeLayout>

布局放置在 MainLayout 中的 ViewPager 中:

Layout to put inside the ViewPager in MainLayout:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/linearLayout"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="#F3F3F4"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#F3F3F4"
        android:orientation="vertical" >

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="vertical"
            android:padding="18dp" >

            <TextView
                android:id="@+id/tutorialText2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="#F3F3F4"
                android:text="title1_thirdscreen"
                android:textColor="#666666"
                android:textSize="16sp"
                android:textStyle="bold" />

            <TextView
                android:id="@+id/tutorialText3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="#F3F3F4"
                android:text="header1_thirdscreen"
                android:textColor="#666666"
                android:textSize="16sp" />

            <ImageView
                android:id="@+id/image1"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:scaleType="centerInside"
                android:src="@drawable/page3" />

          <!--   <TextView
                android:id="@+id/tutorialText4"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="#F3F3F4"
                android:text="@string/tutoril_text3"
                android:textColor="#666666"
                android:textSize="16sp" /> -->
        </LinearLayout>


    </LinearLayout>
    <TextView
                android:id="@+id/tutorialText5"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_centerHorizontal="true"
                android:background="#F3F3F4"
                android:gravity="center"
                android:padding="10dp"
                android:text="footer1_thirdscreen"
                android:textColor="#666666"
                android:textSize="32sp" />

</RelativeLayout>

希望这对你有帮助..:)..祝你好运..:)

Hope this helps you..:)..Good Luck..:)

这篇关于如何在带有 android 的视图寻呼机页面中使用滑动手势?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

How to target newer versions in .gitlab-ci.yml using auto devops (java 11 instead of 8 and Android 31 instead of 29)(如何在.gitlab-ci.yml中使用自动开发工具(Java 11而不是8,Android 31而不是29)瞄准较新的版本)
Android + coreLibraryDesugaring: which Java 11 APIs can I expect to work?(Android+core LibraryDesugering:我可以期待哪些Java 11API能够工作?)
How to render something in an if statement React Native(如何在If语句中呈现某些内容Reaction Native)
How can I sync two flatList scroll position in react native(如何在本机Reaction中同步两个平面列表滚动位置)
Using Firebase Firestore in offline only mode(在仅脱机模式下使用Firebase FiRestore)
Crash on Google Play Pre-Launch Report: java.lang.NoSuchMethodError(Google Play发布前崩溃报告:java.lang.NoSuchMethodError)