=======================
=======================
=======================
package
{
import flash.display.InteractiveObject;
import flash.display.LoaderInfo;
import flash.display.Sprite;
import flash.display.StageAlign;
import flash.display.StageDisplayState;
import flash.display.StageScaleMode;
import flash.events.Event;
import flash.events.MouseEvent;
import flash.geom.Point;
import flash.geom.Rectangle;
import flash.text.TextField;
import flashx.textLayout.formats.Float;
import utils.CStringTokenizer;
[SWF(width=700, height=525, backgroundColor=0xFFFFFF)]
//[SWF(backgroundColor=0x000000)]
public class FullSizeTest extends Sprite
{
//팬타곤 그래프 이미지 크기
public static var _SCREEN_W:int = 700;
public static var _SCREEN_H:int = 525;
public static var _bg:Sprite = null;
public static var _btn1:Sprite = null;
public static var _btn2:Sprite = null;
public static var _btn3:Sprite = null;
public static var _text1:TextField = null;
public static var _text2:TextField = null;
public function FullSizeTest()
{
stage.scaleMode = StageScaleMode.NO_SCALE;
stage.align = StageAlign.TOP_LEFT;
stage.fullScreenSourceRect = new Rectangle(0, 0, _SCREEN_W, _SCREEN_H); //풀사이즈를 맞춤
_bg= new Sprite();
_bg.x = 0;
_bg.y = 0;
_bg.scaleX = 1;
_bg.scaleY = 1;
_bg.width = _SCREEN_W;
_bg.height = _SCREEN_H;
_bg.graphics.beginFill(0x505050);
_bg.scaleX = 1;
_bg.scaleY = 1;
_bg.graphics.drawRect(0, 0, _SCREEN_W, _SCREEN_H);
addChild(_bg);
_btn1= new Sprite();
_btn1.buttonMode = true;
_btn1.x = 5;
_btn1.y = 5;
_btn1.width = 100;
_btn1.height = 100;
_btn1.graphics.beginFill(0x0000FF);
_btn1.scaleX = 1;
_btn1.scaleY = 1;
_btn1.graphics.drawRect(0, 0, 100, 100);
_btn1.addEventListener(MouseEvent.CLICK,
function f():void
{
_btn1.graphics.beginFill(0xFF00FF);
_btn1.scaleX = 1;
_btn1.scaleY = 1;
_btn1.graphics.drawRect(0, 0, 100, 100);
stage.displayState = StageDisplayState.FULL_SCREEN; //풀사이즈 모드
});
_text1 = new TextField();
_text1.text = "full screen";
_btn1.addChild(_text1);
addChild(_btn1);
_btn2= new Sprite();
_btn2.buttonMode = true;
_btn2.x = 150;
_btn2.y = 150;
_btn2.width = 100;
_btn2.height = 100;
_btn2.graphics.beginFill(0x00FFFF);
_btn2.scaleX = 1;
_btn2.scaleY = 1;
_btn2.graphics.drawRect(0, 0, 100, 100);
_btn2.addEventListener(MouseEvent.CLICK,
function f():void
{
_btn2.graphics.beginFill(0xFF00FF);
_btn2.scaleX = 1;
_btn2.scaleY = 1;
_btn2.graphics.drawRect(0, 0, 100, 100);
stage.displayState = StageDisplayState.NORMAL //노멀 모드
});
_text2 = new TextField();
_text2.text = "normal screen";
_btn2.addChild(_text2);
addChild(_btn2);
_btn3= new Sprite();
_btn3.buttonMode = true;
_btn3.x = 350;
_btn3.y = 350;
_btn3.width = 100;
_btn3.height = 100;
_btn3.graphics.beginFill(0x00FFFF);
_btn3.scaleX = 1;
_btn3.scaleY = 1;
_btn3.graphics.drawRect(0, 0, 100, 100);
_btn3.addEventListener(MouseEvent.CLICK,
function f():void
{
_btn3.graphics.beginFill(0xFF00FF);
_btn3.scaleX = 1;
_btn3.scaleY = 1;
_btn3.graphics.drawRect(0, 0, 100, 100);
});
addChild(_btn3);
}
public function destroy():void
{
//삭제....처리..
}
}
}
=======================
=======================
=======================
FLEX로 구현된 RIA중 전체화면모드로 전환되는 기능이 필요하여, 그 구현 방법을 찾아보았습니다.
해결책은 의외로 간단했습니다.
핵심은 Application.application.stage.displayState를 어떤 값으로 설정하느냐에 따라 바뀌는 것이었습니다.
import flash.display.StageDisplayState;
private function toggleFullScreen():void {
try {
switch (Application.application.stage.displayState) {
case StageDisplayState.FULL_SCREEN:
/* 전체화면 모드이므로 일반 화면으로 전환시킴.*/
Application.application.stage.displayState = StageDisplayState.NORMAL;
break;
default:
/* 전체화면모드가 아니므로 전체화면으로 전환함.*/
Application.application.stage.displayState = StageDisplayState.FULL_SCREEN;
break;
}
} catch (err:SecurityError) {
// 무시하기
}
}
이와 더불어 전체화면변환시 이벤트 핸들러도 설정해 주면 유용할 것 같았습니다.
우선 애플리케이션수준의 이벤트핸들러에서 전체화면 변환 이벤트핸들러를 지정해 주면 됩니다.
이제 init함수를 만들어 줘야겠지요.
private function init(evt:Event):void {
Application.application.stage.addEventListener(FullScreenEvent.FULL_SCREEN, fullScreenHandler);
}
private function fullScreenHandler(evt:FullScreenEvent):void {
if (evt.fullScreen) {
// 전체화면시 해야 할 일.
}else{
// 일반화면시 해야 할 일
}
}
자. 이것으로 FLEX쪽은 끝났습니다. 그러나 한가지 남은 일이 있었으니..SWF를 읽어오는 HTML문서에서 <object /> 또는 <embed /> 사이에 "allowFullScreen" 속성을 "true"로 설정해 주어야 합니다. FlexBuilder이용시에는 HTML래퍼에서 수정해 주어야 합니다.
AC_FL_RunContent(
"src", "main",
"width", "100%",
"height", "100%",
"align", "middle",
"id", "main",
"quality", "high",
"bgcolor", "#869ca7",
"name", "main",
"allowScriptAccess","sameDomain",
"type", "application/x-shockwave-flash",
"pluginspage", "http://www.adobe.com/go/getflashplayer",
"allowFullScreen", "true"
);
전체화면모드 사용시에는 키보드 입력이 수행되지 않습니다.
아. 그리고 Application.application대신 systemManager를 사용해도 된다네요. 이 경우에는 mx.managers.SsytemManager를 import해야겠지요.
import mx.managers.SystemManager;
systemManager.stage.displayState = StageDisplayState.NORMAL;
=======================
=======================
=======================
풀스크린 - 발췌 어도비 사이트
stage.fullScreenSourceRect = new Rectangle(0,0,320,240); stage.displayState = StageDisplayState.FULL_SCREEN;
출처: http://help.adobe.com/ko_KR/as3/dev/WS5b3ccc516d4fbf351e63e3d118a9b90204-7e31.html
Stage 클래스는 DisplayObject 클래스의 대부분의 속성과 메서드를 무시합니다. 이 무시되는 속성 또는 메서드 중 하나를 호출하면 Flash Player 및 AIR에서 예외가 발생합니다. 예를 들어, Stage 객체는 응용 프로그램에 대한 기본 컨테이너로 위치가 고정되기 때문에 x 또는 y 속성이 없습니다. x 및 y 속성은 컨테이너를 기준으로 표시 객체의 위치를 나타냅니다. 스테이지는 다른 표시 객체 컨테이너에 포함되지 않기 때문에 이러한 속성이 적용되지 않습니다.
참고: Stage 클래스의 일부 속성과 메서드는 로드된 첫 번째 SWF 파일과 동일한 보안 샌드박스에 있는 표시 객체에만 사용할 수 있습니다. 자세한 내용은 스테이지 보안을 참조하십시오.
재생 프레임 속도 제어
Stage 클래스의 frameRate 속성은 응용 프로그램에 로드된 모든 SWF 파일의 프레임 속도를 설정하는 데 사용됩니다. 자세한 내용은 Adobe Flash Platform용 ActionScript 3.0 참조 설명서를 참조하십시오.
스테이지 크기 조절 제어
화면에서 Flash Player 또는 AIR를 나타내는 부분의 크기가 조절되면 런타임의 스테이지 내용도 그에 맞게 조절됩니다. Stage 클래스의 scaleMode 속성은 스테이지 내용 조절 방식을 결정합니다. 이 속성은 flash.display.StageScaleMode 클래스의 상수로 정의되는 서로 다른 네 가지 값으로 설정할 수 있습니다.
- StageScaleMode.EXACT_FIT 내용의 원래 종횡비에 상관없이 새 스테이지 크기에 맞게 SWF를 조절합니다. 폭과 높이의 비율 인수는 변경될 수도 있으므로 스테이지의 종횡비가 변경됨에 따라 내용의 모양은 눌려지거나 늘어날 수도 있습니다.
- StageScaleMode.SHOW_ALL 내용의 종횡비를 변경하지 않고 새 스테이지 크기 전체를 채우도록 SWF를 조절합니다. 이 크기 조절 모드를 사용하면 내용의 모든 부분을 표시할 수 있지만, 표준 TV에서 와이드스크린 영화를 볼 때 나타나는 검은색 테두리와 비슷한 "레터박스" 테두리가 나타날 수도 있습니다.
- StageScaleMode.NO_BORDER 내용의 종횡비를 변경하지 않고 새 스테이지 크기를 모두 채우도록 SWF를 조절합니다. 이 크기 조절 모드는 스테이지 표시 영역을 모두 활용하지만 잘림이 일어날 수도 있습니다.
- StageScaleMode.NO_SCALE SWF의 크기를 조절하지 않습니다. 새 스테이지 크기가 더 작을 경우 내용이 잘리며 더 클 경우에는 추가된 공간은 비게 됩니다.따라서 scaleMode를 StageScaleMode.NO_SCALE로 설정하면 원하는 경우 윈도우 크기 조절에 맞춰 화면 내용을 조절하는 방법을 보다 세밀하게 제어할 수 있습니다. 예를 들어, 비디오와 컨트롤 막대가 포함된 SWF에서 스테이지의 크기를 조절할 때 컨트롤 막대를 동일한 크기로 유지하고 스테이지 크기 변경에 맞춰 비디오 윈도우의 크기만 변경할 수 있습니다. 다음 예제에서 이를 확인할 수 있습니다.
- StageScaleMode.NO_SCALE 크기 조절 모드에서만 Stage 클래스의 stageWidth 및 stageHeight 속성을 사용하여 크기 조절된 스테이지의 실제 픽셀 크기를 지정할 수 있습니다. 다른 크기 조절 모드에서는 stageWidth 및 stageHeight 속성이 항상 SWF의 원래 폭 및 높이를 반영합니다. 또한 scaleMode가StageScaleMode.NO_SCALE로 설정되고 SWF 파일의 크기가 조절된 경우 Stage 클래스의 resize 이벤트가 전달되어 이에 따라 조절할 수 있습니다.
// mainContent is a display object containing the main content;
// it is positioned at the top-left corner of the Stage, and
// it should resize when the SWF resizes.
// controlBar is a display object (e.g. a Sprite) containing several
// buttons; it should stay positioned at the bottom-left corner of the
// Stage (below mainContent) and it should not resize when the SWF
// resizes.
import flash.display.Stage;
import flash.display.StageAlign;
import flash.display.StageScaleMode;
import flash.events.Event;
var swfStage:Stage = mainContent.stage;
swfStage.scaleMode = StageScaleMode.NO_SCALE;
swfStage.align = StageAlign.TOP_LEFT;
swfStage.addEventListener(Event.RESIZE, resizeDisplay);
function resizeDisplay(event:Event):void
{
var swfWidth:int = swfStage.stageWidth;
var swfHeight:int = swfStage.stageHeight;
// Resize the main content area
var newContentHeight:Number = swfHeight - controlBar.height;
mainContent.height = newContentHeight;
mainContent.scaleX = mainContent.scaleY;
// Reposition the control bar.
controlBar.y = newContentHeight;
}
AIR 윈도우에 대한 스테이지 크기 조절 모드 설정
스테이지 scaleMode 속성은 윈도우 크기를 조정할 때 스테이지에서 자식 표시 객체를 크기 조정 및 클리핑하는 방식을 결정합니다. AIR에서는 noScale 모드만 사용해야 합니다. 이 모드에서는 스테이지가 크기 조절되지 않습니다. 대신 윈도우의 경계에 따라 스테이지의 크기가 직접적으로 변경됩니다. 윈도우 크기를 줄이면 객체가 클리핑될 수 있습니다.
스테이지 크기 조절 모드는 스테이지의 크기 또는 종횡비를 조절하지 못할 수도 있는 웹 브라우저와 같은 환경에서 사용하도록 설계되었습니다. 스테이지가 응용 프로그램의 이상적인 크기 또는 종횡비와 일치하지 않을 경우 이 모드를 통해 결과를 좀 더 개선할 수 있습니다. AIR에서는 항상 스테이지를 제어할 수 있으므로 대부분의 경우에 내용을 재배치하거나 윈도우의 크기를 조정하면 스테이지 크기 조절을 활용하는 것보다 더 좋은 결과를 얻을 수 있습니다.
브라우저 및 초기 AIR 윈도우에서는 윈도우 크기와 초기 비율 인수 사이의 관계가 로드된 SWF 파일로부터 읽혀집니다. 하지만 NativeWindow 객체를 만들 때는 AIR이 윈도우 크기와 비율 인수 72:1 사이의 임의의 관계를 선택합니다. 따라서 윈도우가 72x72 픽셀인 경우 윈도우에 10x10 사각형을 추가하면 10x10 픽셀의 올바른 크기로 그려집니다. 하지만 윈도우가 144x144 픽셀인 경우에는 10x10 픽셀 사각형이 20x20 픽셀로 크기가 조절됩니다. 그래도 윈도우 스테이지에 대해 noScale 대신 scaleMode를 사용한다면 윈도우의 모든 표시 객체에 대한 비율 인수를 스테이지의 현재 폭 및 높이에 대한 72 픽셀 비율로 설정하여 보정할 수 있습니다. 예를 들어 다음 코드에서는 client라는 표시 객체에 대한 필수 비율 인수를 계산합니다.
if(newWindow.stage.scaleMode != StageScaleMode.NO_SCALE){
client.scaleX = 72/newWindow.stage.stageWidth;
client.scaleY = 72/newWindow.stage.stageHeight;
}
참고: Flex 및 HTML 윈도우는 스테이지 scaleMode를 noScale로 자동으로 설정합니다. scaleMode를 변경하면 이러한 유형의 윈도우에서 사용되는 자동 레이아웃 메커니즘이 올바르게 작동하지 않습니다.
전체 화면 모드 작업
전체 화면 모드를 사용하면 컨테이너 테두리 또는 메뉴를 사용하지 않고 뷰어의 전체 모니터를 채우도록 동영상의 스테이지를 설정할 수 있습니다. Stage 클래스의 displayState 속성은 SWF에 대한 전체 화면 모드를 설정 및 해제하는 데 사용됩니다. displayState 속성은 flash.display.StageDisplayState 클래스에 상수로 정의된 값 중 하나로 설정할 수 있습니다. 전체 화면 모드를 설정하려면 displayState 속성을 StageDisplayState.FULL_SCREEN으로 설정합니다.
stage.displayState = StageDisplayState.FULL_SCREEN;
전체 화면 상호 작용 모드(Flash Player 11.3의 새로운 기능)를 사용하려면 displayState 속성을 StageDisplayState.FULL_SCREEN_INTERACTIVE로 설정합니다.
stage.displayState = StageDisplayState.FULL_SCREEN_INTERACTIVE;
Flash Player에서 전체 화면 모드는 ActionScript에서 마우스 클릭(오른쪽 버튼 클릭 포함) 또는 키 입력을 통해서만 시작할 수 있습니다. 응용 프로그램 보안 샌드박스에서 실행 중인 AIR 내용의 경우 사용자 동작에 응답하여 전체 화면 모드를 시작할 필요가 없습니다.
전체 화면 모드를 종료하려면 displayState 속성을 StageDisplayState.NORMAL로 설정합니다.
stage.displayState = StageDisplayState.NORMAL;
또한 사용자는 포커스를 다른 윈도우로 전환하거나 Esc 키(모든 플랫폼), Ctrl+W(Windows), Command+W(Mac), Alt+F4(Windows) 등과 같은 여러 키 조합 중 하나를 사용하여 전체 화면 모드를 해제할 수 있습니다.
Flash Player에서 전체 화면 모드 활성화
HTML 페이지에 포함된 SWF 파일에 대해 전체 화면 모드를 활성화하려면, 다음과 같이 Flash Player를 포함할 HTML 코드는 이름이 allowFullScreen이고 값이 true인 param 태그와 embed 특성을 포함해야 합니다.
<object>
...
<param name="allowFullScreen" value="true" />
<embed ... allowFullScreen="true" />
</object>
Flash 제작 도구에서 [파일] > [제작 설정]을 선택하고 [제작 설정] 대화 상자의 [HTML] 탭에서 [Flash 전용 - 전체 화면 가능] 템플릿을 선택합니다.
Flex에서는 HTML 템플릿에 전체 화면을 지원하는 <object> 및 <embed> 태그가 들어 있는지 확인합니다.
웹 페이지에서 JavaScript를 사용하여 SWF 포함 태그를 생성할 경우 allowFullScreen param 태그 및 특성을 추가하도록 JavaScript를 변경해야 합니다. 예를 들어 HTML 페이지에서 AC_FL_RunContent() 함수(Flash Professional과 Flash Builder로 생성한 HTML 페이지 모두에 사용됨)를 사용하는 경우, 다음과 같이 allowFullScreen 매개 변수를 해당 함수 호출에 추가해야 합니다.
AC_FL_RunContent( ... 'allowFullScreen','true', ... ); //end AC code
독립 실행형 Flash Player에서 실행되는 SWF 파일에는 적용되지 않습니다.
참고: 윈도우 모드(HTML에서 wmode)를 불투명 윈도우 없음(opaque) 또는 투명 윈도우 없음(transparent)으로 설정하면 전체 화면 윈도우는 항상 불투명하게 됩니다.
또한 브라우저에서 Flash Player로 전체 화면 모드를 사용하는 데는 보안 관련 제한 사항이 있습니다. 이러한 제한 사항은 보안에 설명되어 있습니다.
Flash Player 11.3 이상에서 전체 화면 상호 작용 모드 사용
Flash Player 11.3 이상에서는 전체 화면 상호 작용 모드를 지원합니다. 이 모드에서는 모든 키보드 키(전체 화면 상호 작용 모드를 종료하는 Esc 키 제외)를 사용할 수 있습니다. 전체 화면 상호 작용 모드는 게임을 할 때 유용합니다(예: 멀티 플레이 게임에서 채팅을 사용하거나, FPS(First-Person Shooter) 게임에서 WASD 키보드 제어를 사용하는 경우).
HTML 페이지에 포함된 SWF 파일에 대해 전체 화면 상호 작용 모드를 활성화하려면 다음과 같이 Flash Player를 포함할 HTML 코드에 param 태그와 embed 특성(이름이allowFullScreenInteractive이고 값이 true)이 포함되어야 합니다.
<object>
...
<param name="allowFullScreenInteractive" value="true" />
<embed ... allowFullScreenInteractive="true" />
</object>
Flash 제작 도구에서 [파일] > [제작 설정]을 선택하고 [제작 설정] 대화 상자의 [HTML] 탭에서 [Flash 전용 - 전체 화면 가능] 템플릿을 선택합니다.
Flash Builder와 Flex에서 HTML 템플릿에 전체 화면 상호 작용 모드를 지원하는 <object> 및 <embed> 태그가 포함되어야 합니다.
웹 페이지에서 JavaScript를 사용하여 SWF 포함 태그를 생성할 경우 allowFullScreenInteractive param 태그 및 특성을 추가하도록 JavaScript를 변경해야 합니다. 예를 들어 HTML 페이지에서 AC_FL_RunContent() 함수(Flash Professional과 Flash Builder에서 생성한 HTML 페이지에서 사용됨)를 사용하는 경우, 다음과 같이allowFullScreenInteractive 매개 변수를 해당 함수 호출에 추가해야 합니다.
AC_FL_RunContent( ... 'allowFullScreenInteractive','true', ... ); //end AC code
독립 실행형 Flash Player에서 실행되는 SWF 파일에는 적용되지 않습니다.
전체 화면 스테이지 크기 및 크기 조절
Stage.fullScreenHeight 및 Stage.fullScreenWidth 속성은 전체 화면 모드로 즉시 전환될 때 사용되는 모니터의 높이 및 너비를 반환합니다. 사용자가 이러한 값을 검색한 후 전체 화면 모드로 전환하기 전에 한 모니터에서 다른 모니터로 브라우저를 이동할 경우 해당 값이 잘못될 수 있습니다. Stage.displayState 속성을StageDisplayState.FULL_SCREEN으로 설정한 이벤트 핸들러에서 이러한 값을 검색할 경우 올바른 값을 갖게 됩니다. 여러 모니터를 사용하는 사용자의 경우 SWF 내용을 확장하면 모니터 하나만 채워집니다. Flash Player 및 AIR에서는 메트릭을 사용하여 SWF의 가장 많은 부분이 포함된 모니터를 확인하고, 해당 모니터에 전체 화면 모드를 적용합니다. fullScreenHeight 및 fullScreenWidth 속성은 전체 화면 모드에 사용되는 모니터의 크기만 반영합니다. 자세한 내용은 Adobe Flash Platform용 ActionScript 3.0 참조 설명서에서 Stage.fullScreenHeight 및 Stage.fullScreenWidth를 참조하십시오.
전체 화면 모드에 대한 스테이지 크기 조절 비헤이비어는 일반 모드와 동일합니다. 즉, Stage 클래스의 scaleMode 속성에 의해 크기 조절이 제어됩니다. scaleMode 속성을StageScaleMode.NO_SCALE로 설정하면 SWF에서 차지하는 화면의 크기(이 경우 전체 화면)에 따라 Stage의 stageWidth 및 stageHeight 속성이 변경됩니다. 브라우저에서 보는 경우 이 컨트롤의 HTML 매개 변수가 설정을 제어합니다.
Stage 클래스의 fullScreen 이벤트를 사용하여 전체 화면 모드가 설정 또는 해제될 때를 감지하여 응답할 수 있습니다. 예를 들어, 다음 예제처럼 전체 화면 모드를 시작하거나 해제할 때 화면에서 항목을 재배치하거나, 추가 또는 제거할 수 있습니다.
import flash.events.FullScreenEvent;
function fullScreenRedraw(event:FullScreenEvent):void
{
if (event.fullScreen)
{
// Remove input text fields.
// Add a button that closes full-screen mode.
}
else
{
// Re-add input text fields.
// Remove the button that closes full-screen mode.
}
}
mySprite.stage.addEventListener(FullScreenEvent.FULL_SCREEN, fullScreenRedraw);
이 코드에 표시된 것처럼 fullScreen 이벤트에 대한 이벤트 객체는 flash.events.FullScreenEvent 클래스의 인스턴스이며, 전체 화면 모드가 활성화되는지(true) 또는 비활성화되는지(false)를 나타내는 fullScreen 속성을 포함합니다.
전체 화면 모드에서 키보드 지원
브라우저에서 Flash Player가 실행될 때 키보드 이벤트 및 TextField 인스턴스의 텍스트 입력 등과 같은 모든 키보드 관련 ActionScript는 전체 화면 모드에서 비활성화됩니다. 다음과 같은 예외(키 활성화)가 있습니다.
- 인쇄되지 않는 키(예: 화살표 키, 스페이스바, Tab 키) 선택
- 전체 화면 모드를 종료하는 키보드 단축키: Esc(Windows 및 Mac), Ctrl-W(Windows), Command-W(Mac) 및 Alt-F4
SWF 내용을 독립 실행형 Flash Player 또는 AIR에서 실행 중인 경우에는 이러한 제한 사항이 없습니다. AIR에서는 키보드 입력을 허용하는 대화형 전체 화면 모드를 지원합니다.
전체 화면 모드의 마우스 지원
기본적으로 전체 화면 모드의 마우스 이벤트는 전체 화면 모드가 아닌 경우와 동일하게 작동합니다. 그러나 전체 화면 모드에서는 선택적으로 Stage.mouseLock 속성을 설정하여 마우스 잠금을 활성화할 수 있습니다. 마우스 잠금을 활성화하면 커서가 비활성화되고 마우스를 제한 없이 움직일 수 있습니다.
참고: 마우스 잠금은 데스크톱 응용 프로그램의 전체 화면 모드에서만 활성화할 수 있습니다. 전체 화면 모드가 아닌 응용 프로그램이나 휴대·장치의 응용 프로그램에서 설정하면 예외가 발생합니다.
다음과 같은 경우에는 마우스 잠금이 자동으로 비활성화되고 마우스 커서가 다시 표시됩니다.
- 사용자가 Esc 키(모든 플랫폼), Ctrl+W(Windows), Command+W(Mac) 또는 Alt+F4(Windows)를 사용하여 전체 화면 모드를 종료하는 경우
- 응용 프로그램 윈도우가 포커스를 잃는 경우
- [개인 정보] 대화 상자를 포함한 모든 설정 UI가 표시되는 경우
- [파일 업로드] 대화 상자 같은 기본 대화 상자가 표시되는 경우
마우스 이동과 관련된 이벤트(예: mouseMove 이벤트)는 MouseEvent 클래스를 사용하여 이벤트 객체를 나타냅니다. 마우스 잠금이 비활성화된 경우 MouseEvent.localX 및MouseEvent.localY 속성을 사용하여 마우스 위치를 확인합니다. 마우스 잠금이 활성화된 경우에는 MouseEvent.movementX 및 MouseEvent.movementY 속성을 사용하여 마우스 위치를 확인합니다. movementX 및 movementY 속성에는 마우스 위치의 절대 좌표 대신 마지막 이벤트 이후 마우스 위치의 변경 사항이 포함됩니다.
하드웨어를 통해 전체 화면 모드로 크기 조절
Stage 클래스의 fullScreenSourceRect 속성을 사용하여 Flash Player 또는 AIR에서 스테이지의 특정 영역이 전체 화면 모드로 확대되도록 설정합니다. Flash Player 및 AIR는 하드웨어를 통해 크기를 조절합니다. 이 경우 사용자의 컴퓨터에 장착된 그래픽 및 비디오 카드를 사용하며 일반적으로 소프트웨어로 크기를 조절할 때보다 더욱 빠르게 내용을 표시합니다.
하드웨어적인 크기 조절을 활용하려면 모든 스테이지나 스테이지의 일부를 전체 화면 모드로 설정합니다. 다음 ActionScript 3.0 코드는 모든 스테이지를 전체 화면 모드로 설정합니다.
import flash.geom.*; { stage.fullScreenSourceRect = new Rectangle(0,0,320,240); stage.displayState = StageDisplayState.FULL_SCREEN; }
이 속성이 유효한 사각형으로 설정되고 displayState 속성이 전체 화면 모드로 설정된 경우 Flash Player 및 AIR가 지정된 영역의 크기를 조절합니다. ActionScript 내에서 픽셀 단위의 실제 스테이지 크기는 변경되지 않습니다. Flash Player 및 AIR는 "전체 화면 모드를 종료하려면 Esc를 누르십시오"라는 표준 메시지를 수용하도록 사각형의 크기에 대해 최소 제한을 적용합니다. 이 제한은 대개 약 260 x 30 픽셀이지만 플랫폼과 Flash Player 버전에 따라 다를 수 있습니다.
fullScreenSourceRect 속성은 Flash Player 또는 AIR가 전체 화면 모드가 아닌 경우에만 설정할 수 있습니다. 이 속성을 정확히 사용하려면 먼저 이 속성을 설정한 다음displayState 속성을 전체 화면 모드로 설정합니다.
크기 조절을 활성화하려면 fullScreenSourceRect 속성을 rectangle 객체로 설정합니다.
stage.fullScreenSourceRect = new Rectangle(0,0,320,240);
크기 조절을 비활성화하려면 fullScreenSourceRect 속성을 null로 설정합니다.
stage.fullScreenSourceRect = null;
Flash Player의 모든 하드웨어 가속 기능을 사용하려면 [Flash Player 설정] 대화 상자를 통해 활성화합니다. 브라우저에서 Flash Player 내용을 마우스 오른쪽 버튼으로 클릭(Windows)하거나 Control 키를 누른 상태에서 클릭(Mac)하여 대화 상자를 로드합니다. 첫 번째 탭인 [표시] 탭을 선택하고 [하드웨어 가속 사용] 체크 상자를 클릭합니다.
직접 및 GPU 합성 윈도우 모드
Flash Player 10에는 직접 및 GPU 합성 모드라는 두 가지 윈도우 모드가 새로 추가되었습니다. 이러한 모드는 Flash 제작 도구의 제작 설정을 통해 활성화할 수 있습니다. AIR에서는 이러한 모드가 지원되지 않습니다. 이러한 모드를 사용하려면 Flash Player의 하드웨어 가속을 사용하도록 설정해야 합니다.
직접 모드는 가장 빠르고 직접적인 경로를 사용하여 화면에 그래픽을 표시하므로 비디오 재생에 적합합니다.
GPU 합성은 비디오 카드의 GPU(Graphics Processing Unit)를 사용하여 합성 속도를 빠르게 합니다. 비디오 합성은 단일 비디오 이미지를 만들기 위해 여러 개의 이미지를 겹치는 프로세스입니다. GPU로 합성을 빠르게 할 경우 YUV 변환, 색상 교정, 회전 또는 크기 조절, 블렌딩의 성능을 향상시킬 수 있습니다. YUV 변환은 전송에 사용되는 합성 아날로그 신호를 비디오 카메라 및 디스플레이에 사용되는 RGB(빨강, 녹색, 파랑) 색상 모델로 색상 변환하는 것을 나타냅니다. GPU를 사용하여 합성을 빠르게 하면 CPU에 대한 메모리 및 계산 요청을 줄일 수 있습니다. 또한 표준 정의 비디오를 보다 부드럽게 재생할 수 있습니다.
이러한 윈도우 모드를 구현할 때는 주의해야 합니다. GPU 합성을 사용할 경우 메모리 및 CPU 리소스가 많이 소모될 수 있습니다. 블렌드 모드, 필터링, 자르기, 마스크 적용 등의 일부 작업은 GPU에서 수행할 수 없는 경우 소프트웨어에서 수행됩니다. 이러한 모드를 사용하고 있으며 배너에는 이러한 모드를 사용하지 않아야 하는 경우 HTML 페이지당 하나의 SWF 파일을 사용하도록 제한하는 것이 좋습니다. Flash 동영상 테스트 기능에는 하드웨어 가속이 사용되지 않지만 [제작 미리 보기] 옵션을 통해 하드웨어 가속을 사용할 수 있습니다.
SWF 파일의 프레임 속도를 60보다 높게 설정할 경우 최대 화면 새로 고침 속도는 쓸모가 없습니다. 프레임 속도를 50에서 55 사이로 설정하면 이따금 다양한 이유로 발생할 수 있는 프레임 삭제가 허용됩니다.
직접 모드를 사용하려면 Microsoft DirectX 9와 VRAM 128MB(Windows의 경우) 및 OpenGL(Apple Macintosh, Mac OS X v10.2 이상의 경우)이 필요합니다. GPU 합성을 사용하려면 128MB의 VRAM이 장착된 Windows에서 Microsoft DirectX 9 및 Pixel Shader 2.0이 지원되어야 합니다. Mac OS X 및 Linux에서 GPU 합성을 사용하려면 OpenGL 1.5 및 여러 OpenGL 확장(예: framebuffer 객체, multitexture, shader 객체, 셰이딩 언어, 부분 셰이더)이 필요합니다.
Flash [제작 설정] 대화 상자의 [Flash] 탭에 있는 [하드웨어 가속] 메뉴를 통해 SWF별로 직접 및 GPU
=======================
=======================
=======================
출처: http://flashfriend.tistory.com/1360
1. 풀스크린이 막힌 사이트
플래시의 풀스크린 변환이 막혀있는 웹페이지에서 풀스크린 코드를 실행하면,
아무 오류메세지가 생지지 않으면서,
단지 그 코드 아래쪽의 코드가 모두 실행 중단 됩니다.
주의하세요.
2. 풀스크린의 시작 방식제한
풀스크린 변환이 막혀있다는 말은 플래시를 embed 하는 태그에서 allowFullScreen값을 false로 했다는 뜻입니다.
만약 allowFullScreen값을true로 하더라도, 클릭이 아닌 방식으로 풀스크린 명령을 실행하면, 오류가 발생합니다.
버튼 같은 것을 만들고, 클릭이벤트에서 풀스크린 변환을 해주어야 합니다.
3. 변칙 불가능
funcFullScreen( new MouseEvent( 'click', true, false, 10, 10, this,false,false,false,true ) )
처럼 마우스이벤트 함수를 가상으로 만들어 쓴다고 하여 풀스크린을 강제 실행할 수 없습니다.
4. 키보드 입력 불가
잘 모르는 분들이 많은데, 풀스크린 모드를 사용하면 키보드 입력이 되지 않습니다.
방향키와 ESC 제외하고, 다 안됩니다.
만약 풀스크린 상태에서도 키보드 입력을 받고 싶다면,
StageDisplayState.FULL_SCREEN_INTERACTIVE로 변환을 해주면 됩니다.
단, 이 모드를 사용하려면 AIR 이거나 플래시플레이어 11.3 이상 이어야 합니다.
=======================
=======================
=======================
출처: http://stackoverflow.com/questions/5957724/scalling-flashpunk-game-for-fullscreen
I'm making a Flash game with FlashPunk. When I press Ctrl+F Flash goes fullscreen but the game stays at the original size, aligned to the top-left corner. How can I specify to FlashPunk that I want the game scalled to the size of the screen? (keeping aspect ratio, off course) Thanks flash fullscreen |
5 Answers
You can control scaling in OBJECT attributes when you embed the Flash into HTML. Usescale=default to scale maintain aspect ratio. When you run the Flash in player, use menu item View->Show All which functions same as scale=default in OBJECT in HTML. |
Scaling your flash movie will decrease performance significantly. I urge you not to do this for any reason. I'm not sure what flash punk is, but try using this: |
You could hook into the resize event and scale it in code |
The best way to do this, is to override the setStageProperties public function in your main class (in FlashPunk, your main class should be extending the Engine class) |
Take a look at the FP class in flashpunk. Specifically FP.screen.scale which lets you resize your entire game by a specified factor. For example, the code below will double the size of your game screen: FP.screen.scale = 2; If you need to worry about the aspect ratio, you can do X and Y separately with: After you go to fullscreen, you can use the code below to get the correct aspect ratio for enlarging your screen: |
=======================
=======================
=======================
출처: http://www.saybox.co.kr/bbs/board.php?bo_table=flash&wr_id=4
참고 : http://www.adobe.com/devnet/flashplayer/articles/full_screen_mode.html
본 코드는 Flash Player9 이상에서 작동하며 Html단의 object태그에 다음 붉은 글씨가 추가로 삽입된다.
--------------------------------------------------------------------------------------------
<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,18,0"
width="600" height="400" id="fullscreen" align="middle">
<param name="allowFullScreen" value="true" />
<param name="movie" value="fullscreen.swf" />
<param name="bgcolor" value="#333333" />
<embed src="fullscreen.swf" allowFullScreen="true" bgcolor="#333333" width="600" height="400"
name="fullscreen" align="middle" type="application/x-shockwave-flash"
pluginspage="http://www.macromedia.com/go/getflashplayer" />
</object>
-----------------------------------------------------------------------
다음의 예제 코드는 플래시영역에서 마우스 오른쪽 버튼을 눌렀을경우 풀스크린 메뉴를 추가. 기능을작동시키는
펑션으로 구성되어 있다.
AS3.0에서 중요한 문장
------------------------------------------------------------------------
//풀창
stage.displayState = StageDisplayState.FULL_SCREEN;
//노멀창
stage.displayState = StageDisplayState.NORMAL;
----------------------------------------------------------------
AS2.0에서 중요한 문장
------------------------------------------------------------------------
//풀창
Stage["displayState"] = "fullScreen";
//노멀창
Stage["displayState"] = "normal";
----------------------------------------------------------------
AS3.0 형식
import flash.display.Stage;
import flash.display.StageDisplayState;
import flash.display.InteractiveObject.*;
import flash.events.*;
// functions to enter and leave full screen mode
function goFullScreen(event:ContextMenuEvent):void
{
stage.displayState = StageDisplayState.FULL_SCREEN;
}
function exitFullScreen(event:ContextMenuEvent):void
{
stage.displayState = StageDisplayState.NORMAL;
}
// function to enable and disable the context menu items,
// based on what mode we are in.
function menuHandler(event:ContextMenuEvent):void
{
if (stage.displayState == StageDisplayState.NORMAL)
{
event.target.customItems[0].enabled = true;
event.target.customItems[1].enabled = false;
}
else
{
event.target.customItems[0].enabled = false;
event.target.customItems[1].enabled = true;
}
}
// create the context menu, remove the built-in items,
// and add our custom items
var fullscreenCM:ContextMenu = new ContextMenu();
fullscreenCM.addEventListener(ContextMenuEvent.MENU_SELECT, menuHandler);
fullscreenCM.hideBuiltInItems();
var fs:ContextMenuItem = new ContextMenuItem("Go Full Screen" );
fs.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, goFullScreen);
fullscreenCM.customItems.push( fs );
var xfs:ContextMenuItem = new ContextMenuItem("Exit Full Screen");
xfs.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, exitFullScreen);
fullscreenCM.customItems.push( xfs );
// finally, attach the context menu to a movieclip
mc.contextMenu = fullscreenCM;
------------------------------------------------------------------------------------------------/
AS2.0 형식
// functions to enter and leave full screen mode
function goFullScreen() {
Stage["displayState"] = "fullScreen";
}
function exitFullScreen() {
Stage["displayState"] = "normal";
}
// function to enable, disable context menu items, based on which mode we are in.
function menuHandler(obj, menuObj) {
if (Stage["displayState"] == "normal") {
// if we're in normal mode, enable the 'go full screen' item, disable the 'exit' item
menuObj.customItems[0].enabled = true;
menuObj.customItems[1].enabled = false;
} else {
// if we're in full screen mode, disable the 'go full screen' item, enable the 'exit' item
menuObj.customItems[0].enabled = false;
menuObj.customItems[1].enabled = true;
}
}
// create a new context menu
var fullscreenCM:ContextMenu = new ContextMenu(menuHandler);
// hide the regular built-in items
fullscreenCM.hideBuiltInItems();
// now, add the items to enter and leave full screen mode
var fs:ContextMenuItem = new ContextMenuItem("Go Full Screen", goFullScreen);
fullscreenCM.customItems.push( fs );
var xfs:ContextMenuItem = new ContextMenuItem("Exit Full Screen", exitFullScreen);
fullscreenCM.customItems.push( xfs );
// now, attach the context menu to any movieclip in your movie.
// here we attach it to _root, (even though using _root is generally a bad idea,)
// so it will appear if you right click anywhere on the movie.
_root.menu = fullscreenCM;
=======================
=======================
=======================
일단 비디오 불러오기로 flv 파일을 불러 오시고 flvplayback 위에 알파값이 0 인 무비클립을 하나 만들어 줍니다
그리고 아래와 같은 코드를 액션창에 기입합니다
import fl.video.VideoEvent;
//이부분은 AS3.0 으로 만드는 flv를 따와서 만드는 플짤을 참고하시기 바랍니다
mov.autoRewind = true;
//저는 flvplayback의 인스턴스네임을 mov로 지정했습니다
//이부분 역시 AS3.0 으로 만드는 flv를 따와서 만드는 플짤을 참고 하시기 바랍니다
mov.addEventListener(fl.video.VideoEvent.REWIND, _rewind);
//이부분도...
btn.buttonMode = true;
//btn이라는 무비클립의 버튼모드를 작동하게 하는 코드 입니다
//역시 안하셔도 기능상의 차이는 없습니다
btn.addEventListener(MouseEvent.CLICK, _click);
//클릭 했을때 _click 이라는 이벤트가 발생한다는 것입니다
function _click(e:MouseEvent):void
{
stage.displayState = "fullScreen"
//이게 바로 풀스크린을 만드는 코드 입니다 사실 이 강좌는 이거 하나 표현하기위해 만든겁니다
}
function _rewind(e:fl.video.VideoEvent):void
{
trace("완료");
MovieClip(this.root).mov.play();
}
//이부분은 지난 예제와 같습니다....
뭐 이러이러 합니다
중요한 점은 stage.displayState = "fullScreen" 입니다
예제가 flv를 따서 쓰는 방식이라 나머지 코드가 필요했지 실상 풀스크린 모드를 만드는 코드는 저것입니다
풀스크린에서 일반 크기로 다시 되돌리는 코드는 state.displayState = "normal" 입니다
물론 esc를 누르면 되돌아오기 때문에 저는 위와 같은 코드를 안 썻습니다
또한 풀스크린이 되도 플래시 크기가 변형되지 않길 원한다면 stage.scaleMode = StageScaleMode.NO_SCALE;
이 코드를 써 넣어주시길 바랍니다
뭐 나머지 풀스크린에 대한 내용은 help를 참조해 주시기 바라고
예제와 같은 플짤을 만들고 플래시에서 실험을 하면 잘 나옴니다
근데 웹에 올린다 치면 하나 더 써줘야 하는 태그가 잇습니다
<embed src=http://mediafile.dcinside.com/data17/gallery/2009/11/03/4/
2077729628_e53516ac_090614-Boo.swf" quality="high" bgcolor="#ffffff"
width="400" height="300" name="090614-Boo" align="middle" ="sameDomain"
allowFullScreen="true" type="application/x-shockwave-flash"
pluginspage="http://www.adobe.com/go/getflashplayer" />
바로 이것입니다
=======================
=======================
=======================
출처: http://cafe.naver.com/flashdev/62087
비율유지, ScaleMode.. 작업하다 열받아서 만들었어요^^ | | | 내가 만든 플래시 |
http://cafe.naver.com/flashdev/62087 |
^^안녕하세요..
회사에서 스크린세이버 제작하다가..
stage.scaleMode 를 쓸수 없는 상황에 부딪혀서 만든..
허접한.. scaleMode 테스트 용입니다 ㅋ
stage 값이 마구 변해도.. 컨텐츠가 항상 원하는 비율을 유지하면서..
축소/확대 되도록 만들어 봤어요..
아 그런데..올리고 보니..^^;; 다운 받아서 보셔야..
창을 잡고 이리저리 늘렸다 줄였다..테스트를 할 수 있겠군요 ㅋㅋ^^;;
허접한 스킬이지만.. 퇴근전.. 나름 뿌듯해 하며.. 올려놓고 갑니다.ㅋㅋ
한해 마무리들 잘하세요~
엉성한 코드지만..ㅋ
혹시 이런거 수학공식이라든지.. 아니면 좀 쳐내야할 코드가 있을까요?..
↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
stage.scaleMode = StageScaleMode.NO_SCALE;
import flash.events.Event;
var sw:Number; // stage의 width
var sh:Number; // stage의 height
var wx:Number; // stage width의 정수 배율(w_x대비)
var hx:Number; // stage height의 정수 배율(h_x대비)
var wl:Number; // stage width와 w_x:8 대비 배율 정수의 차
var hl:Number; // stage height와 w_x:8 대비 배율 정수의 차
var w_x:Number = 16; // width 비율
var h_x:Number = 9; // height 비율
// mw : mh = w_x : h_x 임의로 16:9 로 해놨습니다^^
mc.width = stage.stageWidth; // mc.width 초기값 => stage와 같게
mc.height = stage.stageHeight; // mc.width 초기값 => stage와 같게
stage.addEventListener(Event.RESIZE,resizeHandler)
function resizeHandler(e:Event):void{
sw = stage.stageWidth;
sh = stage.stageHeight;
wx = Math.floor(sw/w_x);
hx = Math.floor(sh/h_x);
wl = sw - wx*w_x;
hl = sh - hx*h_x;
if(wx > hx){ // width의 배율이 height의 배율보다 클 때,
mc.height = sh;
mc.width = sh*(w_x/h_x);
}else if(wx < hx){ // height의 배율이 width의 배율보다 클 때,
mc.width = sw;
mc.height = sw*(h_x/w_x);
}else{ // width와 height의 정수 배율이 같을 때,
if(wl>hl){ // width의 배율 대비차가 더 클때,
mc.width = sw;
mc.height = sw*(hx/wx)*(h_x/w_x);
}else if(wl<hl){ // height의 배율 대비차가 더 클때,
mc.height = sh;
mc.width = sh*(wx/hx)*(w_x/h_x);
}else{ // 배율 대비차가 같을 때,
mc.width = sw;
mc.height = sh;
}
}
}
//========= by Mistmini
=======================
=======================
=======================
출처: http://blog.naver.com/nanan75?Redirect=Log&logNo=70136261192
(toggleFullScreenBtn.content as MovieClip).gotoAndStop(1);
toggleFullScreenBtn
은
<s:SWFLoader id="toggleFullScreenBtn" source="assets/swfs/main/toggleFullScreenBtn.swf" width="96" height="26" top="10"/>
보다시피
SWFLoader 컴포넌트다..
내가 하고자 했던것은
ESC 를 눌러 풀스크린에서 노멀모드로 전환시
플래시 컨텐츠로 있는 버튼을 1프레임으로 이동하고 싶었던 상황이다.
stage.addEventListener(FullScreenEvent.FULL_SCREEN, changeFullScreen);
private function changeFullScreen(evt:FullScreenEvent):void{
trace("changeFullScreen!!");
if(stage.displayState==StageDisplayState.NORMAL){
(toggleFullScreenBtn.content as MovieClip).gotoAndStop(1);
}
}
해결!!
쉽~~~네..
[출처] [Tip!]flex 개발시 swfLoader에 접근하기|작성자 나난
=======================
=======================
=======================
'ADOBE > ActionScript' 카테고리의 다른 글
[AS] 액션스크립트 SharedObject 쿠키와 비슷하게 저장 제어 관련 (0) | 2020.09.22 |
---|---|
[AS] 액션스크립트 쿠키 제어 관련 (0) | 2020.09.21 |
[AS] 플래시 AS3.0 이벤트 관련 (0) | 2020.09.21 |
플래시 AIR 액션스크립트로 다른 프로그램 실행 시키기 관련 (0) | 2020.09.21 |
[AS] 플래시 air 스마트기기개발 안드로이드, iOS 내에 package된 리소스 파일 file객체로 사용하기 관련 (0) | 2020.09.21 |