2013-10-05 24 views
14

Czy istnieje sposób na określenie pozycji tytułu i wiadomości w widoku Prezentacja? Widzę, że biblioteka używa funkcji do znalezienia najlepszej pozycji, ale chcę ją przesłonić.Prezentacja Wyświetl tekst grawitacja

+1

Proszę wyjaśnić, co próbujesz powiedzieć, pokaż swój kod, a następnie wyjaśnij problem, który otrzymujesz. –

+0

zaktualizowany op. Nadal nie znalazłem sposobu, aby to zrobić. – arayray

+0

Przesłane wydanie w Prezentacji Wyświetl github. https://github.com/Espiandev/ShowcaseView/issues/113 – arayray

Odpowiedz

8

Właśnie wykopałem kod źródłowy ShowcaseView i wygląda na to, że nie ma żadnej możliwości wbudowania, aby ustawić pozycję tekstu. Dlatego dodałem własną modyfikację do biblioteki. Oto zmiany, które ja dokonane:

W klasie ShowcaseView dodania następujących polach:

private boolean hasManualPostion = false; 
private int xPosition, yPosition, width; 

następnie w klasie Builder który jest klasa wewnętrzna w ShowcaseView klasy, dodać te metody:

 public Builder hasManualPosition(boolean hasManualPosition) { 
     showcaseView.hasManualPostion = hasManualPosition; 
     return this; 
    } 

    public Builder xPostion(int xPostion) { 
     showcaseView.xPosition = xPostion; 
     return this; 
    } 

    public Builder yPostion(int yPostion) { 
     showcaseView.yPosition = yPostion; 
     return this; 
    } 

Następnie dodaj tę metodę do klasy TextDrawer:

public void setTestPostionManually(int xPosition, int yPosition) { 
    mBestTextPosition[0] = xPosition; 
    mBestTextPosition[1] = yPosition; 
} 

i przy zmianie onPreDraw metody końcowego w ShowcaseView wyglądać tak:

@Override 
public boolean onPreDraw() { 
    boolean recalculatedCling = showcaseAreaCalculator.calculateShowcaseRect(showcaseX, showcaseY, showcaseDrawer); 
    boolean recalculateText = recalculatedCling || hasAlteredText; 
    if (recalculateText) { 
     textDrawer.calculateTextPosition(getMeasuredWidth(), getMeasuredHeight(), this, shouldCentreText); 
     if (hasManualPostion) { 
      textDrawer.setTestPostionManually(xPosition, yPosition); 
     } 
    } 
    hasAlteredText = false; 
    return true; 
} 

Teraz należy utworzyć ShowcaseView takiego:

sv = new ShowcaseView.Builder(this, true) 
       .setTarget(target) 
       .setContentTitle(R.string.showcase_main_title) 
       .setContentText(R.string.showcase_main_message) 
       .setStyle(R.style.CustomShowcaseTheme2) 
       .setShowcaseEventListener(this) 
       .hasManualPosition(true) 
       .xPostion(0) 
       .yPostion(240) 
       .build(); 

Enjoy!

+0

która to wersja? jakikolwiek pomysł, jak sprawić, by działało w starszej wersji? –

+1

Modyfikacja dotyczy wersji 5.0.0 – Sadegh

+0

czy znasz jakiś sposób, aby wprowadzić animację ręczną w wersji 5.0.0? –