40

ListPopupWindowを使用して、を介して文字列のリストを表示しようとしていますArrayAdapter(最終的には、これはより複雑なカスタムアダプターになります)。コードは以下のとおりです。スクリーンショットに示されているように、結果ListPopupWindowはコンテンツ幅がゼロであるかのように機能するように見えます。アイテムの適切な数が表示され、アイテムは引き続きクリック可能であり、クリックするとが正常に生成されるToastため、少なくともその数は適切に機能しています。

興味深いメモ:popup.setWidth(...)代わりにピクセル単位で幅を指定ListPopupWindow.WRAP_CONTENTすると、コンテンツの一部が表示されますが、これは非常に柔軟性がないようです。

ListPopupWindowコンテンツをラップするにはどうすればよいですか?

テストアクティビティ:

public class MainActivity extends Activity {

    private static final String[] STRINGS = {"Option1","Option2","Option3","Option4"};
    private View anchorView;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        getActionBar().setHomeButtonEnabled(true);
        setContentView(R.layout.activity_main);
        anchorView = findViewById(android.R.id.home);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                showPopup();
                return true;
        }
        return super.onOptionsItemSelected(item);
    }

    private void showPopup() {
        ListPopupWindow popup = new ListPopupWindow(this);
        popup.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, STRINGS));
        popup.setAnchorView(anchorView);
        popup.setWidth(ListPopupWindow.WRAP_CONTENT);
        popup.setOnItemClickListener(new OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                Toast.makeText(MainActivity.this, "Clicked item " + position, Toast.LENGTH_SHORT).show();
            }
        });
        popup.show();
    }
}

スクリーンショット:

ここに画像の説明を入力してください

4

9 に答える 9

62

アダプタコンテンツの幅を測定できます。

private int measureContentWidth(ListAdapter listAdapter) {
    ViewGroup mMeasureParent = null;
    int maxWidth = 0;
    View itemView = null;
    int itemType = 0;

    final ListAdapter adapter = listAdapter;
    final int widthMeasureSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);
    final int heightMeasureSpec = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED);
    final int count = adapter.getCount();
    for (int i = 0; i < count; i++) {
        final int positionType = adapter.getItemViewType(i);
        if (positionType != itemType) {
            itemType = positionType;
            itemView = null;
        }

        if (mMeasureParent == null) {
            mMeasureParent = new FrameLayout(mContext);
        }

        itemView = adapter.getView(i, itemView, mMeasureParent);
        itemView.measure(widthMeasureSpec, heightMeasureSpec);

        final int itemWidth = itemView.getMeasuredWidth();

        if (itemWidth > maxWidth) {
            maxWidth = itemWidth;
        }
    }

    return maxWidth;
}

そしてshowPopup()関数で:

 ArrayAdapter arrayAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, STRINGS);
    popup.setAdapter(arrayAdapter);
    popup.setAnchorView(anchorView);
    popup.setContentWidth(measureContentWidth(arrayAdapter));
于 2014-11-08T07:42:48.217 に答える
31

問題は、の実装にありListPopupWindowます。ソースコードを確認し、ポップアップウィンドウを使用するsetContentWidth(ListPopupWindow.WRAP_CONTENT)か、代わりにアンカービューの幅を使用するようにしました。setWidth(ListPopupWindow.WRAP_CONTENT)

于 2013-01-24T18:55:45.747 に答える
7

使用するのに最適なのはPopupMenuだと思います。例:

final PopupMenu popupMenu = new PopupMenu(mActivity, v);
popupMenu.getMenu().add("test");
popupMenu.setOnMenuItemClickListener(new OnMenuItemClickListener() {

    @Override
    public boolean onMenuItemClick(final MenuItem item) {
        return true;
    }
});
popupMenu.show();
于 2014-04-22T12:06:49.903 に答える
5

dimen.xmlファイルのディメンションを160dp程度に設定します。

<dimen name="overflow_width">160dp</dimen>

次に、getDimensionPixelSizeメソッドを使用してポップアップ幅を設定し、ピクセルに変換します。

int width = mContext.getResources().getDimensionPixelSize(R.dimen.overflow_width); 
mListPopupWindow.setWidth(width);

これにより、サイズ密度が独立した状態に保たれます。

于 2013-09-13T20:05:44.337 に答える
3

あなたの問題は、simple_list_item_1を使用しているArrayAdapterにあると思います。その要素のソースコードを見ると、次のプロパティがあります。

android:layout_width="match_parent"

ここでソースを見ると、同じ情報を使用して独自のnew_list_item_1.xmlを作成できますが、それをに変更してandroid:layout_width="wrap_content"、ArrayAdapterで使用できます。

于 2013-01-24T18:15:05.863 に答える
3

実際にanchorViewの親を取得し(実際のanchorViewは通常ボタンであるため)、そこから幅を基にすることができます。例えば:

popup.setWidth(((View)anchor.getParent()).getWidth()/2);

そうすれば、柔軟な幅を得ることができます。

于 2013-12-26T20:09:19.073 に答える
1

別の解決策は、アンカーとして使用するようにレイアウトxmlに0dpの高さビューを設定することです。

<View
    android:id="@+id/popup_anchor"
    android:layout_width="140dp"
    android:layout_height="0dp"/>

次に、show()メソッドを呼び出す前に、アンカービューを設定します。

listPopupWindow.setAnchorView(popupAnchor);
listPopupWindow.show();
于 2017-10-04T21:49:28.333 に答える
0

以下が役立ちます。

listPopupWindow.setWidth(400);
listPopupWindow.setHeight(ListPopupWindow.WRAP_CONTENT);
于 2017-06-02T10:51:36.913 に答える
0

これに対する私のアプローチ。

専用の幅と位置(高さ1 dp、必要に応じて幅)を使用して、アンカーとして機能するレイアウトを作成Viewします(動的、つまりConstraintLayoutsを使用する場合があります)。見えないようにします(android:visibility=View.INIVISIBLE)。

                <View
                    android:id="@+id/my_anchor"
                    android:layout_height="1dp"
                    android:layout_width="0dp"
                    app:layout_constraintTop_toBottomOf="@id/list_item_order_list_app_compat_image_button_gallery"
                    app:layout_constraintStart_toEndOf="@id/list_item_order_list_material_button_map"
                    app:layout_constraintEnd_toEndOf="parent"
                    android:visibility="invisible"
                    android:layout_marginStart="8dp"
                    android:layout_marginEnd="8dp"
                    />

でのこのビューへの参照viewAnchor(つまり、バインディングあり):

listPopupWindow.anchorView = binding.myAnchor

于 2021-01-06T12:07:36.510 に答える