/*
- * Copyright (c) 2015 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2017 Samsung Electronics Co., Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
#include <dali/dali.h>
#include <dali-toolkit/dali-toolkit.h>
+#include <dali-toolkit/devel-api/controls/buttons/button-devel.h>
using namespace Dali;
using namespace Toolkit;
const char* const PLAY_FILE = DEMO_VIDEO_DIR "demoVideo.mp4";
const char* const PLAY_IMAGE = DEMO_IMAGE_DIR "icon-play.png";
const char* const PAUSE_IMAGE = DEMO_IMAGE_DIR "Pause.png";
- const char* const STOP_IMAGE = DEMO_IMAGE_DIR "icon-stop.png";
- const char* const RESET_IMAGE = DEMO_IMAGE_DIR "icon-reset.png";
+ const char* const CHANGE_IMAGE = DEMO_IMAGE_DIR "icon-change.png";
const char* const FORWARD_IMAGE = DEMO_IMAGE_DIR "Forward.png";
const char* const BACKWARD_IMAGE = DEMO_IMAGE_DIR "Backward.png";
VideoViewController( Application& application )
: mApplication( application ),
mIsPlay( false ),
- mIsStop( false ),
mIsFullScreen( false ),
- mScale( 1.f )
+ mScale( 1.f ),
+ mPinchStartScale( 1.0f )
{
// Connect to the Application's Init signal
mApplication.InitSignal().Connect( this, &VideoViewController::Create );
void Create( Application& application )
{
+ application.GetWindow().ShowIndicator( Dali::Window::INVISIBLE );
+
mStageSize = Stage::GetCurrent().GetSize();
mVideoView = Toolkit::VideoView::New();
mPauseButton.SetPosition( 40, 10 );
mPauseButton.ClickedSignal().Connect( this, &VideoViewController::OnButtonClicked );
- mStopButton = PushButton::New();
- mStopButton.SetParentOrigin( ParentOrigin::TOP_LEFT );
- mStopButton.SetAnchorPoint( AnchorPoint::TOP_LEFT );
- mStopButton.SetName( "Stop" );
- mStopButton.SetResizePolicy( ResizePolicy::FIXED, Dimension::ALL_DIMENSIONS );
- mStopButton.SetSize( BUTTON_SIZE, BUTTON_SIZE );
- mStopButton.SetPosition( 140, 10 );
- mStopButton.ClickedSignal().Connect( this, &VideoViewController::OnButtonClicked );
-
- mResetButton = PushButton::New();
- mResetButton.SetParentOrigin( ParentOrigin::TOP_LEFT );
- mResetButton.SetAnchorPoint( AnchorPoint::TOP_LEFT );
- mResetButton.SetName( "Reset" );
- mResetButton.SetResizePolicy( ResizePolicy::FIXED, Dimension::ALL_DIMENSIONS );
- mResetButton.SetSize( BUTTON_SIZE, BUTTON_SIZE );
- mResetButton.SetPosition( 140, 10 );
- mResetButton.ClickedSignal().Connect( this, &VideoViewController::OnButtonClicked );
+ mChangeButton = PushButton::New();
+ mChangeButton.SetParentOrigin( ParentOrigin::TOP_LEFT );
+ mChangeButton.SetAnchorPoint( AnchorPoint::TOP_LEFT );
+ mChangeButton.SetName( "Change" );
+ mChangeButton.SetResizePolicy( ResizePolicy::FIXED, Dimension::ALL_DIMENSIONS );
+ mChangeButton.SetSize( BUTTON_SIZE, BUTTON_SIZE );
+ mChangeButton.SetPosition( 140, 10 );
+ mChangeButton.ClickedSignal().Connect( this, &VideoViewController::OnButtonClicked );
mBackwardButton = PushButton::New();
mBackwardButton.SetParentOrigin( ParentOrigin::TOP_LEFT );
mMenu.Add( mPlayButton );
mMenu.Add( mPauseButton );
- mMenu.Add( mStopButton );
- mMenu.Add( mResetButton );
+ mMenu.Add( mChangeButton );
mMenu.Add( mBackwardButton );
mMenu.Add( mForwardButton );
mPauseButton.SetVisible( false );
- mPauseButton.SetDisabled( true );
+ mPauseButton.SetProperty( Button::Property::DISABLED, true );
mPlayButton.SetVisible( true );
- mPlayButton.SetDisabled( false );
- mStopButton.SetVisible( true );
- mStopButton.SetDisabled( false );
- mResetButton.SetVisible( false );
- mResetButton.SetDisabled( true );
-
- mPlayButton.SetUnselectedImage( PLAY_IMAGE );
- mPlayButton.SetSelectedImage( PLAY_IMAGE );
- mPauseButton.SetUnselectedImage( PAUSE_IMAGE );
- mPauseButton.SetSelectedImage( PAUSE_IMAGE );
-
- mStopButton.SetUnselectedImage( STOP_IMAGE );
- mStopButton.SetSelectedImage( STOP_IMAGE );
- mResetButton.SetUnselectedImage( RESET_IMAGE );
- mResetButton.SetSelectedImage( RESET_IMAGE );
-
- mBackwardButton.SetUnselectedImage( BACKWARD_IMAGE );
- mBackwardButton.SetSelectedImage( BACKWARD_IMAGE );
- mForwardButton.SetUnselectedImage( FORWARD_IMAGE );
- mForwardButton.SetSelectedImage( FORWARD_IMAGE );
+ mPlayButton.SetProperty( Button::Property::DISABLED, false );
+ mChangeButton.SetVisible( true );
+ mChangeButton.SetProperty( Button::Property::DISABLED, false );
+
+ mPlayButton.SetProperty( Toolkit::DevelButton::Property::UNSELECTED_BACKGROUND_VISUAL, PLAY_IMAGE );
+ mPlayButton.SetProperty( Toolkit::DevelButton::Property::SELECTED_BACKGROUND_VISUAL, PLAY_IMAGE );
+ mPauseButton.SetProperty( Toolkit::DevelButton::Property::UNSELECTED_BACKGROUND_VISUAL, PAUSE_IMAGE );
+ mPauseButton.SetProperty( Toolkit::DevelButton::Property::SELECTED_BACKGROUND_VISUAL, PAUSE_IMAGE );
+
+ mChangeButton.SetProperty( Toolkit::DevelButton::Property::UNSELECTED_BACKGROUND_VISUAL, CHANGE_IMAGE );
+ mChangeButton.SetProperty( Toolkit::DevelButton::Property::SELECTED_BACKGROUND_VISUAL, CHANGE_IMAGE );
+
+ mBackwardButton.SetProperty( Toolkit::DevelButton::Property::UNSELECTED_BACKGROUND_VISUAL, BACKWARD_IMAGE );
+ mBackwardButton.SetProperty( Toolkit::DevelButton::Property::SELECTED_BACKGROUND_VISUAL, BACKWARD_IMAGE );
+ mForwardButton.SetProperty( Toolkit::DevelButton::Property::UNSELECTED_BACKGROUND_VISUAL, FORWARD_IMAGE );
+ mForwardButton.SetProperty( Toolkit::DevelButton::Property::SELECTED_BACKGROUND_VISUAL, FORWARD_IMAGE );
mPanGestureDetector = PanGestureDetector::New();
mPanGestureDetector.Attach( mVideoView );
Stage::GetCurrent().KeyEventSignal().Connect( this, &VideoViewController::OnKeyEvent );
- mWindowSurfaceTarget.Insert( "RENDERING_TARGET", "windowSurfaceTarget" );
- mNativeImageTarget.Insert( "RENDERING_TARGET", "nativeImageTarget" );
-
- mVideoView.FinishedSignal().Connect( this, &VideoViewController::OnFinished );
}
bool OnButtonClicked( Button button )
{
-
if( mPauseButton.GetId() == button.GetId())
{
if( mIsPlay )
{
mPauseButton.SetVisible( false );
- mPauseButton.SetDisabled( true );
+ mPauseButton.SetProperty( Button::Property::DISABLED, true );
mPlayButton.SetVisible( true );
- mPlayButton.SetDisabled( false );
+ mPlayButton.SetProperty( Button::Property::DISABLED, false );
mIsPlay = false;
mVideoView.Pause();
}
else if( mPlayButton.GetId() == button.GetId())
{
- if( mIsStop )
- {
- return false;
- }
-
mPauseButton.SetVisible( true );
- mPauseButton.SetDisabled( false );
+ mPauseButton.SetProperty( Button::Property::DISABLED, false );
mPlayButton.SetVisible( false );
- mPlayButton.SetDisabled( true );
+ mPlayButton.SetProperty( Button::Property::DISABLED, true );
mIsPlay = true;
mVideoView.Play();
}
- else if( mResetButton.GetId() == button.GetId())
+ else if( mChangeButton.GetId() == button.GetId())
{
- if( mIsStop )
+ bool underlay = false;
+ underlay = mVideoView.GetProperty( Toolkit::VideoView::Property::UNDERLAY ).Get< bool >();
+ if( underlay )
{
- mPauseButton.SetVisible( true );
- mPauseButton.SetDisabled( false );
- mPlayButton.SetVisible( false );
- mPlayButton.SetDisabled( true );
- mResetButton.SetVisible( false );
- mResetButton.SetDisabled( true );
- mStopButton.SetVisible( true );
- mStopButton.SetDisabled( false );
-
- mIsStop = false;
- mIsPlay = true;
- mVideoView.SetProperty( VideoView::Property::VIDEO, PLAY_FILE );
- mVideoView.Play();
+ mVideoView.SetProperty( Toolkit::VideoView::Property::UNDERLAY, false );
+ }
+ else
+ {
+ mVideoView.SetProperty( Toolkit::VideoView::Property::UNDERLAY, true );
}
- }
- else if( mStopButton.GetId() == button.GetId())
- {
- mPauseButton.SetVisible( false );
- mPauseButton.SetDisabled( true );
- mPlayButton.SetVisible( true );
- mPlayButton.SetDisabled( false );
- mResetButton.SetVisible( true );
- mResetButton.SetDisabled( false );
- mStopButton.SetVisible( false );
- mStopButton.SetDisabled( true );
-
- mIsStop = true;
- mVideoView.Stop();
}
else if( mBackwardButton.GetId() == button.GetId())
{
return true;
}
- void OnFinished( VideoView& view )
- {
- if( !mIsFullScreen )
- {
- mRotationAnimation.Play();
- mIsStop = true;
- }
- }
-
void OnPan( Actor actor, const PanGesture& gesture )
{
if( !mIsFullScreen && gesture.state == Gesture::Continuing )
if( gesture.state == Gesture::Finished )
{
mScale = mPinchStartScale * gesture.scale;
- if( mScale > 1.f )
- {
- mVideoView.SetSize( mStageSize.x, mStageSize.y );
- mVideoView.SetProperty( VideoView::Property::VIDEO, mWindowSurfaceTarget );
- mMenu.SetSize( mStageSize.x, 120 );
- mIsFullScreen = true;
- }
- else
- {
- mVideoView.SetSize( INIT_WIDTH, INIT_HEIGHT );
- mVideoView.SetProperty( VideoView::Property::VIDEO, mNativeImageTarget );
- mMenu.SetSize( INIT_WIDTH, 120 );
- mIsFullScreen = false;
- }
+ mVideoView.SetScale( mScale );
}
}
{
if( !mIsFullScreen )
{
- mRotationAnimation.Play();
+ mVideoView.SetSize( mStageSize.x, mStageSize.y );
+ mIsFullScreen = true;
+ }
+ else
+ {
+ mVideoView.SetSize( INIT_WIDTH, INIT_HEIGHT );
+ mIsFullScreen = false;
}
}
Vector2 mStageSize;
bool mIsPlay;
- bool mIsStop;
bool mIsFullScreen;
PushButton mPlayButton;
PushButton mPauseButton;
- PushButton mStopButton;
+ PushButton mChangeButton;
PushButton mResetButton;
PushButton mBackwardButton;
PushButton mForwardButton;
float mPinchStartScale;
Animation mRotationAnimation;
- Property::Map mWindowSurfaceTarget;
- Property::Map mNativeImageTarget;
};
-void RunTest( Application& application )
-{
- VideoViewController test( application );
-
- application.MainLoop();
-}
-
-// Entry point for Linux & Tizen applications
-//
int DALI_EXPORT_API main( int argc, char **argv )
{
Application application = Application::New( &argc, &argv, DEMO_THEME_PATH );
-
- RunTest( application );
-
+ VideoViewController test( application );
+ application.MainLoop();
return 0;
}