Handboek Annuleren

Tips en trucs: Richtlijnen voor het ontwerpen van SWF-toepassingen

  1. Adobe Animate-handboek
  2. Inleiding tot Animate
    1. Nieuw in Animate
    2. Visuele verklarende woordenlijst
    3. Systeemvereisten voor Animate
    4. Animate-sneltoetsen
    5. Werken met meerdere bestandstypen in Animate
  3. Animatie
    1. Grondbeginselen voor animaties in Animate
    2. Frames en hoofdframes gebruiken in Animate
    3. Frame-voor-frame-animaties in Animate
    4. Werken met klassieke tussenvoegingsanimaties in Animate
    5. De tool Penseel
    6. Hulplijnen voor bewegingen
    7. Bewegings-tween en ActionScript 3.0
    8. Over tussenvoegingsanimaties met beweging
    9. Animaties met bewegings-tweens
    10. Een animatie met bewegings-tween maken
    11. Eigenschapshoofdframes gebruiken
    12. Een positie animeren met een tween
    13. Bewegings-tweens bewerken in de Bewegingseditor
    14. Het bewegingspad van een tween-animatie bewerken
    15. Bewegings-tweens manipuleren
    16. Aangepaste versnellingen toevoegen
    17. Voorinstellingen voor beweging maken en toepassen
    18. Animatietween-reeksen instellen
    19. Werken met als XML-bestanden opgeslagen bewegings-tweens
    20. Bewegings-tweens en klassieke tweens
    21. Tussenvoegingen met vormen
    22. De tool Bone-animatie gebruiken in Animate
    23. Werken met structuren voor personages in Animate
    24. Maskeerlagen gebruiken in Adobe Animate
    25. Werken met scènes in Animate
  4. Interactiviteit
    1. Knoppen maken met Animate
    2. Animate-projecten converteren naar andere documentindelingen
    3. HTML5 Canvas-documenten maken en publiceren in Animate
    4. Interactiviteit toevoegen met codefragmenten in Animate
    5. Aangepaste HTML5-componenten maken
    6. Componenten in HTML5 Canvas gebruiken
    7. Maken van aangepaste componenten: Voorbeelden
    8. Codefragmenten voor aangepaste componenten
    9. Tips en trucs: Adverteren met Animate
    10. Ontwerp en publicatie van virtual reality
  5. Werkruimte en workflow
    1. Penselen maken en beheren
    2. Google-lettertypen gebruiken in HTML5 Canvas-documenten
    3. Creative Cloud Libraries en Adobe Animate gebruiken
    4. Het werkgebied en het deelvenster Tools voor Animate gebruiken
    5. Workflow en werkruimte in Animate
    6. Weblettertypen gebruiken in HTML5 Canvas-documenten
    7. Tijdlijnen en ActionScript
    8. Werken met meerdere tijdlijnen
    9. Voorkeuren instellen
    10. Deelvensters voor ontwerp in Animate gebruiken
    11. Tijdlijnlagen maken met Animate
    12. Animaties exporteren voor mobiele apps en game-engines
    13. Objecten verplaatsen en kopiëren
    14. Sjablonen
    15. Zoeken en vervangen in Animate
    16. Ongedaan maken, Opnieuw en het deelvenster Historie
    17. Sneltoetsen
    18. De tijdlijn gebruiken in Animate
    19. HTML-extensies maken
    20. Optimalisatieopties voor afbeeldingen en geanimeerde GIF-bestanden
    21. Exportinstellingen voor afbeeldingen en GIF-bestanden
    22. Deelvenster Elementen in Animate
  6. Multimedia en video
    1. Grafische objecten transformeren en combineren in Animate
    2. Symboolinstanties maken in Animate en ermee werken
    3. Afbeeldingen overtrekken
    4. Geluid gebruiken in Adobe Animate
    5. SVG-bestanden exporteren
    6. Videobestanden maken voor gebruik in Animate
    7. Een video toevoegen in Animate
    8. Objecten tekenen en maken met Animate
    9. Lijnen en vormen omvormen
    10. Streken, verlopen en vullingen met Animate CC
    11. Werken met Adobe Premiere Pro en After Effects
    12. Deelvensters voor kleuren in Animate CC
    13. Flash CS6-bestanden openen met Animate
    14. Werken met klassieke tekst in Animate
    15. Illustraties opnemen in Animate
    16. Geïmporteerde bitmaps in Animate
    17. 3D-afbeeldingen
    18. Werken met symbolen in Animate
    19. Lijnen en vormen tekenen met Adobe Animate
    20. Werken met bibliotheken in Animate
    21. Geluiden exporteren
    22. Objecten selecteren in Animate CC
    23. Werken met Illustrator AI-bestanden in Animate
    24. Overvloeimodi toepassen
    25. Objecten rangschikken
    26. Taken automatiseren met het menu Opdrachten
    27. Meertalige tekst
    28. De camera gebruiken in Animate
    29. Grafische filters
    30. Geluid en ActionScript
    31. Tekenvoorkeuren
    32. Tekenen met de pen
  7. Platforms
    1. Animate-projecten converteren naar andere documentindelingen
    2. Ondersteuning voor aangepaste platforms
    3. HTML5 Canvas-documenten maken en publiceren in Animate
    4. Een WebGL-document maken en publiceren
    5. Toepassingen verpakken voor AIR voor iOS
    6. AIR voor Android-toepassingen publiceren
    7. Publiceren voor Adobe AIR voor desktop
    8. Publicatie-instellingen voor ActionScript
    9. Tips en trucs: ActionScript organiseren in een toepassing
    10. ActionScript gebruiken met Animate
    11. Toegankelijkheid in de Animate-werkruimte
    12. Scripts schrijven en beheren
    13. Ondersteuning voor aangepaste platforms inschakelen
    14. Overzicht van ondersteuning voor aangepaste platforms
    15. Werken met plug-in voor ondersteuning voor aangepaste platforms
    16. Foutopsporing in ActionScript 3.0
    17. Ondersteuning voor aangepaste platforms inschakelen
  8. Exporteren en publiceren
    1. Bestanden exporteren uit Animate CC
    2. OAM-publicatie
    3. SVG-bestanden exporteren
    4. Afbeeldingen en video's exporteren met Animate
    5. AS3-documenten publiceren
    6. Animaties exporteren voor mobiele apps en game-engines
    7. Geluiden exporteren
    8. Tips en trucs: Tips voor het maken van inhoud voor mobiele apparaten
    9. Tips en trucs: Videoconventies
    10. Tips en trucs: Richtlijnen voor het ontwerpen van SWF-toepassingen
    11. Tips en trucs: Structuur geven aan FLA-bestanden
    12. Beste werkwijzen voor het optimaliseren van FLA-bestanden voor Animate
    13. Publicatie-instellingen voor ActionScript
    14. Publicatie-instellingen opgeven voor Animate
    15. Projectorbestanden exporteren
    16. Afbeeldingen en geanimeerde GIF-bestanden exporteren
    17. HTML-publicatiesjablonen
    18. Werken met Adobe Premiere Pro en After Effects
    19. Snel uw animaties delen en publiceren
  9. Problemen oplossen
    1. Opgeloste problemen
    2. Bekende problemen

 

Informatie over richtlijnen voor SWF-toepassingen

De beste manier om Animate-toepassingen te maken, hangt af van de toepassing die u maakt en de technologie die u gebruikt om de toepassing te maken.

Bij een online toepassing kan de gebruiker door interactie invloed uitoefenen op een website. De toepassing kan bijvoorbeeld gegevens van de gebruiker verzamelen (zoals een gebruikersnaam en wachtwoord voor registratie), gegevens toevoegen aan de site (zoals in een forum) of er kan sprake zijn van realtime interactie tussen bezoekers van een site (zoals in een chatroom of interactief whiteboard). De resultaten van de server worden vaak in het SWF-bestand opgenomen, afhankelijk van de interactie. Dit zijn voorbeelden van toepassingen waarbij de gebruiker invloed uitoefent en verschillende typen interactie met de server plaatsvinden. Een website die geen informatie of gegevens van gebruikers gebruikt, is geen toepassing (zoals een portfolio, een animatie of een site met statische informatie). Animate-toepassingen omvatten een interactief proces tussen de gebruiker, een webtoepassing en een server. Het basisproces is als volgt:

  1. Een gebruiker voert informatie in een SWF-bestand in.

  2. De informatie wordt omgezet in gegevens.

  3. De gegevens worden opgemaakt en naar een webserver gezonden.

  4. De gegevens worden verzameld door de webserver en naar een toepassingsserver gezonden (zoals ColdFusion, PHP of ASP).

  5. De gegevens worden verwerkt en naar de webserver teruggestuurd.

  6. De webserver stuurt de resultaten naar het SWF-bestand.

  7. Het SWF-bestand ontvangt de opgemaakte gegevens.

  8. Uw ActionScript-code verwerkt de gegevens, zodat de toepassing die kan gebruiken.

Wanneer u een toepassing maakt, moet u een protocol voor het verzenden van gegevens selecteren. Het protocol waarschuwt de toepassing wanneer gegevens worden verzonden of ontvangen, in welke indeling de gegevens worden overgezet en hoe de reactie van de server moet worden verwerkt. Nadat de gegevens door het SWF-bestand zijn ontvangen, moeten deze worden gemanipuleerd en opgemaakt. Wanneer u een protocol gebruikt, hoeft u zich geen zorgen te maken dat gegevens in een onverwachte indeling worden verzonden. Wanneer u gegevens via naam-waardeparen overdraagt, kunt u de indeling van de gegevens controleren. Controleer of de gegevens de juiste indeling hebben, zodat u geen XML-gegevens ontvangt en het SWF-bestand weet welke gegevens het kan verwachten en verwerken.

Gegevens verzamelen en opmaken

Toepassingen zijn afhankelijk van gebruikersinteractie met het SWF-bestand. Vaak is de toepassing afhankelijk van de invoer van gegevens in formulieren. Animate biedt vele manieren om gegevens in Animate-toepassingen in te voeren en op te maken. Deze flexibiliteit is mogelijk dankzij animatiemogelijkheden en creatief beheer van de interface en dankzij de foutcontrole en -validatie die u met ActionScript kunt uitvoeren.

Het gebruik van Animate om formulieren te maken voor gegevensverzameling biedt de volgende voordelen:

  • Meer controle over het ontwerp.

  • Pagina's hoeven niet of minder vaak te worden vernieuwd.

  • Algemene elementen kunnen opnieuw worden gebruikt.

     Wanneer u informatie wilt opslaan die u van de gebruiker hebt verzameld, slaat u deze op in een gezamenlijk object op de computer van de gebruiker. Via gezamenlijke objecten kunt u gegevens op de computer van de gebruiker opslaan, vergelijkbaar met het gebruik van een cookie. Raadpleeg de klasse sharedObject in de Naslaggids voor ActionScript 2.0 of de Naslaggids voor ActionScript® 3.0 voor Adobe® Flash® Professional CS5 voor meer informatie over gezamenlijke objecten.

Gegevens verzenden en verwerken

Gewoonlijk moet u informatie verwerken voordat u deze naar de server verzendt, zodat de gegevens een indeling hebben die de server begrijpt. Wanneer de server de gegevens ontvangt, kunnen deze op verschillende manieren worden gemanipuleerd en teruggestuurd naar een SWF-bestand in een indeling die dat bestand accepteert. De indeling kan variëren van naam-waardeparen tot complexe objecten.

 Op uw applicatieserver moet het MIME-type van de uitvoer zijn ingesteld op application/x-www-urlform-encoded. Wanneer dat MIME-type ontbreekt, is het resultaat gewoonlijk onbruikbaar wanneer het Animate bereikt.

In de volgende tabel worden diverse opties getoond voor het verzenden van gegevens naar een server en het ontvangen van gegevens met Animate:

Gegevens verzenden

Beschrijving

LoadVars.load() en LoadVars.sendAndLoad()

Verzendt naam-waardeparen naar een serverscript voor verwerking. LoadVars.send verzendt variabelen naar een extern script en negeert reacties. LoadVar.sendAndLoad verzendt naam-waardeparen naar een server en laadt of parseert de antwoorden in een doelobject LoadVars.

XML.send en XML.sendAndLoad

Vergelijkbaar met LoadVars, maarXML.send en XML.sendAndLoad verzenden XML-pakketten in plaats van naam-waardeparen.

getURL

Wanneer u de functie getURL() of de methode MovieClip.getURL gebruikt, kunt u variabelen uit Animate naar een frame of pop-upvenster sturen.

Remoting

Hiermee kunt u gemakkelijk complexe informatie tussen Animate en ColdFusion, ASP.NET, Java en meer uitwisselen. U kunt Animate Remoting ook gebruiken voor webservices.

Webservices

Adobe Animate bevat de component WebServiceConnector die u kunt gebruiken om verbinding te maken met externe webservices, gegevens te verzenden en te ontvangen en resultaten aan componenten te verbinden. Zo kunnen Animate-ontwikkelaars snel RIA's (Rich Internet Applications) maken zonder dat ze ook maar één regel ActionScript-code hoeven te schrijven.

U kunt externe webservices gebruiken met behulp van WebServiceClasses, waarvoor complexe ActionScript-code vereist kan zijn.

Gegevens laden en valideren

Gegevens die u ontvangt, moeten worden gevalideerd voordat ze naar de server worden verzonden. Hierdoor neemt de belasting van de externe server af, aangezien minder aanvragen hoeven te worden afgehandeld wanneer gebruikers de vereiste velden niet invullen. Vertrouw echter in geen enkele toepassing uitsluitend op validatie aan de clientzijde; zorg ook voor validatie aan de serverzijde.

Zelfs wanneer u een eenvoudig registratie- of aanmeldingsformulier maakt, moet u controleren of de gebruiker zijn/haar naam en wachtwoord heeft ingevoerd. Voer deze validatie uit voordat u de aanvraag naar het script op de externe server verzendt en op een resultaat wacht. Vertrouw niet uitsluitend op validatie aan de serverzijde. Wanneer de gebruiker alleen een gebruikersnaam invoert, moet het serverscript de aanvraag ontvangen, de verzonden gegevens valideren en een foutbericht naar de Animate-toepassing terugsturen waarin wordt vermeld dat zowel een gebruikersnaam als een wachtwoord is vereist. Wanneer de validatie daarentegen alleen wordt uitgevoerd aan de clientzijde (in het SWF-bestand), zou een gebruiker het SWF-bestand kunnen kraken, de validatie omzeilen en gegevens naar de server verzenden om te proberen onjuiste gegevens te posten.

Clientvalidatie kan zeer eenvoudig zijn. U kunt bijvoorbeeld controleren of een formulierveld ten minste één teken bevat of dat de gebruiker een numerieke waarde heeft ingevoerd en geen tekenreeks. Wanneer u bijvoorbeeld een e-mailadres wilt valideren, controleert u of het tekstveld in Animate niet leeg is en op zijn minst een apenstaartje (@) en punt (.) bevat. Voor servervalidatie voegt u complexere validatie toe en controleert u of het e-mailadres deel uitmaakt van een geldig domein.

U moet ActionScript-code schrijven om de gegevens te verwerken die vanaf de server in het SWF-bestand worden geladen. Nadat de gegevens in een SWF-bestand zijn geladen, kunt u vanaf die locatie toegang krijgen tot de gegevens. Gebruik ActionScript om te controleren of de gegevens volledig zijn geladen. U kunt callback-functies of listeners gebruiken om een signaal te verzenden dat aangeeft dat de gegevens in het document zijn geladen.

Wanneer u gegevens laadt, kunnen deze op verschillende manieren worden opgemaakt:

  • U kunt XML laden, in welk geval u de methoden en eigenschappen van XML-klassen gebruikt om de gegevens te parseren en te gebruiken. Wanneer u naam-waardeparen gebruikt, worden de paren omgezet in variabelen en kunt u ze als variabelen manipuleren.

  • U kunt gegevens ontvangen van een webservice of via Animate Remoting.

In beide gevallen zou u complexe gegevensstructuren kunnen ontvangen, zoals arrays, objecten of recordsets, die u moet parseren en binden.

Foutafhandeling en foutopsporing gebruiken

Uw toepassing moet krachtig genoeg zijn om te anticiperen op bepaalde fouten en deze op de juiste manier te verwerken.

Een van de beste manieren om foutafhandeling toe te passen in ActionScript 2.0 is om try-catch-finally-blokken te gebruiken waarmee u aangepaste fouten kunt genereren en afvangen. Door aangepaste foutklassen te maken, kunt u code in uw toepassing opnieuw gebruiken zonder dat u de foutafhandelingscode opnieuw hoeft te schrijven. Raadpleeg de klasse Error in de Naslaggids voor ActionScript 2.0 voor meer informatie over het genereren van aangepaste fouten. Zie voor meer informatie over try-catch-finally-blokken try..catch..finally in de Naslaggids voor ActionScript 2.0 voor meer informatie.

Gebruik in ActionScript 3.0 de klasse flash.errors om fouten af te vangen.

Zie Synchrone fouten in een toepassing afhandelen in ActionScript 3.0 programmeren voor meer informatie.

Bestanden ordenen en code opslaan

Beantwoord de volgende vragen voordat u bestanden ordent en code opslaat:

  • Splitst u het SWF-bestand op in meerdere SWF-bestanden en zo ja, hoe moeten deze met elkaar communiceren?

  • Welke elementen kunt u tussen SWF-bestanden delen?

  • Welke bestanden worden dynamisch geladen?

  • Hoe en waar slaat u ActionScript-code op?

    Wanneer u een toepassing ontwikkelt, slaat u code en bestanden aan de serverzijde op in een logische mapstructuur, vergelijkbaar met die in een ActionScript-pakket. Wanneer u de code op deze manier opslaat, blijft deze goed geordend en verkleint u de kans dat de code wordt overschreven.

    Voor grotere toepassingen kunt u client/server-communicatie en -services onderbrengen in klassen. Het gebruik van klassen biedt de volgende voordelen:

  • U kunt de code opnieuw gebruiken in meerdere SWF-bestanden.

  • U kunt code bewerken op een centrale locatie en alle SWF-bestanden bijwerken door ze opnieuw te publiceren.

  • U kunt een enkele API maken die verschillende elementen van de gebruikersinterface of andere elementen kan manipuleren die soortgelijke functies uitvoeren.

Het ontwerppatroon MVC gebruiken

Het ontwerppatroon MVC wordt gebruikt om de verwerking van informatie, uitvoer en gegevens in de toepassing van elkaar te scheiden. De toepassing bestaat uit drie onderdelen: model, weergave en bediening (in het Engels: model, view en controller, kortweg MVC), waarbij elk onderdeel een ander deel van het proces afhandelt.

Het model

- omvat de gegevens en regels van de toepassing. Een groot deel van de verwerking van de toepassing vindt plaats in dit deel van het ontwerppatroon. Het model bevat ook eventuele componenten (zoals CFC's, EJB's en webservices) en de database. De geretourneerde gegevens worden in dit deel van het proces niet opgemaakt voor de interface (of front-end) van de toepassing. De geretourneerde gegevens kunnen voor verschillende interfaces (of weergaven) worden gebruikt.

De weergave

Handelt het front-end van de toepassing af (de interface waarmee de interactie met de gebruiker plaatsvindt) en rendert de inhoud van het model. De interface bepaalt hoe de gegevens van het model worden aangeboden, levert de weergave voor de gebruiker, biedt de gebruiker toegang tot de gegevens van de toepassing en maakt het mogelijk dat de gebruiker die gegevens manipuleert. Wanneer het model verandert, wordt de weergave bijgewerkt om die wijzigingen te weerspiegelen door gegevens te verzenden ('push') of op te vragen ('pull'). Wanneer u een hybride webtoepassing maakt (zoals een toepassing waarbij Animate interacties aangaat met andere toepassingen op de pagina), moet u de verschillende interfaces beschouwen als onderdeel van de weergave in het ontwerppatroon. Het ontwerppatroon MVC ondersteunt de afhandeling van diverse weergaven.

De bediening

- handelt de vereisten van het model en de weergave af om gegevens te verwerken en weer te geven en bevat gewoonlijk veel code. De bediening roept een deel van het model aan, afhankelijk van de gebruikersaanvragen vanuit de interface (of de weergave) en bevat code die specifiek is voor de toepassing. Aangezien deze code specifiek is voor de toepassing, kan deze gewoonlijk niet opnieuw worden gebruikt. De andere componenten in het ontwerppatroon kunnen echter wel opnieuw worden gebruikt. De bediening verwerkt geen gegevens en levert geen uitvoer van gegevens, maar ontvangt de aanvraag van de gebruiker en beslist welk onderdeel van het model of de weergave moet worden aangeroepen. Vervolgens wordt bepaald waar de gegevens naartoe moeten worden verzonden en welke indeling op de geretourneerde gegevens moet worden toegepast. De bediening zorgt ervoor dat weergaven toegang hebben tot de onderdelen van de modelgegevens die moeten worden weergegeven. De bediening verzendt en reageert op wijzigingen die betrekking hebben op het model en de weergave.

Elk onderdeel van het model is ontworpen als een op zichzelf staande component binnen het algemene proces. Wanneer u een onderdeel van het model wijzigt (u zou bijvoorbeeld de interface kunnen aanpassen), hoeven de andere onderdelen van het proces gewoonlijk niet te worden gewijzigd, waardoor de kans op problemen afneemt. Wanneer uw ontwerppatroon correct is opgezet, kunt u de weergave wijzigen zonder het model of de bediening te hoeven aanpassen. Wanneer uw toepassing MVC niet gebruikt, kunnen wijzigingen in de toepassing overal elders in de code doorwerken, waardoor meer wijzigingen nodig zijn dan wanneer u een specifiek ontwerppatroon gebruikt.

Een belangrijke reden om het ontwerppatroon MVC te gebruiken, is dat gegevens en logica worden gescheiden van de gebruikersinterface. Doordat deze onderdelen van het proces worden gescheiden, kunt u verschillende grafische interfaces gebruiken die hetzelfde model en dezelfde niet-opgemaakte gegevens gebruiken. Dit betekent dat u uw toepassing met verschillende Animate-interfaces kunt gebruiken, zoals een interface voor het web, een interface voor Pocket PC, een versie voor mobiele telefoons en wellicht een HTML-versie die helemaal geen gebruik maakt van Animate. Door de gegevens van de rest van de toepassing te scheiden, kan het ontwikkelen, testen en zelfs bijwerken van meerdere clientinterfaces aanzienlijk minder tijd in beslag nemen. Om dezelfde reden kunt u gemakkelijker nieuwe front-ends voor dezelfde toepassing toevoegen wanneer u een bestaand model kunt gebruiken.

Gebruik MVC alleen wanneer u een grote of complexe toepassing maakt, zoals een e-commercewebsite of een e-learningtoepassing. Het gebruik van de architectuur vereist planning en begrip van de manier waarop Animate en dit ontwerppatroon werken. Overdenk zorgvuldig de interactie tussen de verschillende delen door ze te testen en fouten op te sporen. Wanneer u MVC gebruikt, zijn tests en foutopsporing veelomvattender en ingewikkelder dan in standaard Animate-toepassingen. Wanneer u een toepassing maakt waarin u extra complexiteit nodig hebt, overweeg dan het gebruik van MVC om uw werk te ordenen.

Beveiligde toepassingen maken

Kwaadwillende gebruikers kunnen proberen uw toepassing te kraken, ongeacht of u een kleine portalsite maakt waar gebruikers zich kunnen aanmelden en artikelen kunnen lezen of een grote e-commercewinkel. Overweeg daarom de volgende stappen te nemen om uw toepassing te beveiligen.

  • Post gegevens die moeten worden beveiligd als HTTPS. Versleutel waarden in Animate voordat u deze voor verwerking naar een externe server verzendt.

     Sla informatie of code die gebruikers niet mogen zien nooit in een SWF-bestand op. SWF-bestanden kunnen gemakkelijk worden gedeassembleerd, waarna de inhoud ervan met software van derden kan worden bekeken.

  • Voeg een interdomeinbeleid toe dat voorkomt dat onbevoegde domeinen toegang krijgen tot uw elementen.

 

Krijg sneller en gemakkelijker hulp

Nieuwe gebruiker?