Emi*_*Adz 6 android android-fragments android-viewpager android-fragmentactivity
我正在开发一个ViewPager包含片段的活动(每次最多4个片段)TableLayout.所以基本上加载了4个表.这是用于将数据加载到Fragment以后附加到的代码ViewPager:
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
if (container == null) {
return null;
}
LinearLayout.LayoutParams layoutParams=new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
layoutParams.gravity=Gravity.CENTER_VERTICAL;
layoutParams.setMargins(10, 0, 0, 0);
fragmetLayout = (LinearLayout)inflater.inflate(R.layout.grid_fragment_layout, container, false);
table = (TableLayout) fragmetLayout.findViewById(R.id.tlGridTable);
llParameterContainer = (LinearLayout) fragmetLayout.findViewById(R.id.llParametersContainer);
tabName = (TextView) fragmetLayout.findViewById(R.id.tvTabName);
tabName.setText(tab.getTabName());
//tabName.setLayoutParams(layoutParams);
for (Parameter parameter : SGRaportManagerAppObj.getInstance().parametersRepository.getParametersRepository())
{
ImageView parameterPoint = new ImageView(getActivity());
parameterPoint.setImageResource(R.drawable.parameter_chosen_point);
parameterPoint.setPadding(10, 10, 10, 0);
parameterPoint.setLayoutParams(layoutParams);
llParameterContainer.addView(parameterPoint);
TextView parameterTextView = new TextView(getActivity());
parameterTextView.setText(parameter.getName()+":");
parameterTextView.setGravity(Gravity.CENTER);
parameterTextView.setTextColor(getResources().getColor(R.color.my_black));
parameterTextView.setPadding(5, 10, 3, 10);
parameterTextView.setLayoutParams(layoutParams);
llParameterContainer.addView(parameterTextView);
TextView parameterChosenValueTextView = new TextView(getActivity());
parameterChosenValueTextView.setText(parameter.getChosenValue());
parameterChosenValueTextView.setGravity(Gravity.CENTER);
parameterChosenValueTextView.setPadding(0, 10, 0, 10);
parameterChosenValueTextView.setLayoutParams(layoutParams);
parameterChosenValueTextView.setTextColor(getResources().getColor(R.color.my_black));
llParameterContainer.addView(parameterChosenValueTextView);
}
//table.setStretchAllColumns(true);
//table.setShrinkAllColumns(true);
TableRow tableRow = new TableRow(getActivity());
TableLayout.LayoutParams tableRowParams=new TableLayout.LayoutParams(TableLayout.LayoutParams.WRAP_CONTENT,TableLayout.LayoutParams.WRAP_CONTENT);
tableRowParams.setMargins(2, 0, 0, 0);
tableRow.setLayoutParams(tableRowParams);
Log.d(TAG, "TAB FROM FRAGMENT:"+tab.toString());
TableRow.LayoutParams tlparamsFirstColumn = new TableRow.LayoutParams(TableRow.LayoutParams.WRAP_CONTENT, TableRow.LayoutParams.WRAP_CONTENT);
tlparamsFirstColumn.setMargins(4, 0, 2, 0);
TableRow.LayoutParams tlparams = new TableRow.LayoutParams(TableRow.LayoutParams.WRAP_CONTENT, TableRow.LayoutParams.WRAP_CONTENT);
tlparams.setMargins(0, 0, 2, 0);
//The First row for the column names.
for (int i= 0; i < tab.getGrid().getGridColumnsList().size(); i++)
{
TextView tvName = new TextView(getActivity());
String columnName = tab.getGrid().getGridColumnsList().get(i).getGridColumnAlias();
tvName.setText(columnName);
Log.d(TAG, "COLUMN ALIAS FROM FRAGMENT: "+columnName);
if (i == 0)
{
tvName.setLayoutParams(tlparamsFirstColumn);
}
else
{
tvName.setLayoutParams(tlparams);
}
tvName.setGravity(Gravity.CENTER);
tvName.setTextColor(getResources().getColor(R.color.my_white));
tvName.setPadding(10, 10, 10, 10);
tvName.setBackgroundDrawable(getResources().getDrawable(R.drawable.grid_column_name_background));
tableRow.addView(tvName);
}
table.addView(tableRow);
for (int j = 0; j < tab.getGrid().getGridData().getNumRows(); j++)
{
TableRow newRow = new TableRow(getActivity());
TableLayout.LayoutParams insideRowParams=new TableLayout.LayoutParams(TableLayout.LayoutParams.WRAP_CONTENT,TableLayout.LayoutParams.WRAP_CONTENT);
tableRowParams.setMargins(0, 2, 0, 0);
for (int k = 0; k < tab.getGrid().getGridData().getNumCols(j); k++)
{
TextView tvName = new TextView(getActivity());
String columnName = tab.getGrid().getGridData().get(j, k);
tvName.setText(columnName);
if ( (j % 2) == 0)
{
tvName.setBackgroundDrawable(getResources().getDrawable(R.drawable.grid_first_row_background));
}
else
{
tvName.setBackgroundDrawable(getResources().getDrawable(R.drawable.grid_second_row_background));
}
if (k == 0)
{
tvName.setLayoutParams(tlparamsFirstColumn);
}
else
{
tvName.setLayoutParams(tlparams);
}
tvName.setGravity(Gravity.CENTER);
tvName.setTextColor(getResources().getColor(R.color.my_black));
tvName.setPadding(10, 10, 10, 10);
newRow.addView(tvName);
}
table.addView(newRow);
}
return fragmetLayout;
}
Run Code Online (Sandbox Code Playgroud)
更新:
我的ViewPagerActivity布局:
<?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" >
<TabHost
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_below="@+id/imageView3" >
<LinearLayout
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_weight="0"/>
<android.support.v4.view.ViewPager
android:id="@+id/pager"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="1" >
</android.support.v4.view.ViewPager>
<TabWidget
android:id="@android:id/tabs"
android:orientation="horizontal"
android:layout_gravity="center_horizontal"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
</TabHost>
<ImageView
android:id="@+id/imageView3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="-3dp"
android:background="@drawable/login_scr_top_bar"
android:contentDescription="@drawable/login_scr_top_bar" />
<TextView
android:id="@+id/tvReportName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="top|left"
android:paddingLeft="15dp"
android:paddingTop="13dp"
android:text="@string/report_tabs"
android:textColor="@color/my_black"
android:textSize="18sp"
android:textStyle="bold" />
<LinearLayout
android:id="@+id/llTabsButtonsContainer"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentLeft="true"
android:layout_alignParentRight="true"
android:gravity="center_horizontal"
android:orientation="horizontal"
android:paddingBottom="5dp"
android:paddingTop="5dp" >
</LinearLayout>
<TextView
android:id="@+id/tvReportTitle"
android:layout_width="wrap_content"
android:layout_height="20dp"
android:layout_alignBaseline="@+id/tvReportName"
android:layout_alignBottom="@+id/tvReportName"
android:layout_toLeftOf="@+id/bBackToParameters"
android:layout_toRightOf="@+id/tvReportName"
android:text="TextView"
android:textSize="18sp" />
<Button
android:id="@+id/bBackToParameters"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/tvReportTitle"
android:layout_marginRight="10dp"
android:layout_alignParentRight="true"
android:background="@drawable/button_back_to_parameters_selector"
android:clickable="true"
android:onClick="backToParametersButtonOnClick"
android:padding="3dp"
android:text="@string/back_to_parameters"
android:textColor="@color/my_white"
android:textStyle="bold" />
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
和我的GridFramgnet布局:
<?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:orientation="vertical" >
<LinearLayout
android:id="@+id/llParametersContainer"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
</LinearLayout>
<TextView
android:id="@+id/tvTabName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/my_black"
android:textStyle="bold"
android:textSize="18sp"
android:layout_marginLeft="10dp"
android:text="It a test string for report Name"/>
<ScrollView
android:id="@+id/layout"
android:layout_height="match_parent"
android:scrollbars="horizontal|vertical"
android:layout_width="match_parent"
android:layout_marginTop="5dip"
android:scrollbarStyle="outsideInset"
android:fillViewport="true">
<HorizontalScrollView
android:id="@+id/horizontalView"
android:layout_height="wrap_content"
android:scrollbars="horizontal|vertical"
android:layout_width="wrap_content"
android:layout_marginTop="5dip">
<TableLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/tlGridTable" >
</TableLayout>
</HorizontalScrollView>
</ScrollView>
</LinearLayout>
Run Code Online (Sandbox Code Playgroud)
问题 3这个Fragments加载大约需要10秒钟,因此用户在Activity实际加载之前会获得黑屏10秒钟.我怎么能避免呢?运行填充表格的所有过程AsyncTask将使我ViewPager Activity加载更快?甚至可以做到吗?
更新:
大部分时间都花费在填充/创建TableLayout.如果从服务器收到大量数据,则需要创建大量TextView的数据并将其设置为TableLayout.
更新#2:
嗯,我已经完全消除了这个问题,因为我了解我的需求(整个视图的水平和垂直滚动)我必须使用TableLayout,所以我需要等待这次加载它.但我需要找到一种方法来加载片段中的数据,至少在用户知道数据正在填充(显示适当Dialog)的情况下.我试图把一个对话框中onCreate的ViewPager我才开始片段的初始化,但由于某种原因没有显示,我只看到了黑屏,直到片段被加载.
请参阅上一个问题,因为我知道无法确定加载时间:
问题:
有没有办法创建一个ViewPager几乎为空的片段(每个片段只有一个单独的标题),将它们呈现给用户,然后,在活动已加载并可见(并且不显示黑屏)后,呈现Dialog和填充在所述片段虽然示出的对话框?
任何帮助,将不胜感激.
谢谢.
这对于 3 个 Fragment 需要大约 10 秒才能加载,因此用户在实际加载 Activity 之前会黑屏 10 秒。
原因是您在布局中使用的小部件数量加上Activity. 从你发布的内容来看,你有这样的事情:
可能的包装
ViewPager中Activity> -ViewPager- >至少一个ScrollView(如你说的垂直和水平滚动的东西) - >Linearlayout- > TableLayout - >的TableRow - >内容TableRow
那是 7 的深度(如果我没记错的话,支持片段框架还在中间插入了一些视图)。这对性能非常不利。您还有很多小部件(假设这些for循环最多运行 10 次迭代,否则它真的很糟糕)Fragment并考虑到第二个片段也将加载其视图,您可以看到这将再次成为性能受到打击。
发布您当前的布局以查看它们是否无法优化会很有帮助。
您可以对当前代码进行一些小的改进,但这不会帮助您像您应该的那样从 10 秒到最多 1 秒:
这段代码没有任何意义:
if (container == null) {
return null;
}
Run Code Online (Sandbox Code Playgroud)
我不知道这是做什么的:
SGRaportManagerAppObj.getInstance().parametersRepository.getParametersRepository()
Run Code Online (Sandbox Code Playgroud)
但看看你是否不创建无用的对象(那是单例吗?)。不要把它放在for循环中,因为它每次都会运行,使用正常for来避免使用Iterator:
final int count = SGRaportManagerAppObj.getInstance().parametersRepository.getParametersRepository().size();
for (int i = 0; i < count; i++) {
final Parameter parameter = SGRaportManagerAppObj.getInstance().parametersRepository.getParametersRepository().get(i);
// ... rest of code
Run Code Online (Sandbox Code Playgroud)
你应该在其他for循环中做同样的事情。
在for循环外检索这些资源(颜色和可绘制对象),在循环中仅将它们分配给视图。
编辑: 您的布局非常深且视图过多,因此性能会很差。解决这个问题的唯一方法是使用一个可回收其视图的小部件(我知道你说的是什么)。替代方案是:
onCreateView并返回结合显示加载ProgressDialog。在Fragment变得可见后,您将开始创建Fragment块的真实视图,最后将其附加到片段。这对用户体验来说是非常糟糕的。当您使用 a 时,ViewPager将有额外的工作来使页面切换之间的事情顺利进行。也许您可以重新考虑您当前的设置。
由于您使用寻呼机,因此当您启动活动时,您将加载更多内容,而不仅仅是第一个片段。使带有进度条的初始片段视图可见并且表格隐藏,并且仅当您切换到该片段时才加载数据。
在活动使用中
mPager.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int position) {
Fragment f = mAdapter.getFragment(mPager.getCurrentItem());
f.loadData(); // when you finish loading the data, hide the progress bar and show the table
}
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
Run Code Online (Sandbox Code Playgroud)
要使用 mAdapter.getFragment(),请从以下位置继承您的适配器:
public abstract class SmartFragmentPagerAdapter extends FragmentPagerAdapter{
private SparseArray<String> mFragmentTags;
private FragmentManager mFragmentManager;
public SmartFragmentPagerAdapter(FragmentManager fragmentManager) {
super(fragmentManager);
mFragmentManager = fragmentManager;
mFragmentTags = new SparseArray<String>();
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
Object obj = super.instantiateItem(container, position);
if (obj instanceof Fragment) {
// record the fragment tag here.
Fragment f = (Fragment) obj;
String tag = f.getTag();
mFragmentTags.put(position, tag);
}
return obj;
}
public Fragment getFragment(int position) {
String tag = mFragmentTags.get(position);
if (tag == null)
return null;
return mFragmentManager.findFragmentByTag(tag);
}
public FragmentManager getFragmentManager(){
return mFragmentManager;
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5946 次 |
| 最近记录: |