修复 Viewpager Android 视图
Fix Viewpager Android Views
我有 Android 带有选项卡式 viewpager 的应用程序请参阅 运行 应用程序的图像屏幕截图
http://i.stack.imgur.com/zhlKF.png
问题是我看到的是空白页面,而不是我的 xml 布局引用片段 类,
Viewpager支持的XML文件的正确写法是什么
这是 XML 布局代码
first1.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:text="HOLA MUNDO"/>
</RelativeLayout>
Frag1.java
package com.example.aliencomputing.kakamila;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Frag1 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.first1, container, false);
return view;
}
}
Frag2.java
package com.example.aliencomputing.kakamila;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Frag2 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.first2, container, false);
return view;
}
}
Frag3.java
package com.example.aliencomputing.kakamila;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Frag3 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.first3, container, false);
return view;
}
}
这是主要的 Activity 代码
MainActivity.java
package com.example.aliencomputing.kakamila;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.ViewPager;
import android.os.Bundle;
public class MainActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setAdapter(new ViewPagerAdapter(getSupportFragmentManager()));
}
}
和ViewPagerAdapter.java
package com.example.aliencomputing.kakamila;
import android.content.Context;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
public class ViewPagerAdapter extends FragmentPagerAdapter {
final int PAGE_COUNT = 3;
//TAB TITLES
private String tabtitles[]=new String[] {"Tab1", "Tab2", "Tab3"};
Context context;
public ViewPagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public int getCount() {
return PAGE_COUNT;
}
@Override
public Fragment getItem(int position) {
switch (position) {
case 0:
Frag1 frag1 = new Frag1();
return frag1;
case 1:
Frag2 frag2 = new Frag2();
return frag2;
case 2:
Frag3 frag3 = new Frag3();
return frag3;
}
return null;
}
@Override
public CharSequence getPageTitle(int position) {
return tabtitles[position];
}
}
来自您发布的 activity_main:您需要一个位于 viewpager 之外的视图组,并且需要使 pagertabstrip 的高度包裹内容。
我认为您发布的 java 代码是正确的。
你的 activity_main
布局有误,试试这个:
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.view.ViewPager
xmlns:android="schemas.android.com/apk/res/android"
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.PagerTabStrip
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="top"
/>
</android.support.v4.view.ViewPager>
你原文中的主要错误是:android:layout_height="match_parent"
我有 Android 带有选项卡式 viewpager 的应用程序请参阅 运行 应用程序的图像屏幕截图
http://i.stack.imgur.com/zhlKF.png
问题是我看到的是空白页面,而不是我的 xml 布局引用片段 类, Viewpager支持的XML文件的正确写法是什么 这是 XML 布局代码 first1.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:text="HOLA MUNDO"/>
</RelativeLayout>
Frag1.java
package com.example.aliencomputing.kakamila;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Frag1 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.first1, container, false);
return view;
}
}
Frag2.java
package com.example.aliencomputing.kakamila;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Frag2 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.first2, container, false);
return view;
}
}
Frag3.java
package com.example.aliencomputing.kakamila;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class Frag3 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.first3, container, false);
return view;
}
}
这是主要的 Activity 代码 MainActivity.java
package com.example.aliencomputing.kakamila;
import android.support.v4.app.FragmentActivity;
import android.support.v4.view.ViewPager;
import android.os.Bundle;
public class MainActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewPager viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setAdapter(new ViewPagerAdapter(getSupportFragmentManager()));
}
}
和ViewPagerAdapter.java
package com.example.aliencomputing.kakamila;
import android.content.Context;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
public class ViewPagerAdapter extends FragmentPagerAdapter {
final int PAGE_COUNT = 3;
//TAB TITLES
private String tabtitles[]=new String[] {"Tab1", "Tab2", "Tab3"};
Context context;
public ViewPagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public int getCount() {
return PAGE_COUNT;
}
@Override
public Fragment getItem(int position) {
switch (position) {
case 0:
Frag1 frag1 = new Frag1();
return frag1;
case 1:
Frag2 frag2 = new Frag2();
return frag2;
case 2:
Frag3 frag3 = new Frag3();
return frag3;
}
return null;
}
@Override
public CharSequence getPageTitle(int position) {
return tabtitles[position];
}
}
来自您发布的 activity_main:您需要一个位于 viewpager 之外的视图组,并且需要使 pagertabstrip 的高度包裹内容。
我认为您发布的 java 代码是正确的。
你的 activity_main
布局有误,试试这个:
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.view.ViewPager
xmlns:android="schemas.android.com/apk/res/android"
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.PagerTabStrip
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="top"
/>
</android.support.v4.view.ViewPager>
你原文中的主要错误是:android:layout_height="match_parent"