Код, который вы разместили, не подходит для ответа на ваш вопрос. Допустим, у вас есть 4 докладчика:
- MainPresenter
- HeaderPresenter
- NavigationPresenter
- Home Presenter
MainPresenter
будет содержать 3 других докладчиков. При обнаружении места (дома) происходит событие.
HomePresenter
код:
@Override
protected void revealInParent() {
// trigger the setInSlot of MainPageView
RevealContentEvent.fire(this, MainPagePresenter.TYPE_SetMainContent,
this);
}
Затем это событие обрабатывается setInSlot
из MainPageView
, который добавляет контент в один из слотов. Поэтому в MainPresenter
должно быть 3 слота со следующим кодом:
@ContentSlot
public static final Type<RevealContentHandler< ? >> TYPE_SetMainContent = new Type<RevealContentHandler< ? >>();
@ContentSlot
public static final Type<RevealContentHandler< ? >> TYPE_SetHeaderContent = new Type<RevealContentHandler< ? >>();
@ContentSlot
public static final Type<RevealContentHandler< ? >> TYPE_SetNavigationContent = new Type<RevealContentHandler< ? >>();
private boolean headerNavigationDisplayed = false;
@Inject
public MainPagePresenter(final EventBus eventBus, final MyView view,
final MyProxy proxy) {
super(eventBus, view, proxy);
}
@Override
protected void revealInParent() {
// trigger setInSlot in the RootView
RevealRootContentEvent.fire(this, this);
}
@Override
protected void onReveal() {
super.onReveal();
if (!headerNavigationDisplayed) {
// Fire this event to force reveal the header and navigation
// presenters
MainContentSetEvent.fire(this, "ThreePart");
headerNavigationDisplayed = true;
}
}
Когда раскрывается MainPagePresenter
. Вызывает пользовательское событие MainContentSetEvent
. У меня есть параметр, но он вам не нужен. Для обработки этого события HeaderPresenter
должен реализовывать интерфейс the
MainContentSetHandler`. Введите следующий код:
@Override
protected void revealInParent() {
RevealContentEvent.fire(this, MainPagePresenter.TYPE_SetHeaderContent,
this);
}
@ProxyEvent
@Override
public void onMainContentSet(MainContentSetEvent event) {
forceReveal();
}
Сделайте то же самое для NavigationPresenter
. Введите следующий код:
@Override
protected void revealInParent() {
RevealContentEvent.fire(this,
MainPagePresenter.TYPE_SetNavigationContent, this);
}
@ProxyEvent
@Override
public void onMainContentSet(MainContentSetEvent event) {
layout = event.getLayout();
forceReveal();
}
Со стороны вида введите следующий код в MainPageView
:
@Override
public void setInSlot(Object slot, Widget content) {
if (slot == MainPagePresenter.TYPE_SetMainContent) {
setMainContent(content);
} else if (slot == MainPagePresenter.TYPE_SetHeaderContent) {
setHeaderContent(content);
} else if (slot == MainPagePresenter.TYPE_SetNavigationContent) {
setNavigationContent(content);
} else {
super.setInSlot(slot, content);
}
}
Если вы хотите понять весь механизм, работающий в режиме отладки, вам легче понять иерархию вызовов. Я только поставил соответствующий код, так как вы знаете о SimpleNestetExample
, вы сможете написать отсутствующий код.