Skip to main content

AS3: Custom Dropdown


Here is the code for the custom dropdown component.
/**
 * @file Sample.fla
 * @author Abhishek Kumar
 */
import com.engine.CDropdown;
import flash.display.MovieClip;

var cb:CDropdown = new CDropdown(dropdown_mc, onclick);
cb.attachListeners();

function onclick(mc:MovieClip):void
{
 trace(mc.name);
}

The pseudo code of application (Sample.fla) design architecture.
{
 movieclip: 'dropdown_mc'
 {
  movieclip: 'controller'
  {
   textfield: 'caption',
   frames: [up, over, down]
  }
  movieclip: 'dropdown'
  {
   movieclip: 'item0'
   { 
    textfield: 'caption',
    movieclip: 'selected',
    frames: [up, over, down]
   }
   movieclip: 'item1'
   { 
    textfield: 'caption',
    movieclip: 'selected',
    frames: [up, over, down]
   }
   movieclip: 'item2'
   { 
    textfield: 'caption',
    movieclip: 'selected',
    frames: [up, over, down]
   }
   movieclip: 'item3'
   { 
    textfield: 'caption',
    movieclip: 'selected',
    frames: [up, over, down]
   }
  }
 }
}

The source code of the component library.
/**
 * @file Dropdown.as
 * @author Abhishek Kumar
 */
package com.engine 
{
 import flash.display.MovieClip;
 
 public class CDropdown 
 {
  private var container:MovieClip;
  private var proceed:Function;
  
  private var controller:CButton;
  private var dropdown:CList;
  private var isopen:Boolean;
  
  public function CDropdown(mc:MovieClip, fn:Function) 
  {
   container = mc;
   proceed = fn;
   
   initialize();
  }
  
  private function initialize():void
  {  
   isopen = false;
   controller = new CButton(container.controller, onCick_controller);
   dropdown = new CList(container.dropdown, onClick_dropdown, 4);
   dropdown.hide();
  }
  
  public function attachListeners():void
  {
   controller.attachListeners();
  }
  
  public function detachListeners():void
  {
   controller.detachListeners();
  }
  
  private function onCick_controller(mc:MovieClip):void
  {
   if (isopen)
   {
    dropdown.hide();
    dropdown.detachListeners();
   }
   else
   {
    dropdown.attachListeners();
    dropdown.show(); 
   }
   isopen = !isopen;
  }
  
  private function onClick_dropdown(mc:MovieClip):void
  {
   proceed(mc);
  }
 }

}

/**
 * @file CList.as
 * @author Abhishek Kumar
 */
package com.engine 
{
 import flash.display.MovieClip;
 
 public class CList 
 {
  private var container:MovieClip;
  private var proceed:Function;
  
  private var items:Array;
  private var itemcount:int;
  
  public function CList(mc:MovieClip, fn:Function, icount:int) 
  {
   container = mc;
   proceed = fn;
   
   itemcount = icount;
   
   initialize();
  }
  
  private function initialize():void
  {  
   items = [];
   for (var i:int = 0; i < itemcount; i++)
   {
    if(container['item' + i].getChildByName('selected') != null)
    {
     container['item' + i].selected.visible = false;
    }    
    items[i] = new CButton(container['item' + i], onClick);
   }
  }
  
  public function attachListeners():void
  {
   for (var i:int = 0; i < itemcount; i++)
   {
    CButton(items[i]).attachListeners();
   }
  }
  
  public function detachListeners():void
  {
   for (var i:int = 0; i < itemcount; i++)
   {
    CButton(items[i]).detachListeners();
   }
  }
  
  private function onClick(mc:MovieClip):void
  {
   for (var i:int = 0; i < itemcount; i++)
   { 
    if(container['item' + i].getChildByName('selected') != null)
    {   
     container['item' + i].selected.visible = (mc.name == 'item' + i);
    }
   }
   proceed(mc);
  }
  
  public function show():void
  {
   container.visible = true;
  }
  
  public function hide():void
  {
   container.visible = false;
  }
  
 }

}

/**
 * @file CButton.as
 * @author Abhishek Kumar
 */
package com.engine 
{
 import flash.display.MovieClip;
 import flash.events.MouseEvent;
 public class CButton 
 {
  private var container:MovieClip;
  private var proceed:Function;
  
  public function CButton(mc:MovieClip, fn:Function) 
  {
   container = mc;
   proceed = fn;
   
   initialize();
  }
  
  private function initialize():void
  {   
   container.gotoAndStop('up');
   container.buttonMode = true;
   container.mouseChildren = false;
  }
  
  public function attachListeners():void
  {
   container.addEventListener(MouseEvent.MOUSE_UP, onMouseUp);
   container.addEventListener(MouseEvent.MOUSE_DOWN, onMouseDown);
   container.addEventListener(MouseEvent.MOUSE_OVER, onMouseOver);
   container.addEventListener(MouseEvent.MOUSE_OUT, onMouseOut);
  }
  
  public function detachListeners():void
  {
   container.removeEventListener(MouseEvent.MOUSE_UP, onMouseUp);
   container.removeEventListener(MouseEvent.MOUSE_DOWN, onMouseDown);
   container.removeEventListener(MouseEvent.MOUSE_OVER, onMouseOver);
   container.removeEventListener(MouseEvent.MOUSE_OUT, onMouseOut);
  }
  
  private function onMouseUp(me:MouseEvent):void
  {
   container.gotoAndStop('up');
   proceed(me.target);
  }
  
  private function onMouseDown(me:MouseEvent):void
  {
   container.gotoAndStop('down');
  }
  
  private function onMouseOver(me:MouseEvent):void
  {
   container.gotoAndStop('over');
  }
  
  private function onMouseOut(me:MouseEvent):void
  {
   container.gotoAndStop('up');
  }
  
  public function show():void
  {
   container.visible = true;
  }
  
  public function hide():void
  {
   container.visible = false;
  }
  
 }

}

Comments

  1. Damn, why you don't publish the sources?!

    ReplyDelete

Post a Comment

Popular posts from this blog

Unlock protected blocks in Siemens SIMATIC Step 7

Recently I'd been called by Hindalco's Fabrication Plant division to unlock the protected blocks in Siemens SIMATIC Step 7. They were in need to unlock those blocks since an year because of 1 million Rupees of loss per month. They want to re-program those blocks but it was locked by the man who'd done the setup. From the people working in that department, I came to know that they were trying to call that man (someone from Italy) right here but he's not coming. Actually, what he'd done was that he'd locked some of the blocks and deleted the source file. And Siemens didn't provide any feature to unlock. Department people also told me that even the people working in Siemens don't know how to do it. Being a software engineer I know that any thing can be reverse engineered. So I took up the challenge. How did I unlocked the blocks? The first thing I'd done was searched about this software at Google and read about what is this software all about. Aft...

Launching a Jupyter Notebook with TensorFlow using Docker

This article will walk you through setting up a Jupyter Notebook environment with TensorFlow pre-installed using Docker. Docker allows you to run isolated containerized applications, providing a consistent environment regardless of your underlying operating system. Prerequisites: Docker: Ensure you have Docker installed and running on your system. You can download and install it from the official Docker website ( https://www.docker.com/ ). Steps: Start Docker: Open your Docker application (Docker Desktop for Windows/macOS or the command line if using Linux). Run the Jupyter Notebook container: For macOS/Linux: Open your terminal application and run the following command: docker run -it --rm -p 8888:8888 -v "${PWD}":/home/jovyan/work jupyter/tensorflow-notebook For Windows: Open your Command Prompt application and run the following command: docker run -it --rm -p 8888:8888 -v "%CD%":/home/jovyan/work jupyter/tensorflow-notebook Explanation of the command flags: -...

JS: The complete code example of Crypto.js (DES)

For one of the project I was trying to use crypto.js but I found that the Quick-start Guide have some deficiency in terms of library usage. So I am writing it here as a useful note for memory recap. <script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/rollups/tripledes.js"></script> <script> var encrypted = CryptoJS.DES.encrypt("The secret message", "secret_key"); var e_msg = encrypted.toString(); console.log(e_msg); var decrypted = CryptoJS.DES.decrypt(e_msg, "secret_key"); var d_msg = decrypted.toString(CryptoJS.enc.Utf8); console.log(d_msg); </script>