1

タイトルが少し曖昧だったらごめんなさい。

私はフリーランサーでアプリを開発していますが、テスト後の顧客からの苦情を除いて、ほぼ完成しています。

意味がある場合は、ダイアログの代わりにPopupWindowを使用して、コンテキスト設定を編集します。私はあまり具体的になりたくなく、アプリのコンセプトを明かしてしまうリスクを冒したくありません。これは、顧客があまり喜ばないことだと確信しています。

PopupWindowには、XMLから拡張されたレイアウトのコンテンツビューが提供されます。そのレイアウトには、いくつかのEditTextウィジェットがあります。問題は、これらのEditTextが、長押し時にテキスト/ IME選択、および切り取り/コピー/貼り付けのオプションを表示するデフォルトのコンテキストダイアログをトリガーしないことです。

TouchTriggerなどを取得しようとして同様の質問が表示されましたが、setBackgroundDrawable()がないと機能しません。これは、単純な新しいColorDrawable()で試しました。それでも機能しません。

OnLongPressListenerでシステムデフォルトの長押しダイアログをトリガーする簡単な方法はありますか、それとも自分で実装するために天国と地球を移動する必要がありますか?その場合は、フラグメントを作成してトランザクションで交換するだけだからです。私はそれがうまくいくことを知っています。

関連するコード:開始フラグメント内:

RulesDialog dialog;
PopupWindow window;

public void showAddRuleDialog(){
    dialog = new RulesDialog();

    View view = getView();

    window = new PopupWindow(dialog.initViews(this, null), view.getWidth(), view.getHeight(), true);

    window.setBackgroundDrawable(new ColorDrawable());

    dialog.setRulesDialogListener(new rulesDialogListener(){            

        @Override
        public void onSave(ViewHolder holder) {


            addRule(holder);

            window.dismiss();


        }

        @Override
        public void onCancel() {
            window.dismiss();

        }});

    int[] location = {0,0};
    view.getLocationOnScreen(location);



    window.showAtLocation(view, 0, location[0], location[1]);

RulesDialogの場合:

public class ViewHolder{
    public ViewHolder(View dialogView){
        name = (TextView) dialogView.findViewById(R.id.name);
        response = (TextView) dialogView.findViewById(R.id.response);

        senders = (TextView) dialogView.findViewById(R.id.senders);
        sendersAdd = (Button) dialogView.findViewById(R.id.sendersAdd);
        sendersEdit = (Button) dialogView.findViewById(R.id.sendersEdit);

        timeFrom = (TextView) dialogView.findViewById(R.id.from);
        timeFromEdit = (Button) dialogView.findViewById(R.id.timeBeforeEdit);
        timeTo = (TextView) dialogView.findViewById(R.id.to);
        timeToEdit = (Button) dialogView.findViewById(R.id.timeAfterEdit);

        keywords = (TextView) dialogView.findViewById(R.id.keywords);

        matchCase = (CheckBox) dialogView.findViewById(R.id.matchCase);
        matchAlone = (CheckBox) dialogView.findViewById(R.id.matchAlone);
        matchPlural = (CheckBox) dialogView.findViewById(R.id.matchPlural);

        cancel = (Button) dialogView.findViewById(R.id.cancel);
        save = (Button) dialogView.findViewById(R.id.save);


    }

    TextView name;
    TextView response;
    TextView senders;
    Button sendersAdd;
    Button sendersEdit;
    TextView timeFrom;
    Button timeFromEdit;
    TextView timeTo;
    Button timeToEdit;
    TextView keywords;

    CheckBox matchCase;
    CheckBox matchAlone;
    CheckBox matchPlural;

    Button cancel;
    Button save;


}

Activity activity;
ViewHolder holder;
Fragment fragment;



public View initViews(Fragment mFragment, Rule rule){
    fragment = mFragment;
    activity = fragment.getActivity();
    View dialogView = LayoutInflater.from(activity).inflate(R.layout.rules_dialog, null);

    holder = new ViewHolder(dialogView);

    final TextView senders = holder.senders;

    holder.sendersAdd.setOnClickListener(new OnClickListener(){

        @Override
        public void onClick(View v) {
            showContacts();
        }});

    holder.sendersEdit.setOnClickListener(new OnClickListener(){

        @Override
        public void onClick(View v) {
            editSenders(senders);

        }

    });

    final TextView timeFrom = holder.timeFrom;
    holder.timeFromEdit.setOnClickListener(new OnClickListener(){

        @Override
        public void onClick(View v) {
            showTimePickerDialog(timeFrom);             

        }

        });

    final TextView timeTo = holder.timeTo;
    holder.timeToEdit.setOnClickListener(new OnClickListener(){

        @Override
        public void onClick(View v) {
            showTimePickerDialog(timeTo);               

        }

        });


    holder.cancel.setOnClickListener(new OnClickListener(){

        @Override
        public void onClick(View v) {
            mListener.onCancel();

        }});        
    holder.save.setOnClickListener(new OnClickListener(){

        @Override
        public void onClick(View v) {
            mListener.onSave(holder);

        }});


    if(rule == null)
        rule = new Rule();


    holder.name.setText(rule.name);
    holder.response.setText(rule.response);

    holder.senders.setText(rule.senders.toString());
    holder.senders.setTag(rule.senders);                

    holder.keywords.setText(rule.keywords);

    holder.matchCase.setChecked(rule.matchCase);
    holder.matchAlone.setChecked(rule.matchAlone);
    holder.matchPlural.setChecked(rule.matchPlural);        

    holder.timeFrom.setTag(rule.timeFrom);                          
    holder.timeFrom.setText(Rules.formatTime(rule.timeFrom));

    holder.timeTo.setTag(rule.timeTo);
    holder.timeTo.setText(Rules.formatTime(rule.timeTo));

    return dialogView;
}
4

1 に答える 1

0

そこで、RulesDialog をフラグメントとして書き直そうとしましたが、うまくいきませんでした。Fragment Transactions が操作している Fragments から呼び出されたときに正しく動作するようにする際に問題がありました。

(これがフラグメントのポイントではないことはわかっています。今のところ、完全にモジュール化されたアプリを作成することを実際に目指しているわけではありません。顧客が満足する製品を作りたいだけです。)

代わりに RulesDialog を Activity として書き直し、呼び出し元のフラグメントから startActivityForResult() を使用することになりました。次に、編集したデータを setResult() で返します。それはすべてコンサートでうまく機能します。

于 2012-11-07T00:05:34.123 に答える