質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.37%

Edit textで入力した文字列を遷移元のフラグメントに返したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 510

score 19

fragmentA内のListViewのitem(adapterのインスタンスを生成するときに引数として与えているもの)をタップするとfragmentBに遷移してコメントを入力するedit textの画面に遷移します。
fragmentA内のListViewに対してadapterのフィールド変数はitemだけではなくArrayList<String>もあります。遷移先のfragmentB内で入力したテキストをボタン押下後にアダプタ内のArrayList<String>に加え、ListViewに反映させたいです

onActivityResultをフラグメントAに作ればfragmentBから遷移元にデータを引き継げるかと思いましたが、fragmentAはオーバーライドできないようでした。
現在、どう手を付ければよいかわからない状態です

public class UploadRouteFragment extends Fragment implements OnMapReadyCallback, LocationListener,
        View.OnClickListener, CompoundButton.OnCheckedChangeListener, GoogleMap.OnMarkerClickListener {

途中省略

 public void onClick(View view) {
        switch (view.getId()) {
            case R.id.button:

                break;

            case R.id.button2:

                final BaseAdapter adapter = new EditListAdapter(getContext(), R.layout.list_items, mMarkerList, commentList);
                // ListViewにadapterをセット
                listView.setAdapter(adapter);
                //リストビューを押したら
                listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
                    @Override
                    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                        mEditWindowFragment=new EditWindowFragment();
                        FragmentTransaction transaction1=getActivity().getSupportFragmentManager().beginTransaction();
                        transaction1.add(R.id.frameLayout,mEditWindowFragment);
                        transaction1.commit();
                    }
                });
           }
public class EditWindowFragment extends Fragment {
    private EditText edit;
    private UploadRouteFragment mUpfragment;
    static String textComment;


    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        return inflater.inflate(R.layout.memo_add, container, false);
    }

    @Override
    public void onActivityCreated(@Nullable Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        edit=getActivity().findViewById(R.id.editText);
        Button button = getActivity().findViewById(R.id.editfinish);

        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                // エディットテキストのテキストを取得
             textComment = edit.getText().toString();

            }
        });

    }

}
public class EditListAdapter extends BaseAdapter {
    private LayoutInflater inflater;
    private int layoutID;
    private ArrayList<Marker> mMarkerList;
    private ArrayList<String> mBaseCommentList;


    static class ViewHolder {
        TextView text;
        TextView text2;
    }

    //コンストラクタ
    //context,itemLayoutIDというリスト要素の番号,アップロードするためのマーカーリスト,マップに対するコメント
    EditListAdapter(Context context, int itemLayoutId,
                    ArrayList<Marker> MarkerList, ArrayList<String> BaseCommentList){
        inflater = LayoutInflater.from(context);
        layoutID = itemLayoutId;
        mMarkerList= MarkerList;
        mBaseCommentList=BaseCommentList;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {

        ViewHolder holder;

        if (convertView == null) {
            convertView = inflater.inflate(layoutID, null);
            holder = new ViewHolder();
            holder.text = convertView.findViewById(R.id.text_view);
            holder.text2=convertView.findViewById(R.id.text_view2);
            convertView.setTag(holder);
        } else {
            holder = (ViewHolder) convertView.getTag();
        }
        holder.text.setText(mMarkerList.get(position).getTitle());

        return convertView;
    }


    @Override
    public int getCount() {
        return mMarkerList.size();
    }

    @Override
    public Object getItem(int position) {
        return position;
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • hoshi-takanori

    2020/02/08 14:50

    フラグメントはアクティビティではないので、onActivityResultは使えません。

    以下の記事のようにフラグメントBからアクティビティに結果を渡して、アクティビティ側でListViewのデータを更新するか、アクティブティからフラグメントAに結果を転送する必要があると思います。
    http://y-anz-m.blogspot.com/2012/06/fragment-activity.html

    キャンセル

回答 1

checkベストアンサー

0

サンプルになると良いのですが.
何処かに不具合があるかもしれないのは予めご了承ください.

MainActivity.java

import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.FragmentTransaction;

import android.content.Context;
import android.os.Bundle;
import android.view.*;
import android.widget.*;
import java.util.*;

class Item {
  long id;
  String fixed, comment;
}
class Adapter extends BaseAdapter {
  private class ViewHolder {
    TextView text1;
    TextView text2;
  }
  private LayoutInflater inflater;
  private List<Item> list = new ArrayList<>();
  Adapter(Context context, List<String> fixedData) {
    inflater = LayoutInflater.from(context);
    long id = 0;
    for(String data : fixedData) {
      Item item = new Item();
      item.id = id++;
      item.fixed = data;
      item.comment = "";
      list.add(item);
    }
  }
  void setComment(long id, String text) {
    Item item = getItem(id);
    if(item != null) {
      item.comment = text;
      notifyDataSetChanged();
    }
  }
  Item getItem(long id) {
    for(Item item : list) if(item.id == id) return item;
    return null;
  }
  @Override
  public int getCount() {
    return list.size();
  }
  @Override
  public Object getItem(int position) {
    return list.get(position);
  }
  @Override
  public long getItemId(int position) {
    return list.get(position).id;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder holder = null;
    if(convertView == null) {
      convertView = inflater.inflate(R.layout.list_item_layout, null);
      holder = new ViewHolder();
      holder.text1 = convertView.findViewById(R.id.text1);
      holder.text2 = convertView.findViewById(R.id.text2);
      convertView.setTag(holder);
    } else {
      holder = (ViewHolder)convertView.getTag();
    }
    holder.text1.setText(list.get(position).fixed);
    holder.text2.setText(list.get(position).comment);
    return convertView;
  }
};
public class MainActivity extends AppCompatActivity implements ListFragment.ListModel, ItemFragment.Regist {
  private Adapter adapter;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    adapter = new Adapter(this, Arrays.asList("AAA","BBB","CCC","DDD"));
    showListFragment();
  }
  void showListFragment() {
    FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
    transaction.replace(R.id.flagmentContainer, ListFragment.createInstance());
    transaction.commit();
  }
  void showItemFragment(long id, String fixed, String comment) {
    FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
    transaction.replace(R.id.flagmentContainer, ItemFragment.createInstance(id, fixed, comment));
    transaction.addToBackStack(null);
    transaction.commit();
  }
  @Override
  public ListAdapter getAdapter() {
    return adapter;
  }
  @Override
  public void onSelect(long id) {
    Item item = adapter.getItem(id);
    showItemFragment(id, item.fixed, item.comment);
  }
  @Override
  public void onRegist(long id, String text) {
    adapter.setComment(id, text);
    showListFragment();
  }
}


ListFragment.java

import android.content.Context;
import android.os.Bundle;
import android.view.*;
import android.widget.*;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;

public class ListFragment extends Fragment {
  static ListFragment createInstance() {
    return new ListFragment();
  }
  interface ListModel {
    ListAdapter getAdapter();
    void onSelect(long id);
  }
  private ListModel listModel;
  private ListView listView;
  @Nullable
  @Override
  public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    View v = inflater.inflate(R.layout.list_fragment, container, false);
    listView = v.findViewById(R.id.listView);
    listView.setAdapter(listModel.getAdapter());
    listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
      @Override
      public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        listModel.onSelect(id);
      }
    });
    return v;
  }
  @Override
  public void onAttach(Context context) {
    super.onAttach(context);
    if(context instanceof ListModel) {
      listModel = (ListModel)context;
    }
  }
}


ItemFragment.java

import android.content.Context;
import android.os.Bundle;
import android.view.*;
import android.widget.*;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;

public class ItemFragment extends Fragment {
  private static final String ARGS_ID = "id";
  private static final String ARGS_FIXED = "fixed";
  private static final String ARGS_COMMENT = "comment";
  static ItemFragment createInstance(long id, String fixed, String comment) {
    ItemFragment fragment = new ItemFragment();
    Bundle args = new Bundle();
    args.putLong(ARGS_ID, id);
    args.putString(ARGS_FIXED, fixed);
    args.putString(ARGS_COMMENT, comment);
    fragment.setArguments(args);
    return fragment;
  }
  interface Regist {
    void onRegist(long id, String text);
  }
  @Override
  public void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
  }
  private Regist regist;
  @Nullable
  @Override
  public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
    View v = inflater.inflate(R.layout.item_fragment, container, false);
    TextView fixed = v.findViewById(R.id.fixed);
    final EditText editText = v.findViewById(R.id.editText);
    Bundle args = getArguments();
    if(args != null) {
      fixed.setText(args.containsKey(ARGS_FIXED) ? args.getString(ARGS_FIXED) : "");
      editText.setText(args.containsKey(ARGS_COMMENT) ? args.getString(ARGS_COMMENT) : "");
    }
    Button button = v.findViewById(R.id.button);
    button.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        Bundle args = getArguments();
        if(args != null && args.containsKey(ARGS_ID)) {
          regist.onRegist(args.getLong(ARGS_ID), editText.getText().toString());
        }
      }
    });
    return v;
  }
  @Override
  public void onAttach(final Context context) {
    super.onAttach(context);
    if(context instanceof Regist) {
      regist = (Regist)context;
    }
  }
}


activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    tools:context=".MainActivity"
    android:orientation="horizontal"
    android:id="@+id/flagmentContainer"/>


list_fragment.xml

<?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">

    <ListView
        android:id="@+id/listView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</LinearLayout>


list_item_layout.xml

<?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">

    <TextView
        android:id="@+id/text1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
    <TextView
        android:id="@+id/text2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
</LinearLayout>


item_fragment.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:id="@+id/fixed"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="0"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"/>
    <EditText
        android:id="@+id/editText"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:ems="10"
        android:gravity="start|top"
        android:inputType="textMultiLine"
        app:layout_constraintTop_toBottomOf="@id/fixed"
        app:layout_constraintBottom_toTopOf="@id/button"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"/>
    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="0"
        android:text="Regist"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"/>
</androidx.constraintlayout.widget.ConstraintLayout>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/02/09 17:45

    ありがとうございます。サンプル通り実装しました。jimbeさんの場合アクティビティ内のonCreateでadapterの定義を行っていますが、私の場合、アクティビティはメニュータブの切り替え機能とフラグメントの入れ替えについてのみにしています。したがって、フラグメントにボタンを設置し、押したら
    adapter = new Adapter(this, Arrays.asList("AAA","BBB","CCC","DDD"));
    showListFragment();
    としました。しかし、
    listView.setAdapter(listModel.getAdapter());
    のgetAdapter()でNUllが起きてしまっています。
    listModelインタフェースはフラグメントに実装してしまうとgetAdapter()を参照できないのでしょうか?

    キャンセル

  • 2020/02/10 00:05

    どの部分をどう変えられたのかが分かり難いのですが, 「ボタンを設置」したというフラグメントは, 私のコードの ListFragment/ItemFragment より前に表示されているフラグメントでしょうか. そしてそのフラグメントにも listModel を実装されたのでしょうか.
    それ以外を変更されていないとしますと, ListFragment.listModel の実体は onAttach で渡された context = MainActivity で, 『「ボタンを設置」されたフラグメント』ではありません.
    フラグメントを渡すのであれば onAttach 以外の方法で渡す必要があります.

    ただ, あるフラグメントのデータを別のフラグメントが生成するというのはフラグメント間の関係が強すぎるように思います.
    フラグメントは画面の部品ですので表示のみに関わり, データやその他の部分をアクティビティが管理するほうが纏まりが良いのではないでしょうか.

    キャンセル

  • 2020/02/20 18:38

    jimbeさんのとおりフラグメントは部品であり、フラグメント間でのデータのやり取りはできるだけしないほうが良いと判断しました。そのため、リストのあるフラグメントからインテントを作り編集画面のアクティビティにとびSQLiteを用いてローカルデータベースにコメントを保存しました

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る