Office: (Office 2016) Glücksrad mit VBA und For-Schleifen

Helfe beim Thema Glücksrad mit VBA und For-Schleifen in Microsoft Excel Hilfe um das Problem gemeinsam zu lösen; Hallo zusammen! Da ich hier immer Hilfe finde wende ich mich mal wieder mit folgendem Problem an euch: Ich möchte in Excel etwas auslosen. Das... Dieses Thema im Forum "Microsoft Excel Hilfe" wurde erstellt von Poempel, 10. Oktober 2018.

  1. Glücksrad mit VBA und For-Schleifen


    Hallo zusammen!

    Da ich hier immer Hilfe finde wende ich mich mal wieder mit folgendem Problem an euch:

    Ich möchte in Excel etwas auslosen. Das ansich ist auch kein Problem. Damit es etwas spannender ist und etwas hübscher aussieht soll es jedoch wie bei einem Glücksrad ein paar Sekunden dauern, bis das endgültige Los angezeigt wird. In der Zwischenzeit soll per Zufall ein anderes Los als gezogen angezeigt werden, eben wie bei einem Glücksrad. Zusätzlich wird das aktuelle Los noch farblich markiert. Etwas schwer zu erklären, ich hoffe ihr versteht es.
    Da zunächst einer von vier Töpfen gezogen wird und anschließend aus dem Topf das wirkliche Los, wird unten angezeigter Code quasi zweimal hintereinander ausgeführt, eben nur mit anderen Bezugs-Auswahl. Wie ihr dort seht habe ich das ganze mit For-Schleifen und Sleep realisiert. Hierbei kommt es immer wieder zu Problemen. Erstmal läuft das ganze nicht schön rund, spirch es kommt immer wieder zu rucklern. Dabei kann es desweiteren dann passieren, dass Excel komplett abstüzrt, weiß wird und "keine Rückmeldung" ausgibt, bis der Code komplett durchgelaufen ist.

    Bei folgendem Code-Abschnitt kommt es zu den Abstürzen:

    Code:
        Dim i As Integer
            For i = 0 To 60
            zz2 = Round((4 - 1) * Rnd() + 1, 0)
            Tabelle1.Cells(14, 13).Value = zz2
            Tabelle1.Cells(2, 2 * zz2).Interior.ColorIndex = 6
            Sleep 50
            Tabelle1.Range("B2:H2").Interior.ColorIndex = 0
        Next i
        
        Dim j As Integer
        For j = 0 To 30
            zz2 = Round((4 - 1) * Rnd() + 1, 0)
            Tabelle1.Cells(14, 13).Value = zz2
            Tabelle1.Cells(2, 2 * zz2).Interior.ColorIndex = 6
            Sleep 100
            Tabelle1.Range("B2:H2").Interior.ColorIndex = 0
        Next j
        
        Dim k As Integer
        For k = 0 To 3
            zz2 = Round((4 - 1) * Rnd() + 1, 0)
            Tabelle1.Cells(14, 13).Value = zz2
            Tabelle1.Cells(2, 2 * zz2).Interior.ColorIndex = 6
            Sleep 500
            Tabelle1.Range("B2:H2").Interior.ColorIndex = 0
        Next k
    
    Die For-Schleifen werden immer kürzer, dafür die Sleep-Zeit immer länger um eben die Spannung ein bisschen aufrecht zu erhalten. Ist die Kombination aus For-Schleife und Sleep das Problem oder gibt es generell eine rechenunaufwändigere Methode um so eine Art Glücksrad zu realisieren?

    Vielen Dank schonmal
    Poempel
     
    Poempel, 10. Oktober 2018
    #1
  2. Exl121150 Erfahrener User
    Hallo,

    ich habe deinen Codeausschnitt in eine SUB verpackt, die Variable "zz2" als Integer deklariert und auf Modulebene noch die "Sleep"-SUB aus der "kernel32.dll" (mittels bedingtem Compilercode) deklariert:
    Code:
    Option Explicit
    
    #If VBA7 Then
      Declare PtrSafe Sub Sleep Lib "kernel32" (ByVal Milliseconds As LongPtr)
    #Else
      Declare Sub Sleep Lib "kernel32" (ByVal Milliseconds As Long)
    #End If
    
    Sub test()
    
        Dim zz2 As Integer
    
        'Dein Code von vorhin
        '....
    
    End Sub
    
    
    und konnte kein Problem, was seinen Ablauf betreffen sollte, feststellen.
    Ich habe ihn mehrmals laufen lassen.
     
    Exl121150, 11. Oktober 2018
    #2
Thema:

Glücksrad mit VBA und For-Schleifen

Die Seite wird geladen...
  1. Glücksrad mit VBA und For-Schleifen - Similar Threads - Glücksrad VBA For

  2. ActiveX Steuerelemente nicht verfügbar im VBA Entwurfsmodus.

    in Microsoft Excel Hilfe
    ActiveX Steuerelemente nicht verfügbar im VBA Entwurfsmodus.: Guten Tag allerseits. Ich habe eine Excel-Anwendung (xlsm mit Macros), die auf einem Laptop Probleme macht. Auf allen anderen PC's läuft es perfekt, auf dem genannten Laptop scheitern Zugriffe auf...
  3. VBA: Datei Upload mit http: POST

    in Microsoft Excel Hilfe
    VBA: Datei Upload mit http: POST: Hallo, schönen Gruß an alle; ich hoffe jemand hat einen Hinweis wo ich ansetzen kann. Problembeschreibung: · VBA aus Excel (das muss auch so bleiben) und funktioniert anscheinend ja auch...
  4. VBA - Dateinamen anhand von Unterstrich und Großbuchstaben trennen

    in Microsoft Excel Hilfe
    VBA - Dateinamen anhand von Unterstrich und Großbuchstaben trennen: Hallo zusammen, ich würde gern folgendes Projekt realisieren. Ich bekomme regelmäßige pdf- und jpg-Dateien (immer im Format Nachname_Vornamen_Geburtsdatum - z. B.:...
  5. VBA Outlook E-Mailvorschau aktualisieren wg. Flag-Text

    in Microsoft Outlook Hilfe
    VBA Outlook E-Mailvorschau aktualisieren wg. Flag-Text: Hallo Leute, ich benötige bei einem Problem euer Wissen. Ich setze in Outlook einen Flag "Erledig" mit einem individuellen Text (= MdName). Allerdingst wird mir dieser Text erst nach einem...
  6. VBA HTTP Post - Probleme JSON Payload

    in Microsoft Excel Hilfe
    VBA HTTP Post - Probleme JSON Payload: Moin, ich steh auf dem Schlauch.... Ich möchte mit VBA einen HTTP Post senden. Das klappt beim versenden OHNE Payload auch soweit auch ganz gut. Private Function http_post(url As String,...
  7. Kombinationsfeld in VBA auswerten

    in Microsoft Access Hilfe
    Kombinationsfeld in VBA auswerten: Guten Tag, ich habe ein VBA-Problem mit Kombinationsfeldern. Umfeld: Eine Tabelle A mit Namen incl. Adressen, indiziert (NamenID), keine doppelten Einträge möglich. Eine Tabelle B mit Rechnungen,...
  8. Glücksrad unter Excel mit VBA

    in Microsoft Excel Hilfe
    Glücksrad unter Excel mit VBA: Hallo, ich habe heute mal eine ungewöhnliche frag, ich will meinem Sohn helfen der ein Glücksrad mit 7 Bereichen erstellen soll und wenn ich unter Excel ein Button drücke soll dann das Glücksrad...
  1. Diese Seite verwendet Cookies, um Inhalte zu personalisieren, diese deiner Erfahrung anzupassen und dich nach der Registrierung angemeldet zu halten.
    Auf dieser Website werden Cookies für die Zugriffsanalyse und Anzeigenmessung verwendet.
    Wenn du dich weiterhin auf dieser Seite aufhältst, akzeptierst du unseren Einsatz von Cookies.
    Information ausblenden