Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
ea6e923f
Commit
ea6e923f
authored
Mar 06, 2014
by
Felix Paul Kühne
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add basic iOS dialog provider
There is no support for progress dialogs so far
parent
2fbc137c
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
347 additions
and
2 deletions
+347
-2
configure.ac
configure.ac
+1
-0
modules/codec/avcodec/vda.c
modules/codec/avcodec/vda.c
+0
-1
modules/gui/Modules.am
modules/gui/Modules.am
+4
-1
modules/gui/ios_dialog_provider/Modules.am
modules/gui/ios_dialog_provider/Modules.am
+8
-0
modules/gui/ios_dialog_provider/dialogProvider.m
modules/gui/ios_dialog_provider/dialogProvider.m
+334
-0
No files found.
configure.ac
View file @
ea6e923f
...
@@ -4111,6 +4111,7 @@ AC_CONFIG_FILES([
...
@@ -4111,6 +4111,7 @@ AC_CONFIG_FILES([
modules/audio_filter/Makefile
modules/audio_filter/Makefile
modules/control/Makefile
modules/control/Makefile
modules/gui/Makefile
modules/gui/Makefile
modules/gui/ios_dialog_provider/Makefile
modules/gui/macosx/Makefile
modules/gui/macosx/Makefile
modules/gui/minimal_macosx/Makefile
modules/gui/minimal_macosx/Makefile
modules/gui/macosx_dialog_provider/Makefile
modules/gui/macosx_dialog_provider/Makefile
...
...
modules/codec/avcodec/vda.c
View file @
ea6e923f
...
@@ -161,7 +161,6 @@ static int Setup( vlc_va_t *external, void **pp_hw_ctx, vlc_fourcc_t *pi_chroma,
...
@@ -161,7 +161,6 @@ static int Setup( vlc_va_t *external, void **pp_hw_ctx, vlc_fourcc_t *pi_chroma,
memset
(
&
p_va
->
hw_ctx
,
0
,
sizeof
(
p_va
->
hw_ctx
)
);
memset
(
&
p_va
->
hw_ctx
,
0
,
sizeof
(
p_va
->
hw_ctx
)
);
p_va
->
hw_ctx
.
format
=
'
avc1
'
;
p_va
->
hw_ctx
.
format
=
'
avc1
'
;
p_va
->
hw_ctx
.
use_ref_buffer
=
1
;
int
i_pix_fmt
=
var_CreateGetInteger
(
p_va
->
p_log
,
"avcodec-vda-pix-fmt"
);
int
i_pix_fmt
=
var_CreateGetInteger
(
p_va
->
p_log
,
"avcodec-vda-pix-fmt"
);
...
...
modules/gui/Modules.am
View file @
ea6e923f
DIST_SUBDIRS = macosx minimal_macosx qt4 skins2 macosx_dialog_provider
DIST_SUBDIRS = macosx minimal_macosx qt4 skins2 macosx_dialog_provider
ios_dialog_provider
SUBDIRS =
SUBDIRS =
if ENABLE_MACOSX_UI
if ENABLE_MACOSX_UI
...
@@ -7,6 +7,9 @@ endif
...
@@ -7,6 +7,9 @@ endif
if ENABLE_MACOSX_DIALOG_PROVIDER
if ENABLE_MACOSX_DIALOG_PROVIDER
SUBDIRS += macosx_dialog_provider
SUBDIRS += macosx_dialog_provider
endif
endif
if HAVE_IOS
SUBDIRS += ios_dialog_provider
endif
if ENABLE_MINIMAL_MACOSX
if ENABLE_MINIMAL_MACOSX
SUBDIRS += minimal_macosx
SUBDIRS += minimal_macosx
endif
endif
...
...
modules/gui/ios_dialog_provider/Modules.am
0 → 100644
View file @
ea6e923f
AM_LIBTOOLFLAGS=--tag=CC
libios_dialog_provider_plugin_la_SOURCES = dialogProvider.m
libios_dialog_provider_plugin_la_LDFLAGS = $(AM_LDFLAGS) -Wl,-framework,UIKit
if HAVE_IOS
gui_LTLIBRARIES += libios_dialog_provider_plugin.la
endif
modules/gui/ios_dialog_provider/dialogProvider.m
0 → 100644
View file @
ea6e923f
/*****************************************************************************
* dialogProvider.m: iOS Dialog Provider
*****************************************************************************
* Copyright (C) 2009, 2014 VLC authors and VideoLAN
* $Id$
*
* Authors: Felix Paul Kühne <fkuehne # videolan org>
* Pierre d'Herbemont <pdherbemont # videolan org>
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; either version 2.1 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
/*****************************************************************************
* Preamble
*****************************************************************************/
#import <stdlib.h>
/* malloc(), free() */
#import <string.h>
#ifdef HAVE_CONFIG_H
# import "config.h"
#endif
#import <vlc_common.h>
#import <vlc_plugin.h>
#import <vlc_dialog.h>
#import <vlc_modules.h>
#import <vlc_interface.h>
#import <UIKit/UIKit.h>
/*****************************************************************************
* Prototypes
*****************************************************************************/
@interface
VLCDialogDisplayer
:
NSObject
{
}
+
(
NSDictionary
*
)
dictionaryForDialog
:(
const
char
*
)
title
:
(
const
char
*
)
message
:
(
const
char
*
)
yes
:
(
const
char
*
)
no
:
(
const
char
*
)
cancel
;
-
(
void
)
displayError
:(
NSDictionary
*
)
dialog
;
-
(
void
)
displayCritical
:(
NSDictionary
*
)
dialog
;
-
(
NSNumber
*
)
displayQuestion
:(
NSDictionary
*
)
dialog
;
-
(
NSDictionary
*
)
displayLogin
:(
NSDictionary
*
)
dialog
;
@end
@interface
VLCBlockingAlertView
:
UIAlertView
<
UIAlertViewDelegate
>
@property
(
copy
,
nonatomic
)
void
(
^
completion
)(
BOOL
,
NSInteger
);
-
(
id
)
initWithTitle
:(
NSString
*
)
title
message
:(
NSString
*
)
message
cancelButtonTitle
:(
NSString
*
)
cancelButtonTitle
otherButtonTitles
:(
NSArray
*
)
otherButtonTitles
;
@end
static
int
OpenIntf
(
vlc_object_t
*
);
static
void
CloseIntf
(
vlc_object_t
*
);
static
void
Run
(
intf_thread_t
*
);
static
int
DisplayError
(
vlc_object_t
*
,
const
char
*
,
vlc_value_t
,
vlc_value_t
,
void
*
);
static
int
DisplayCritical
(
vlc_object_t
*
,
const
char
*
,
vlc_value_t
,
vlc_value_t
,
void
*
);
static
int
DisplayQuestion
(
vlc_object_t
*
,
const
char
*
,
vlc_value_t
,
vlc_value_t
,
void
*
);
static
int
DisplayLogin
(
vlc_object_t
*
,
const
char
*
,
vlc_value_t
,
vlc_value_t
,
void
*
);
static
inline
NSDictionary
*
DictFromDialogFatal
(
dialog_fatal_t
*
dialog
)
{
return
[
VLCDialogDisplayer
dictionaryForDialog
:
dialog
->
title
:
dialog
->
message
:
NULL
:
NULL
:
NULL
];
}
static
inline
NSDictionary
*
DictFromDialogLogin
(
dialog_login_t
*
dialog
)
{
return
[
VLCDialogDisplayer
dictionaryForDialog
:
dialog
->
title
:
dialog
->
message
:
NULL
:
NULL
:
NULL
];
}
static
inline
NSDictionary
*
DictFromDialogQuestion
(
dialog_question_t
*
dialog
)
{
return
[
VLCDialogDisplayer
dictionaryForDialog
:
dialog
->
title
:
dialog
->
message
:
dialog
->
yes
:
dialog
->
no
:
dialog
->
cancel
];
}
struct
intf_sys_t
{
VLCDialogDisplayer
*
displayer
;
};
/*****************************************************************************
* Module descriptor
*****************************************************************************/
vlc_module_begin
()
/* Minimal interface. see intf.m */
set_shortname
(
"iOS Dialogs"
)
add_shortcut
(
"ios_dialog_provider"
,
"miosx"
)
set_description
(
"iOS Dialog Provider"
)
set_capability
(
"interface"
,
0
)
set_callbacks
(
OpenIntf
,
CloseIntf
)
set_category
(
CAT_INTERFACE
)
set_subcategory
(
SUBCAT_INTERFACE_MAIN
)
vlc_module_end
()
/*****************************************************************************
* OpenIntf: initialize interface
*****************************************************************************/
int
OpenIntf
(
vlc_object_t
*
p_this
)
{
intf_thread_t
*
p_intf
=
(
intf_thread_t
*
)
p_this
;
p_intf
->
p_sys
=
malloc
(
sizeof
(
intf_sys_t
));
if
(
!
p_intf
->
p_sys
)
return
VLC_ENOMEM
;
memset
(
p_intf
->
p_sys
,
0
,
sizeof
(
*
p_intf
->
p_sys
));
p_intf
->
p_sys
->
displayer
=
[[
VLCDialogDisplayer
alloc
]
init
];
var_Create
(
p_intf
,
"dialog-error"
,
VLC_VAR_ADDRESS
);
var_AddCallback
(
p_intf
,
"dialog-error"
,
DisplayError
,
p_intf
);
var_Create
(
p_intf
,
"dialog-critical"
,
VLC_VAR_ADDRESS
);
var_AddCallback
(
p_intf
,
"dialog-critical"
,
DisplayCritical
,
p_intf
);
var_Create
(
p_intf
,
"dialog-login"
,
VLC_VAR_ADDRESS
);
var_AddCallback
(
p_intf
,
"dialog-login"
,
DisplayLogin
,
p_intf
);
var_Create
(
p_intf
,
"dialog-question"
,
VLC_VAR_ADDRESS
);
var_AddCallback
(
p_intf
,
"dialog-question"
,
DisplayQuestion
,
p_intf
);
dialog_Register
(
p_intf
);
msg_Dbg
(
p_intf
,
"iOS dialog provider initialised"
);
return
VLC_SUCCESS
;
}
/*****************************************************************************
* CloseIntf: destroy interface
*****************************************************************************/
void
CloseIntf
(
vlc_object_t
*
p_this
)
{
intf_thread_t
*
p_intf
=
(
intf_thread_t
*
)
p_this
;
/* unsubscribe from the interactive dialogues */
dialog_Unregister
(
p_intf
);
var_DelCallback
(
p_intf
,
"dialog-error"
,
DisplayError
,
p_intf
);
var_DelCallback
(
p_intf
,
"dialog-critical"
,
DisplayCritical
,
p_intf
);
var_DelCallback
(
p_intf
,
"dialog-login"
,
DisplayLogin
,
p_intf
);
var_DelCallback
(
p_intf
,
"dialog-question"
,
DisplayQuestion
,
p_intf
);
[
p_intf
->
p_sys
->
displayer
release
];
msg_Dbg
(
p_intf
,
"iOS dialog provider closed"
);
free
(
p_intf
->
p_sys
);
}
/*****************************************************************************
* Callbacks triggered by the "dialog-*" variables
*****************************************************************************/
static
int
DisplayError
(
vlc_object_t
*
p_this
,
const
char
*
type
,
vlc_value_t
previous
,
vlc_value_t
value
,
void
*
data
)
{
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
dialog_fatal_t
*
dialog
=
value
.
p_address
;
intf_thread_t
*
p_intf
=
(
intf_thread_t
*
)
p_this
;
intf_sys_t
*
sys
=
p_intf
->
p_sys
;
[
sys
->
displayer
performSelectorOnMainThread
:
@selector
(
displayError
:)
withObject
:
DictFromDialogFatal
(
dialog
)
waitUntilDone
:
NO
];
[
pool
release
];
return
VLC_SUCCESS
;
}
static
int
DisplayCritical
(
vlc_object_t
*
p_this
,
const
char
*
type
,
vlc_value_t
previous
,
vlc_value_t
value
,
void
*
data
)
{
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
dialog_fatal_t
*
dialog
=
value
.
p_address
;
intf_thread_t
*
p_intf
=
(
intf_thread_t
*
)
p_this
;
intf_sys_t
*
sys
=
p_intf
->
p_sys
;
[
sys
->
displayer
performSelectorOnMainThread
:
@selector
(
displayCritical
:)
withObject
:
DictFromDialogFatal
(
dialog
)
waitUntilDone
:
NO
];
[
pool
release
];
return
VLC_SUCCESS
;
}
static
int
DisplayQuestion
(
vlc_object_t
*
p_this
,
const
char
*
type
,
vlc_value_t
previous
,
vlc_value_t
value
,
void
*
data
)
{
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
dialog_question_t
*
dialog
=
value
.
p_address
;
intf_thread_t
*
p_intf
=
(
intf_thread_t
*
)
p_this
;
intf_sys_t
*
sys
=
p_intf
->
p_sys
;
dialog
->
answer
=
[[
sys
->
displayer
displayQuestion
:
DictFromDialogQuestion
(
dialog
)]
intValue
];
[
pool
release
];
return
VLC_SUCCESS
;
}
static
int
DisplayLogin
(
vlc_object_t
*
p_this
,
const
char
*
type
,
vlc_value_t
previous
,
vlc_value_t
value
,
void
*
data
)
{
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
dialog_login_t
*
dialog
=
value
.
p_address
;
intf_thread_t
*
p_intf
=
(
intf_thread_t
*
)
p_this
;
intf_sys_t
*
sys
=
p_intf
->
p_sys
;
NSDictionary
*
dict
=
[
sys
->
displayer
displayLogin
:
DictFromDialogLogin
(
dialog
)];
if
(
dict
)
{
*
dialog
->
username
=
strdup
([[
dict
objectForKey
:
@"username"
]
UTF8String
]);
*
dialog
->
password
=
strdup
([[
dict
objectForKey
:
@"password"
]
UTF8String
]);
}
[
pool
release
];
return
VLC_SUCCESS
;
}
@implementation
VLCDialogDisplayer
+
(
NSDictionary
*
)
dictionaryForDialog
:(
const
char
*
)
title
:
(
const
char
*
)
message
:
(
const
char
*
)
yes
:
(
const
char
*
)
no
:
(
const
char
*
)
cancel
{
NSMutableDictionary
*
dict
=
[
NSMutableDictionary
dictionary
];
if
(
title
)
[
dict
setObject
:
@
(
title
)
forKey
:
@"title"
];
if
(
message
)
[
dict
setObject
:
@
(
message
)
forKey
:
@"message"
];
if
(
yes
)
[
dict
setObject
:
@
(
yes
)
forKey
:
@"yes"
];
if
(
no
)
[
dict
setObject
:
@
(
no
)
forKey
:
@"no"
];
if
(
cancel
)
[
dict
setObject
:
@
(
cancel
)
forKey
:
@"cancel"
];
return
dict
;
}
#define VLCAssertIsMainThread() assert([NSThread isMainThread])
-
(
void
)
displayError
:(
NSDictionary
*
)
dialog
{
VLCAssertIsMainThread
();
VLCBlockingAlertView
*
alert
=
[[
VLCBlockingAlertView
alloc
]
initWithTitle
:[
dialog
objectForKey
:
@"title"
]
message
:[
dialog
objectForKey
:
@"message"
]
delegate
:
nil
cancelButtonTitle
:
@"OK"
otherButtonTitles
:
nil
];
alert
.
completion
=
^
(
BOOL
cancelled
,
NSInteger
buttonIndex
)
{
[
alert
release
];
};
[
alert
show
];
}
-
(
void
)
displayCritical
:(
NSDictionary
*
)
dialog
{
VLCAssertIsMainThread
();
VLCBlockingAlertView
*
alert
=
[[
VLCBlockingAlertView
alloc
]
initWithTitle
:[
dialog
objectForKey
:
@"title"
]
message
:[
dialog
objectForKey
:
@"message"
]
delegate
:
nil
cancelButtonTitle
:
@"OK"
otherButtonTitles
:
nil
];
alert
.
completion
=
^
(
BOOL
cancelled
,
NSInteger
buttonIndex
)
{
[
alert
release
];
};
[
alert
show
];
}
-
(
NSNumber
*
)
displayQuestion
:(
NSDictionary
*
)
dialog
{
__block
int
ret
=
0
;
__block
VLCBlockingAlertView
*
alert
;
dispatch_semaphore_t
sema
=
dispatch_semaphore_create
(
0
);
dispatch_async
(
dispatch_get_main_queue
(),
^
{
alert
=
[[
VLCBlockingAlertView
alloc
]
initWithTitle
:[
dialog
objectForKey
:
@"title"
]
message
:[
dialog
objectForKey
:
@"message"
]
delegate
:
nil
cancelButtonTitle
:
[
dialog
objectForKey
:
@"cancel"
]
otherButtonTitles
:
[
dialog
objectForKey
:
@"yes"
],
[
dialog
objectForKey
:
@"no"
],
nil
];
alert
.
completion
=
^
(
BOOL
cancelled
,
NSInteger
buttonIndex
)
{
if
(
cancelled
)
ret
=
3
;
else
ret
=
buttonIndex
;
dispatch_semaphore_signal
(
sema
);
};
alert
.
delegate
=
alert
;
[
alert
show
];
});
dispatch_semaphore_wait
(
sema
,
DISPATCH_TIME_FOREVER
);
[
alert
release
];
return
@
(
ret
);
}
-
(
NSDictionary
*
)
displayLogin
:(
NSDictionary
*
)
dialog
{
__block
NSDictionary
*
dict
;
__block
VLCBlockingAlertView
*
alert
;
dispatch_semaphore_t
sema
=
dispatch_semaphore_create
(
0
);
dispatch_async
(
dispatch_get_main_queue
(),
^
{
alert
=
[[
VLCBlockingAlertView
alloc
]
initWithTitle
:[
dialog
objectForKey
:
@"title"
]
message
:[
dialog
objectForKey
:
@"message"
]
delegate
:
nil
cancelButtonTitle
:
@"Cancel"
otherButtonTitles
:
@"Login"
,
nil
];
alert
.
alertViewStyle
=
UIAlertViewStyleLoginAndPasswordInput
;
alert
.
completion
=
^
(
BOOL
cancelled
,
NSInteger
buttonIndex
)
{
if
(
!
cancelled
)
{
NSString
*
user
=
[
alert
textFieldAtIndex
:
0
].
text
;
NSString
*
pass
=
[
alert
textFieldAtIndex
:
1
].
text
;
dict
=
[[
NSDictionary
dictionaryWithObjectsAndKeys
:
user
,
@"username"
,
pass
,
@"password"
,
nil
]
retain
];
}
dispatch_semaphore_signal
(
sema
);
};
alert
.
delegate
=
alert
;
[
alert
show
];
});
dispatch_semaphore_wait
(
sema
,
DISPATCH_TIME_FOREVER
);
[
alert
release
];
return
dict
;
}
@end
@implementation
VLCBlockingAlertView
-
(
id
)
initWithTitle
:(
NSString
*
)
title
message
:(
NSString
*
)
message
cancelButtonTitle
:(
NSString
*
)
cancelButtonTitle
otherButtonTitles
:(
NSArray
*
)
otherButtonTitles
{
self
=
[
self
initWithTitle
:
title
message
:
message
delegate
:
self
cancelButtonTitle
:
cancelButtonTitle
otherButtonTitles
:
nil
];
if
(
self
)
{
for
(
NSString
*
buttonTitle
in
otherButtonTitles
)
[
self
addButtonWithTitle
:
buttonTitle
];
}
return
self
;
}
-
(
void
)
alertView
:(
UIAlertView
*
)
alertView
didDismissWithButtonIndex
:(
NSInteger
)
buttonIndex
{
if
(
self
.
completion
)
{
self
.
completion
(
buttonIndex
==
self
.
cancelButtonIndex
,
buttonIndex
);
self
.
completion
=
nil
;
}
}
@end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment