Можно ли добавлять представления к другой компоновке, чем та, которая вызвана в setContentView() в OnCreate()?
Я пытаюсь использовать Zylincs ViewPager (находится по адресу http://www.zylinc.com/blog-reader/items/viewpager-page-indicator.html), и у меня есть эта настройка деталей и отлично работает.
Что это оставляет меня с 4 макета. 1 - main.xml, а остальные три - main_pg0.xml, main_pg1.xml и main_pg3.xml
Три страницы содержат содержимое каждой "страницы", где main.xml содержит средство просмотра страниц.
В onCreate im используется setContentView (main.xml).
То, что я пытаюсь сделать сейчас, - это возможность добавлять текстовые элементы программно к некоторым страницам.
Сейчас у меня есть:
LayoutInflater factory = getLayoutInflater();
View layout = factory.inflate(R.layout.main_pg0, null);
View linearLayout = layout.findViewById(R.id.linearLayout);
TextView valueTV = new TextView(this);
valueTV.setText("hallo hallo");
valueTV.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.WRAP_CONTENT));
((LinearLayout) linearLayout).addView(valueTV);
Это настолько, насколько мне удалось получить, что совсем не добавляет текстовое представление.
----РЕДАКТИРОВАТЬ----
Надеюсь уточнить немного больше, что я пытаюсь сделать Heres мой код
Main.java
public class Main extends FragmentActivity implements PageInfoProvider {
public GlobalVars globalVars;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
globalVars = (GlobalVars) getApplicationContext();
MyPagerAdapter adapter = new MyPagerAdapter();
ViewPager myPager = (ViewPager) findViewById(R.id.viewpager);
myPager.setAdapter(adapter);
myPager.setCurrentItem(0);
ViewPagerIndicator indicator = (ViewPagerIndicator) findViewById(R.id.indicator);
myPager.setOnPageChangeListener(indicator);
indicator.init(0, adapter.getCount(), this);
Resources res = getResources();
Drawable prev = res.getDrawable(R.drawable.indicator_prev_arrow);
Drawable next = res.getDrawable(R.drawable.indicator_next_arrow);
indicator.setArrows(prev, next);
}
private class MyPagerAdapter extends PagerAdapter {
public int getCount() {
return 3;
}
public Object instantiateItem(View collection, int position) {
LayoutInflater inflater = (LayoutInflater) collection.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
int resId = 0;
switch (position) {
case 0:
resId = R.layout.main_pg0;
LoadVehicles();
break;
case 1:
resId = R.layout.main_pg1;
break;
case 2:
resId = R.layout.main_pg2;
break;
}
View view = inflater.inflate(resId, null);
((ViewPager) collection).addView(view, 0);
return view;
}
@Override
public void destroyItem(View arg0, int arg1, Object arg2) {
((ViewPager) arg0).removeView((View) arg2);
}
@Override
public void finishUpdate(View arg0) {
// TODO Auto-generated method stub
}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == ((View) arg1);
}
@Override
public void restoreState(Parcelable arg0, ClassLoader arg1) {
// TODO Auto-generated method stub
}
@Override
public Parcelable saveState() {
// TODO Auto-generated method stub
return null;
}
@Override
public void startUpdate(View arg0) {
// TODO Auto-generated method stub
}
}
public String getTitle(int position) {
String title = "--Untitled--";
switch (position) {
case 0:
title = "Page 0";
break;
case 1:
title = "Page 1";
break;
case 2:
title = "Page 2";
break;
}
return title;
}
}
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<com.zylinc.view.ViewPagerIndicator
android:id="@+id/indicator"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#EAEAEA"
android:paddingBottom="8dp"
android:paddingLeft="5dp"
android:paddingRight="5dp"
android:paddingTop="8dp" />
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="#ffeaeaea" >
<View
android:layout_width="fill_parent"
android:layout_height="1dp"
android:layout_alignBottom="@+id/current"
android:background="#C5C5C5" />
<ImageView
android:id="@+id/current"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerInParent="true"
android:src="@drawable/indicator_current" />
</RelativeLayout>
<android.support.v4.view.ViewPager
android:id="@+android:id/viewpager"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
</LinearLayout>
main_pg0.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#FFFFFF"
android:orientation="vertical"
android:id="@+id/linearLayout" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="5dp"
android:text="main_pg0.xml"
android:textColor="#0C0C0C"
android:textSize="18sp" />
</LinearLayout>
То, что я пытаюсь сделать, это добавить текстовое представление программно в main_pg0.xml ТОЛЬКО, оставив только 2 страницы
Вы явно не ViewPager
, ViewPager
ли вы Fragment
в ViewPager
, но поскольку вы работаете с реализацией Zylinc, я собираюсь предположить, что вы есть. На самом деле, я просто использую предоставленный примерный код, чтобы показать вам эту идею.
Ключом к пониманию того, как вы понимаете, что вам нужно, является то, что страницы в ViewPager
являются автономными единицами в виде Fragment
s. Они многоразовые, имеют собственный жизненный цикл и могут обрабатывать свои собственные макеты. Следовательно, если вы хотите внести изменения в макет страницы, вы захотите сделать это внутри Fragment
, составляющих эти страницы.
Следующий метод можно найти в примере кода класса ItemFragment
. Я просто добавил TextView
из своего собственного фрагмента кода. Для демонстрационных целей я скрывал ListView
который использовался для заполнения всего пространства в date_fragment.xml
макета date_fragment.xml
.
@Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View v = inflater.inflate(R.layout.date_fragment, container, false);
View tv = v.findViewById(R.id.text);
((TextView)tv).setText(readableDateFormat.format(date));
// changes below
TextView valueTV = new TextView(getActivity());
valueTV.setText("hallo hallo");
valueTV.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.WRAP_CONTENT));
((ViewGroup)v).addView(valueTV);
return v;
}
Это даст вам текст "hallo hallo" (вы - голландцы?;)) Прямо под датой на странице:
Кстати, вы можете подумать о переходе на Jake ViewPagerIndicator
. Хотя я не очень внимательно смотрел на тот, который вы сейчас используете, Джейк выглядит более гибким для меня и чище работать. До вас, конечно.
Edit: Хорошо, поэтому вы фактически не используете фрагменты в ViewPager
, но скорее кормите его макетами. Это прекрасно, хотя, вероятно, с этим сложнее справится, когда страницы станут более сложными. В любом случае, ключ к изменению макетов страниц во время выполнения все равно должен делать это всякий раз, когда вы его создаете/раздуваете. При использовании фрагментов это было бы в переопределенном методе, как показано выше. В вашем случае, однако, вам нужно будет сделать это непосредственно в instantiateItem(...)
.
Я на самом деле не набирал это в среде IDE, поэтому, пожалуйста, учитывайте и незначительные синтаксические ошибки.
public Object instantiateItem(View collection, int position) {
LayoutInflater inflater = (LayoutInflater) collection.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = null;
switch (position) {
case 0:
view = inflater.inflate(R.layout.main_pg0, null);
TextView valueTV = new TextView(getActivity());
valueTV.setText("hallo hallo");
valueTV.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.WRAP_CONTENT));
((ViewGroup)view).addView(valueTV);
break;
case 1:
view = inflater.inflate(R.layout.main_pg1, null);
// or perhaps better for readability: build the layout in a different method, passing in the root
buildSecondPageLayout(view);
break;
case 2:
view = inflater.inflate(R.layout.main_pg2, null);
buildThirdPageLayout(view);
break;
}
return view;
}
ViewPagerIndicator
как «Новый проект Android»> «Из существующего источника ...»; Вы не можете импортировать проект напрямую.
Вы должны добавить представление в основное представление, которое раздуто макет. Просто добавьте одну строку.
LayoutInflater factory = getLayoutInflater();
View layout = factory.inflate(R.layout.main_pg0, null);
View linearLayout = layout.findViewById(R.id.linearLayout);
TextView valueTV = new TextView(this);
valueTV.setText("hallo hallo");
valueTV.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,LayoutParams.WRAP_CONTENT));
((LinearLayout) linearLayout).addView(valueTV);
layout.addView(linearLayout);
ViewPager
где-то вPagerAdapter
, чтобы это было подходящим местом для добавления представлений в макет. В качестве альтернативы, вы можетеViewPager
Fragment
s вViewPager
, и, делая это, вы можете вносить изменения в макет в соответствующем классеFragment
.