2014-04-04 2 views
0

나는 내 질문에 어리 석게 보일지 모르지만 안드로이드에 익숙하지 않다.파편이 필요하며 어떻게 파편에 액세스해야합니까?

나는 이전에 앱을 만들기 시작했고 'Create new Android Activity'를 사용하여 대개 .java 및 .xml 파일을 만들었고 모든 것이 작동했습니다. 이제 'Create new Android Activity'를 사용할 때 업데이트 된 후 클래스로 .java가 생성되고 (이전에는 ActionBarActivity가 아니라 Activity로 확장됩니다.) fragment_nameofactivity.xml + 모든 것을 추가하여 내부 클래스 확장 Fragment처럼 작동하게합니다. ..

페이지에서 일부 ListView 표시를 사용했는데 조각이 없으면 모두 잘 작동하지만 조각이 도입되면 더 이상 findViewById (R.id.list_view)를 조각 할 수 없습니다.

내 질문은 단편 확장 클래스 내에 전체 기능을 배치해야합니까? 나는 시도했지만 작동하지 않았다 ... 아니면 내가 아직도 여기

코드는 ... 원래 수업 시간에 내 모든 기능을 작성하고 다음 어떻게 든 조각에서 목록보기에 액세스 할 :

public class PlayersActivity extends ActionBarActivity { 

PlayerDataDatabaseAdapter playerDataHelper; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_players); 

    if (savedInstanceState == null) { 
     getSupportFragmentManager().beginTransaction() 
       .add(R.id.container, new PlaceholderFragment()).commit(); 
    } 

    playerDataHelper = new PlayerDataDatabaseAdapter(this); 
    playerDataHelper.open(); 

    displayPlayersList(); 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 

    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.players, 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(); 
    if (id == R.id.action_settings) { 
     return true; 
    } 
    return super.onOptionsItemSelected(item); 
} 

/** 
* A placeholder fragment containing a simple view. 
*/ 
public static class PlaceholderFragment extends Fragment { 

    public PlaceholderFragment() { 
    } 

    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
      Bundle savedInstanceState) { 
     View rootView = inflater.inflate(R.layout.fragment_players, 
       container, false); 
     return rootView; 
    } 
} 

private void displayPlayersList() { 
    Cursor cursor = playerDataHelper.getAllPlayers(); 

    String [] columns = playerDataHelper.columnsToBind(); 

    int [] to = new int[] { 
      R.id.player_name, 
    }; 

    SimpleCursorAdapter dataAdapter = new SimpleCursorAdapter(this, R.layout.fragment_player_details, cursor, columns, to, 0); 

    ListView listView = (ListView) findViewById(R.id.players_list); 
    listView.setAdapter(dataAdapter); 

    listView.setOnItemClickListener(new OnItemClickListener(){ 

     @Override 
     public void onItemClick(AdapterView<?> listView, View view, int position, long id) { 
      Cursor cursor = (Cursor) listView.getItemAtPosition(position); 

      int player_id = cursor.getInt(cursor.getColumnIndexOrThrow("_id")); 

      Intent intent = new Intent(PlayersActivity.this, EditPlayerActivity.class); 
      intent.putExtra("PlayerId", player_id); 
      startActivity(intent);  
     } 
    }); 
} 

public void addNewPlayer(View view) { 
    Intent intent = new Intent(this, AddPlayerActivity.class); 
    startActivity(intent); 
} 
} 

Fragment_players.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" 
android:paddingBottom="@dimen/activity_vertical_margin" 
android:paddingLeft="@dimen/activity_horizontal_margin" 
android:paddingRight="@dimen/activity_horizontal_margin" 
android:paddingTop="@dimen/activity_vertical_margin" 
tools:context="uk.co.eximage.soccermum.PlayersActivity$PlaceholderFragment" > 

<TextView 
    android:id="@+id/textView1" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_centerHorizontal="true" 
    android:layout_alignParentTop="true" 
    android:text="@string/players" 
    android:textAppearance="?android:attr/textAppearanceLarge" /> 

<Button 
    android:id="@+id/button1" 
    style="?android:attr/buttonStyleSmall" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_centerHorizontal = "true" 
    android:layout_below="@+id/textView1" 
    android:onClick="addNewPlayer" 
    android:text="@string/add_player" /> 

<ListView 
    android:id="@+id/players_list" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_below="@+id/button1" 
    > 

</ListView> 

</RelativeLayout> 

activity_players.xml :

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:id="@+id/container" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
tools:context="uk.co.eximage.soccermum.PlayersActivity" 
tools:ignore="MergeRootFrame" /> 

이가 빵점을 반환 실행 플레이어를 얻으려고하는 줄의 lPointerException :

ListView listView = (ListView) findViewById(R.id.players_list); 

이 listView는 null입니다.

내가 뭘 잘못하고 있니?

마지막으로 조각이 필요한가요? 어쩌면 나는 그것들을 제거하고 페이지 당 하나의보기로 '오래된'방식으로해야 할까?

+1

아직 조각을 사용하지 않아도 조각은 사용할 필요가 없습니다. 당신은 "옛날 방식"의 일을 할 수 있습니다. 그들은 잘 작동 할 것입니다 ... –

+0

'Null Pointer Exception'은'ListView'가 여러분의'Fragment_players '에 속해 있다는 것입니다.xml' –

+0

조각을 가지고 작업한다면'findViewById' 전에'getView'를 호출해야합니다 : getView(). findViewById (...) – nikis

답변

2

당신은

ListView listView; 
@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
     Bundle savedInstanceState) { 
View rootView = inflater.inflate(R.layout.fragment_players, 
      container, false); 
listView = (ListView)rootView. findViewById(R.id.players_list); 
playerDataHelper = new PlayerDataDatabaseAdapter(getActivity()); 
playerDataHelper.open(); 
displayPlayersList(); 

조각

ListViewfragment_players.xml에 속하는 목록보기 iniaitlize해야합니다. 조각과 관련된 모든 코드는 onCreateView으로 이동하십시오.

편집 :

public static class PlaceholderFragment extends Fragment { 

public PlaceholderFragment() { 
} 

    ListView listView; 
    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container, 
     Bundle savedInstanceState) { 
    View rootView = inflater.inflate(R.layout.fragment_players, 
      container, false); 
    listView = (ListView)rootView. findViewById(R.id.players_list); 
    playerDataHelper = new PlayerDataDatabaseAdapter(getActivity()); 
    playerDataHelper.open(); 
    displayPlayersList(); 

    return rootView; 
} 
private void displayPlayersList() { 
Cursor cursor = playerDataHelper.getAllPlayers(); 

String [] columns = playerDataHelper.columnsToBind(); 

int [] to = new int[] { 
     R.id.player_name, 
}; 

SimpleCursorAdapter dataAdapter = new SimpleCursorAdapter(getActivity(), R.layout.fragment_player_details, cursor, columns, to, 0); 
listView.setAdapter(dataAdapter); 

listView.setOnItemClickListener(new OnItemClickListener(){ 

    @Override 
    public void onItemClick(AdapterView<?> listView, View view, int position, long id)  { 
     Cursor cursor = (Cursor) listView.getItemAtPosition(position); 

     int player_id = cursor.getInt(cursor.getColumnIndexOrThrow("_id")); 

     Intent intent = new Intent(getActivity(), EditPlayerActivity.class); 
     intent.putExtra("PlayerId", player_id); 
     startActivity(intent);  
    } 
}); 
} 
} 
+0

안녕하세요, 상세한 답변을 많이 주셔서 감사합니다. 나는 당신이 전체 코드를 편집하기 전에 당신의 초기 대답 이후에 알아 낸 것이지만 시간을내어 주셔서 감사합니다. 말할 필요도없이 지금 작동합니다. 고맙습니다! – RandomWhiteTrash

0

당신은 조각 rootView 에서 목록보기를 초기화해야 하나 당신은 조각의 onCreateView 내부 세계와 초기화하기 목록보기 선언 또는 세계적으로보기 rootView를 선언해야하고

으로 목록보기를 초기화해야
ListView listView = (ListView) rootView .findViewById(R.id.players_list); 
2

태블릿 폼 팩터를보다 잘 지원하기 위해 단편을 도입했습니다. 디스플레이를 다시 정렬 할 계획이 없다면 (예 : 쇼 목록 및 세부 정보보기) 조각이 필요 없으며 이전 방식으로 갈 수 있습니다.

+0

정보를 제공해 주셔서 감사합니다. 왜 조각이 필요한지 궁금합니다. :). 항상 존재하는 테이블의 세계 에서처럼 나는 그들을 사용하는 법을 더 잘 배웁니다. – RandomWhiteTrash

관련 문제