XML : Settext to TextView in fragment

I have followed this tutorial for make a swipe UI. So i have maked a similar version. Here is my code :

  import android.os.Bundle;  import android.support.design.widget.TabLayout;  import android.support.v4.app.Fragment;  import android.support.v4.app.FragmentManager;  import android.support.v4.app.FragmentPagerAdapter;  import android.support.v4.view.ViewPager;  import android.support.v7.app.AppCompatActivity;  import android.support.v7.widget.Toolbar;  import android.view.Menu;  import android.view.MenuItem;  import android.widget.TextView;  import java.util.ArrayList;  import java.util.List;      public class MainActivity extends AppCompatActivity {    private Toolbar toolbar;  private TabLayout tabLayout;  public static ViewPager viewPager;    @Override  protected void onCreate(Bundle savedInstanceState) {      super.onCreate(savedInstanceState);      setContentView(R.layout.activity_main);        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);      setSupportActionBar(toolbar);        getSupportActionBar().setDisplayHomeAsUpEnabled(true);        viewPager = (ViewPager) findViewById(R.id.viewpager);      setupViewPager(viewPager);          tabLayout = (TabLayout) findViewById(R.id.tabs);      tabLayout.setupWithViewPager(viewPager);    }    private void setupViewPager(ViewPager viewPager) {      ViewPagerAdapter adapter = new ViewPagerAdapter(getSupportFragmentManager());      adapter.addFragment(new OneFragment(), "ONE");      adapter.addFragment(new TwoFragment(), "TWO");      viewPager.setAdapter(adapter);  }      public class ViewPagerAdapter extends FragmentPagerAdapter {      private final List<Fragment> mFragmentList = new ArrayList<>();      private final List<String> mFragmentTitleList = new ArrayList<>();      private TextView xx = (TextView)findViewById(R.id.txt1);      public ViewPagerAdapter(FragmentManager manager) {          super(manager);      }        @Override      public Fragment getItem(int position) {          return mFragmentList.get(position);      }        @Override      public int getCount() {          return mFragmentList.size();      }        public void addFragment(Fragment fragment, String title) {          mFragmentList.add(fragment);          mFragmentTitleList.add(title);          }        @Override      public CharSequence getPageTitle(int position) {          return mFragmentTitleList.get(position);      }  }    @Override  public boolean onCreateOptionsMenu(Menu menu) {      // Inflate the menu; this adds items to the action bar if it is present.      getMenuInflater().inflate(R.menu.menu_main, menu);      return true;  }    @Override  public boolean onOptionsItemSelected(MenuItem item) {      // Handle action bar item clicks here. The action bar will      // automatically handle clicks on the Home/Up button, so long      // as you specify a parent activity in AndroidManifest.xml.      int id = item.getItemId();        //noinspection SimplifiableIfStatement      if (id == R.id.action_settings) {          return true;      }        return super.onOptionsItemSelected(item);  }     }    

Here are My two Fragment Classes ;

  import android.os.Bundle;  import android.support.v4.app.Fragment;  import android.view.LayoutInflater;  import android.view.View;  import android.view.ViewGroup;    public class OneFragment extends Fragment{  public OneFragment() {  }    @Override  public void onCreate(Bundle savedInstanceState) {      super.onCreate(savedInstanceState);  }    @Override  public View onCreateView(LayoutInflater inflater, ViewGroup container,                           Bundle savedInstanceState) {      // Inflate the layout for this fragment      return inflater.inflate(R.layout.fragment_one, container, false);  }  }    

and

  import android.os.Bundle;  import android.support.v4.app.Fragment;  import android.view.LayoutInflater;  import android.view.View;  import android.view.ViewGroup;    public class TwoFragment extends Fragment{        public TwoFragment() {      // Required empty public constructor  }    @Override  public void onCreate(Bundle savedInstanceState) {      super.onCreate(savedInstanceState);  }    @Override  public View onCreateView(LayoutInflater inflater, ViewGroup container,                           Bundle savedInstanceState) {      // Inflate the layout for this fragment        return inflater.inflate(R.layout.fragment_two, container, false);  }    }    

this is the xml file of my Activity:

  <?xml version="1.0" encoding="utf-8"?>  <android.support.design.widget.CoordinatorLayout  xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:app="http://schemas.android.com/apk/res-auto"  xmlns:tools="http://schemas.android.com/tools"  android:layout_width="match_parent"  android:layout_height="match_parent"  android:fitsSystemWindows="true"  tools:context=".MainActivity">    <android.support.design.widget.AppBarLayout      android:layout_width="match_parent"      android:layout_height="wrap_content"      android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">        <android.support.v7.widget.Toolbar          android:id="@+id/toolbar"          android:layout_width="match_parent"          android:layout_height="?attr/actionBarSize"          android:background="?attr/colorPrimary"          app:layout_scrollFlags="scroll|enterAlways"          app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />        <android.support.design.widget.TabLayout          android:id="@+id/tabs"          android:layout_width="match_parent"          android:layout_height="wrap_content"          app:tabMode="fixed"          app:tabGravity="fill"/>  </android.support.design.widget.AppBarLayout>  <include layout="@layout/content_main" />    

And this is the XML files of the first fragment

  <?xml version="1.0" encoding="utf-8"?>  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:orientation="vertical" android:layout_width="match_parent"  android:layout_height="match_parent"  android:weightSum="1">    <TextView      android:layout_width="87dp"      android:layout_height="wrap_content"      android:text="@string/one"      android:textSize="40dp"      android:textStyle="bold"      android:layout_centerInParent="true"      android:layout_weight="0.03" />    <TextView      android:layout_width="133dp"      android:layout_height="wrap_content"      android:textAppearance="?android:attr/textAppearanceLarge"      android:id="@+id/txt1" />    

My question is how can i add text at the TextView that have txt1 as id? I have tried a lot of things but i have an Null Point Exception. I have read that i can't use a TextView (And other objects) as if it was located in a normal activity. Can someone help me?

No comments:

Post a Comment