Autore Topic: Rilevare quando il testo eccede la dimensione orizzontale di una Label  (Letto 176 volte)

Offline vuott

  • Moderatore globale
  • Senatore Gambero
  • *****
  • Post: 11.713
  • Ne mors quidem nos iunget
    • Mostra profilo
« Chiunque, non ricorrendo lo stato di necessità, nel proprio progetto Gambas fa uso delle istruzioni Shell o Exec, è punito con la sanzione pecuniaria da euro 20,00 a euro 60,00. »

Offline Gianluigi

  • Moderatore globale
  • Senatore Gambero
  • *****
  • Post: 4.244
  • Tonno verde
    • Mostra profilo
Re:Rilevare quando il testo eccede la dimensione orizzontale di una Label
« Risposta #1 il: 16 Giugno 2022, 17:05:56 »
Siccome le ultime mie due risposte non seguono il thred (sono sparite  :-\ ) metto qui il codice da me suggerito a Steve:
Codice: [Seleziona]
Public Sub Form_Open()

  Dim s As String = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua."
  Dim iRows As Integer
  Dim hFont As Font
  Dim hTextLabel As TextLabel

  With hTextLabel = New TextLabel(Me) As "TextLabel1"
    .X = 50
    .Y = 50
    .W = 100
    .H = 100
    .AutoResize = False
    .Wrap = True
    .Text = s
    .Border = 1
    hFont = .Font
  End With

  iRows = Rows(hTextLabel.Text, hTextLabel.Width, hFont)

  While (iRows * hFont.Height) > hTextLabel.Height
    hFont.Size -= 0.5
    iRows = Rows(hTextLabel.Text, hTextLabel.Width, hFont)
  Wend

End

Private Function Rows(value As String, iWidth As Integer, hFont As Font) As Integer

  Dim i As Integer
  Dim ss As String[]
  Dim sRow As String

  If hFont.TextWidth(value) < iWidth Then Return 1
  ss = Split(value, " ")
  For Each s As String In ss
    sRow &= " " & s
    If hFont.TextWidth(sRow) > iWidth Then
      sRow = s
      Inc i
    Endif
  Next
  Return i + 1

End

Nota: il codice va copiato in un nuovo progetto grafico.

 :ciao:
nuoto in attesa del bacio di una principessa che mi trasformi in un gambero azzurro

Offline Gianluigi

  • Moderatore globale
  • Senatore Gambero
  • *****
  • Post: 4.244
  • Tonno verde
    • Mostra profilo
Re:Rilevare quando il testo eccede la dimensione orizzontale di una Label
« Risposta #2 il: 17 Giugno 2022, 23:09:10 »
Comunque anche se pare che io non abbia capito quello che voleva se si desidera ridurre un testo fino a farlo stare all'interno di una Label invece che di una TextLabel che ha la proprietà Wrap, basta aggiungere la funzione:
Codice: [Seleziona]
Private Function RowSplit(value As String, iWidth As Integer, hFont As Font) As String

  Dim i As Integer
  Dim ss As String[]
  Dim sRow As String

  If hFont.TextWidth(value) < iWidth Then Return 1
  ss = Split(value, " ")
  For Each s As String In ss
    If hFont.TextWidth(sRow & " " & s) > iWidth Then
      sRow &= "\n"
      sRow &= s
    Else
      sRow = sRow & " " & s
    Endif
  Next
  Return Trim(sRow)

End
che passa alla label il testo della giusta dimensione, tutto il testo senza troncarlo.
Probabilmente c'è un modo migliore per farlo ma a me è venuto in mente solo questo.

nuoto in attesa del bacio di una principessa che mi trasformi in un gambero azzurro