Добавление просмотров программно в Android

1

Можно ли добавлять представления к другой компоновке, чем та, которая вызвана в 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 страницы

  • 0
    Вы должны надувать / создавать макеты страниц внутри ViewPager где-то в PagerAdapter , чтобы это было подходящим местом для добавления представлений в макет. В качестве альтернативы, вы можете ViewPager Fragment s в ViewPager , и, делая это, вы можете вносить изменения в макет в соответствующем классе Fragment .
  • 0
    @MH. Я думаю, что это медленно подталкивает меня в правильном направлении, но я все еще не смог заставить его работать. Похоже, у вас есть опыт в прошлом, можно ли привести пример?
Показать ещё 1 комментарий
Теги:
layout

2 ответа

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" (вы - голландцы?;)) Прямо под датой на странице:

Изображение 174551

Кстати, вы можете подумать о переходе на 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;
}
  • 0
    Я действительно ценю пример! Я думал, что это заставило меня идти по правильному пути, но все же не повезло. Я добавил больше информации в мой вопрос, включая мой код. Проблема с предоставленным примером заключается в том, что текстовое представление отображается на всех страницах, и страницы не используют макеты XML для каждой страницы, как я. Также я пытался этим утром в течение часа заставить Jakes ViewPagerIndicator работать ... хотя это выглядит намного лучше, я сдался, когда не смог заставить его работать, или даже импортировал проект в затмение
  • 0
    Мне жаль это слышать. Добавленный код проясняет некоторые вещи, поэтому, пожалуйста, смотрите редактирование в моем ответе. На заметку: если я правильно помню, вам нужно настроить Jake's ViewPagerIndicator как «Новый проект Android»> «Из существующего источника ...»; Вы не можете импортировать проект напрямую.
Показать ещё 1 комментарий
2

Вы должны добавить представление в основное представление, которое раздуто макет. Просто добавьте одну строку.

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);
  • 0
    Спасибо за ваш вклад @Karn, однако я сделал это, и это не имело никакого значения:

Ещё вопросы

Сообщество Overcoder
Наверх
Меню