Проблема с добавлением фрагмента карты поддержки Google в режиме просмотра Android

Я использую фрагмент карты Google для отображения карты в представлении Android Recycle, я использую этот код для грамматического отображения карты Google

        SupportMapFragment supportMapFragment =  
SupportMapFragment.newInstance();
        supportFragment.beginTransaction().replace(R.id.map_container, 
supportMapFragment).commit(); 

но проблема в том, что она отображает карту только в первом элементе структуры фрейма контейнера карты в представлении переработчика, но не во всех, и если я прокручиваю в представлении переработчика, то первый элемент также исчезает, для целей тестирования я пытался изменить фоновый ресурс контейнера карты и это работает на всех элементах, но как я могу показать фрагмент карты во всех элементах

адаптер

public class PrivateDialogMessagesAdapter extends BaseDialogMessagesAdapter implements OnMapReadyCallback {

private static int EMPTY_POSITION = -1;

Context context;

GoogleMap map;

FragmentManager supportFragment;

private int lastRequestPosition = EMPTY_POSITION;
private int lastInfoRequestPosition = EMPTY_POSITION;
private FriendOperationListener friendOperationListener;

public PrivateDialogMessagesAdapter(
        BaseActivity baseActivity,
        FriendOperationListener friendOperationListener,
        List<CombinationMessage> objectsList,
        ChatUIHelperListener chatUIHelperListener,
        Dialog dialog,
        Context context,
        FragmentManager fragmentManager) {
    super(baseActivity, objectsList);
    this.friendOperationListener = friendOperationListener;
    this.chatUIHelperListener = chatUIHelperListener;
    this.dialog = dialog;
    this.context = context;
    this.supportFragment = fragmentManager;
}


@Override
public PrivateDialogMessagesAdapter.ViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {
    switch (viewType) {
        case TYPE_REQUEST_MESSAGE:
            return new ViewHolder(this, layoutInflater.inflate(R.layout.item_friends_notification_message, viewGroup, false));
        case TYPE_OWN_MESSAGE:
            // MapFragment mapFragment = (MapFragment) ((Activity)context).getFragmentManager().findFragmentById(R.id.location_message_own);
            //mapFragment.getMapAsync(this);
            return new ViewHolder(this, layoutInflater.inflate(R.layout.item_message_own, viewGroup, false));
        case TYPE_OPPONENT_MESSAGE:
            return new ViewHolder(this, layoutInflater.inflate(R.layout.item_private_message_opponent, viewGroup, false));
        default:
            return null;
    }
}


@Override
public void onBindViewHolder(BaseClickListenerViewHolder<CombinationMessage> baseClickListenerViewHolder, int position) {
    CombinationMessage combinationMessage = getItem(position);
    boolean ownMessage = !combinationMessage.isIncoming(currentUser.getId());

    ViewHolder viewHolder = (ViewHolder) baseClickListenerViewHolder;
    boolean friendsRequestMessage = DialogNotification.Type.FRIENDS_REQUEST.equals(
            combinationMessage.getNotificationType());
    boolean friendsInfoRequestMessage = combinationMessage
            .getNotificationType() != null && !friendsRequestMessage;

    if (viewHolder.verticalProgressBar != null) {
        viewHolder.verticalProgressBar.setProgressDrawable(baseActivity.getResources().getDrawable(R.drawable.vertical_progressbar));
    }

    if (friendsRequestMessage) {
        viewHolder.messageTextView.setText(combinationMessage.getBody());
        viewHolder.timeTextMessageTextView.setText(DateUtils.formatDateSimpleTime(combinationMessage.getCreatedDate()));

        setVisibilityFriendsActions(viewHolder, View.GONE);
    } else if (friendsInfoRequestMessage) {
        viewHolder.messageTextView.setText(combinationMessage.getBody());
        viewHolder.timeTextMessageTextView.setText(DateUtils.formatDateSimpleTime(combinationMessage.getCreatedDate()));

        setVisibilityFriendsActions(viewHolder, View.GONE);

        lastInfoRequestPosition = position;
    } else if (combinationMessage.getAttachment() != null) {
        resetUI(viewHolder);

        setViewVisibility(viewHolder.progressRelativeLayout, View.VISIBLE);
        viewHolder.timeAttachMessageTextView.setText(DateUtils.formatDateSimpleTime(combinationMessage.getCreatedDate()));

        if (ownMessage && combinationMessage.getState() != null) {
            setMessageStatus(viewHolder.attachDeliveryStatusImageView, State.DELIVERED.equals(
                    combinationMessage.getState()), State.READ.equals(combinationMessage.getState()));
        }

        displayAttachImageById(combinationMessage.getAttachment().getAttachmentId(), viewHolder);
    } else if (combinationMessage.getBody().toString().equals("no")) {
        resetUI(viewHolder);
        setViewVisibility(viewHolder.ownLocationMessageContainer, View.VISIBLE);
        viewHolder.ownLocationMessageContainer.setBackgroundColor(context.getResources().getColor(R.color.main_color));

        SupportMapFragment supportMapFragment =  SupportMapFragment.newInstance();
        supportFragment.beginTransaction().replace(R.id.map_container, supportMapFragment).commit();

    } else {
        resetUI(viewHolder);

        setViewVisibility(viewHolder.textMessageView, View.VISIBLE);
        viewHolder.messageTextView.setText(combinationMessage.getBody());
        viewHolder.timeTextMessageTextView.setText(DateUtils.formatDateSimpleTime(combinationMessage.getCreatedDate()));

        if (ownMessage && combinationMessage.getState() != null) {
            setMessageStatus(viewHolder.messageDeliveryStatusImageView, State.DELIVERED.equals(
                    combinationMessage.getState()), State.READ.equals(combinationMessage.getState()));
        } else if (ownMessage && combinationMessage.getState() == null) {
            //viewHolder.messageDeliveryStatusImageView.setImageResource(android.R.color.transparent);
        }
    }


    if (!State.READ.equals(combinationMessage.getState()) && !ownMessage && baseActivity.isNetworkAvailable()) {
        combinationMessage.setState(State.READ);
        QBUpdateStatusMessageCommand.start(baseActivity, ChatUtils.createQBDialogFromLocalDialog(dataManager, dialog), combinationMessage, true);
    }

    // check if last messageCombination is request messageCombination
    boolean lastRequestMessage = (position == getAllItems().size() - 1 && friendsRequestMessage);
    if (lastRequestMessage) {
        findLastFriendsRequest();
    }

    // check if friend was rejected/deleted.
    if (lastRequestPosition != EMPTY_POSITION && lastRequestPosition < lastInfoRequestPosition) {
        lastRequestPosition = EMPTY_POSITION;
    } else if ((lastRequestPosition != EMPTY_POSITION && lastRequestPosition == position)) { // set visible friends actions
        setVisibilityFriendsActions(viewHolder, View.VISIBLE);
        initListeners(viewHolder, position, combinationMessage.getDialogOccupant().getUser().getUserId());
    }
}

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

public void clearLastRequestMessagePosition() {
    lastRequestPosition = EMPTY_POSITION;
}

public void findLastFriendsRequestMessagesPosition() {
    new FindLastFriendsRequestThread().run();
}

private void setVisibilityFriendsActions(ViewHolder viewHolder, int visibility) {
    setViewVisibility(viewHolder.acceptFriendImageView, visibility);
    setViewVisibility(viewHolder.dividerView, visibility);
    setViewVisibility(viewHolder.rejectFriendImageView, visibility);
}

private void initListeners(ViewHolder viewHolder, final int position, final int userId) {
    viewHolder.acceptFriendImageView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            friendOperationListener.onAcceptUserClicked(position, userId);
        }
    });

    viewHolder.rejectFriendImageView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            friendOperationListener.onRejectUserClicked(position, userId);
        }
    });
}

private void findLastFriendsRequest() {
    for (int i = 0; i < getAllItems().size(); i++) {
        findLastFriendsRequest(i, getAllItems().get(i));
    }
}

private void findLastFriendsRequest(int position, CombinationMessage combinationMessage) {
    boolean ownMessage;
    boolean friendsRequestMessage;
    boolean isFriend;

    if (combinationMessage.getNotificationType() != null) {
        ownMessage = !combinationMessage.isIncoming(currentUser.getId());
        friendsRequestMessage = DialogNotification.Type.FRIENDS_REQUEST.equals(
                combinationMessage.getNotificationType());

        if (friendsRequestMessage && !ownMessage) {
            isFriend = dataManager.getFriendDataManager().
                    getByUserId(combinationMessage.getDialogOccupant().getUser().getUserId()) != null;
            if (!isFriend) {
                lastRequestPosition = position;
            }
        }
    }
}

@Override
public void onMapReady(GoogleMap googleMap) {
    LatLng sydney = new LatLng(-33.867, 151.206);

    if (ActivityCompat.checkSelfPermission(context, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(context, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
        // TODO: Consider calling
        //    ActivityCompat#requestPermissions
        // here to request the missing permissions, and then overriding
        //   public void onRequestPermissionsResult(int requestCode, String[] permissions,
        //                                          int[] grantResults)
        // to handle the case where the user grants the permission. See the documentation
        // for ActivityCompat#requestPermissions for more details.
        return;
    }
    googleMap.setMyLocationEnabled(true);
    googleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(sydney, 13));

    googleMap.addMarker(new MarkerOptions()
            .title("Sydney")
            .snippet("The most populous city in Australia.")
            .position(sydney));
}

private class FindLastFriendsRequestThread extends Thread {

    @Override
    public void run() {
        findLastFriendsRequest();
    }
}
}

XML макет один

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:animateLayoutChanges="true"
android:orientation="horizontal"
android:padding="10dp">

<LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="right"
    android:orientation="vertical">

    <include layout="@layout/view_chat_progress_bars" />

    <include layout="@layout/view_chat_text_message_own" />

    <include layout="@layout/view_chat_attach_message_own" />

    <include layout="@layout/view_location_message_own" />

</LinearLayout>



</FrameLayout>

XML-макет два

<FrameLayout android:layout_height="100dp"
android:layout_width="100dp"
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/view_location_message_own"
android:background="@color/red">

<FrameLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/map_container" />


</FrameLayout>

1 ответ

Я наблюдаю только одно значение широты и долготы, которое вы применяете, и то, что вы применяете позицию элемента по getitem. он показывает, что будет загружена только ваша текущая позиция переработчика, что займет больше времени, чтобы загрузить все списки.

@Override

public int getItemViewType (int position) {

return getItemViewType(getItem(position));

}

так что попробуй это.

@Override

public int getItemViewType (int position) {

if (objectsList! = null && objectsList.size ()> 0) {

return objectsList.size();

}

еще {

  return null;

 }

}

Другие вопросы по тегам