Seite 1 von 2

Gadgets automatisch nach unten scrollen

Verfasst: 02.02.2018 13:03
von stevie1401
Ich suche eine Möglichkeit für ein ListIconGadget oder Webgadget oder irgendein anderes Gadget, wo Text rein kann, automatisch bis ganz nach unten zu scrollen.
Ich brauche das für eine Chatbox.
Im Spiederbasic-Forum finde ich leider nichts.
Geht das vielleicht mit Javascript?
Hat jemand eine Idee?

Re: Gadgets automatisch nach unten scrollen

Verfasst: 02.09.2018 23:12
von stevie1401
Nun habe ich vor geraumer Zeit eine Möglichkeit gefunden mit einem Textgadget zu scrollen.
Aber ich brauche auch eine Lösung für ein Editorgadget.
Hat jemand eine Idee, wie man bei einem Editorgadget automatisch nach unten scrollen kann?

Re: Gadgets automatisch nach unten scrollen

Verfasst: 03.09.2018 00:34
von Kiffi
stevie1401 hat geschrieben:Nun habe ich vor geraumer Zeit eine Möglichkeit gefunden mit einem Textgadget zu scrollen.
schade, dass Du Deine Lösung dann nicht den anderen mitgeteilt hast.
stevie1401 hat geschrieben:Hat jemand eine Idee, wie man bei einem Editorgadget automatisch nach unten scrollen kann?
eine Möglichkeit:

Code: Alles auswählen

OpenWindow(0, 0, 0, 322, 150, "EditorGadget", #PB_Window_SystemMenu | #PB_Window_ScreenCentered)

EditorGadget(0, 8, 8, 306, 133)

SetGadgetText(0, "Line 01" + #LF$ +
                 "Line 02" + #LF$ +
                 "Line 03" + #LF$ +
                 "Line 04" + #LF$ +
                 "Line 05" + #LF$ +
                 "Line 06" + #LF$ +
                 "Line 07" + #LF$ +
                 "Line 08" + #LF$ +
                 "Line 09" + #LF$ +
                 "Line 10" + #LF$ +
                 "Line 11")

gid = GadgetID(0)
! v_gid.gadget.textbox.scrollIntoView()
SetActiveGadget(0)

Re: Gadgets automatisch nach unten scrollen

Verfasst: 03.09.2018 10:51
von stevie1401
Hey Kiffi, dein Beispiel funktioniert bei mir leider nicht.
Liegt es an dieser Zeile:
! v_gid.gadget.textbox.scrollIntoView()

Da steht textbox und nicht editorgadget?

Und hier die beiden Proceduren, die es ermöglichen in einer Textbox zu scrollen:

Code: Alles auswählen

Procedure ScrollDown(aGadget)
  Protected chatid = GadgetID(aGadget)
  
  !$(v_chatid.div).animate({scrollTop: $(v_chatid.div).prop("scrollHeight")}, 0);
EndProcedure

Procedure ScrollEnable(aGadget)
  Protected chatid
  
  chatid = GadgetID(aGadget)
  !$(v_chatid.div).css("overflow", "scroll") 
EndProcedure

ScrollEnable(meinTextGadget) muss gleich nach dem Erstellen des Textgadget ausgeführt werden.
Danach kann man bei Bedarf Text dem Textgadget hinzugefügt werden und dann mit:

ScrollDown(meinTextGadget)
automatisch nach unten scrollen.

Re: Gadgets automatisch nach unten scrollen

Verfasst: 03.09.2018 11:22
von Kiffi
stevie1401 hat geschrieben:Da steht textbox und nicht editorgadget?
nee, das stimmt schon so. Das ist eine dijitTextBox.
stevie1401 hat geschrieben:dein Beispiel funktioniert bei mir leider nicht.
seltsam. Gibt's eine Fehlermeldung (in der Konsole (F12))?

Grüße ... Peter

Nachtrag: Im IE funktioniert es in der Tat nicht (der IE mal wieder... >_<).

Re: Gadgets automatisch nach unten scrollen

Verfasst: 04.09.2018 10:06
von stevie1401
Ich habe den Fehler gefunden.
Ich habe das Gadget nicht aktiv gesetzt.

SetActiveGadget(meinEditorgadget) fehlte. Ohne das Aktivsetzen scheint es nicht zu funktionieren.
Leider möchte ich nach dem Laden von Text in das Editorgadget und dem Runterscrollen ein Eingabetextgadget aktiv setzen. Aber wenn ich das mache, funktioniert das Scrollen nicht mehr.
Aber vielleicht kann ich da eine Pause einbauen oder so.
Erst einmal vielen Dank!

Re: Gadgets automatisch nach unten scrollen

Verfasst: 04.09.2018 12:19
von Kiffi
für das ListViewGadget und das ListIconGadget habe ich jetzt eine SetGadgetStateEx() - Funktion geschrieben.
Wenn Du magst, kannst Du das ja mal ausprobieren:

Code: Alles auswählen

EnableExplicit

Procedure SetGadgetStateEx(Gadget, SelectedItem)
  
  Select GadgetType(Gadget)
      
    Case #PB_GadgetType_ListView, #PB_GadgetType_ListIcon
      
      ! setTimeout( function() {
      
      SetGadgetState(Gadget, SelectedItem)
      
      ! if (($(spider_GadgetID(v_gadget).div).find(".dgrid-selected")).length > 0) {
      !   spider_GadgetID(v_gadget).gadget.scrollTo({x:0,y:$(spider_GadgetID(v_gadget).div).find(".dgrid-selected").position().top});
      ! } else {
      !   spider_GadgetID(v_gadget).gadget.scrollTo({x:0,y:0});
      ! }
      
      ! }, 10);
      
    Default
      
      Debug "Unsupported Gadget"
      
  EndSelect
  
EndProcedure

Enumeration
  #Window
  #ListViewGadget
  #ListIconGadget
EndEnumeration

Define Counter

OpenWindow(#Window, 0, 0, 510, 140, "ScrollIntoView", #PB_Window_SystemMenu | #PB_Window_ScreenCentered)

; ######################
; # ListViewGadget
; ######################

ListViewGadget(#ListViewGadget, 10, 10, 250, 120)

For Counter = 1 To 12
  AddGadgetItem (#ListViewGadget, -1, "Line " + Str(Counter) + " of the ListViewGadget")
Next

SetGadgetStateEx(#ListViewGadget, 10)

; ######################
; # ListIconGadget
; ######################

ListIconGadget(#ListIconGadget, 260, 10, 250, 120, "First Column", 200)

For Counter = 1 To 12
  AddGadgetItem (#ListIconGadget, -1, "Line " + Str(Counter) + " of the ListIconGadget")
Next

SetGadgetStateEx(#ListIconGadget, 10)
Grüße ... Peter

Re: Gadgets automatisch nach unten scrollen

Verfasst: 14.09.2022 07:45
von stevie1401
Wie kann ich denn beim Editorgadget ganz an den Anfang nach oben scrollen?

Code: Alles auswählen

 chatid = GadgetID(#edigadget)
 !$(v_chatid.div).animate({scrollTop: $(v_chatid.div).prop("scrollHeight")}, 0);
 
...funktioniert nicht.

Re: Gadgets automatisch nach unten scrollen

Verfasst: 14.09.2022 18:50
von Kiffi
stevie1401 hat geschrieben: 14.09.2022 07:45...funktioniert nicht.
bitte ein kleines lauffähige Beispiel posten.

Re: Gadgets automatisch nach unten scrollen

Verfasst: 18.09.2022 15:38
von stevie1401

Code: Alles auswählen



OpenWindow(0, 0, 0, 322, 150, "EditorGadget", #PB_Window_SystemMenu | #PB_Window_ScreenCentered)

EditorGadget(1, 8, 8, 306, 133)

s.s=""
For i=1 To 50
  s+Str(i)+Chr(10)
Next i



SetGadgetText(1, s)


;Unteres funktioniert nicht
gid = GadgetID(1)
! v_gid.gadget.textbox.scrollIntoView(false)
SetActiveGadget(1)

;Dies auch nicht
chatid = GadgetID(1)
 !$(v_chatid.div).animate({scrollTop: $(v_chatid.div).prop("scrollHeight")}, 0);