forked from Syphon/Syphon-Framework
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSyphonMetalServer.h
122 lines (93 loc) · 5.73 KB
/
SyphonMetalServer.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*
SyphonMetalServer.h
Syphon
Copyright 2020-2023 Maxime Touroute & Philippe Chaurand (www.millumin.com),
bangnoise (Tom Butterworth) & vade (Anton Marini). All rights reserved.
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#import <Syphon/SyphonServerBase.h>
#import <Metal/Metal.h>
NS_ASSUME_NONNULL_BEGIN
/*! @name Server Options Dictionary Key Constants */
/*! @{ */
/*!
@relates SyphonServerBase
If this key is matched with a NSNumber with a BOOL value YES, then the server will be invisible to other Syphon users. You are then responsible for passing the NSDictionary returned by serverDescription to processes which require it to create a SyphonClient. Default is NO.
*/
extern NSString * const SyphonServerOptionIsPrivate;
/*! @} */
/*!
@nosubgrouping
SyphonMetalServer handles the publishing of frames from one video source to any number of clients. Frames are published by passing in an existing Metal texture.
A SyphonMetalServer object represents one video output for your application. If your application produces several video outputs, then they should each have their own SyphonMetalServer. If your application might have multiple servers running, you should name each server to aid identification by users.
It is safe to access instances of this class across threads.
*/
@interface SyphonMetalServer : SyphonServerBase
/** @name Instantiation */
/** @{ */
/*!
Creates a new server with the specified human-readable name (which need not be unique) for a MTLDevice and given options. The server will be started immediately. Init may fail and return nil if the server could not be started.
@param name Non-unique human readable server name. This is not required and may be nil, but is usually used by clients in their UI to aid identification.
@param device The MTLDevice that textures will be valid and available on for publishing.
@param options A dictionary containing key-value pairs to specify options for the server. The only currently supported option is SyphonServerOptionIsPrivate. See its description for details.
@returns A newly intialized SyphonMetalServer. Nil on failure.
*/
- (id)initWithName:(nullable NSString*)name device:(id<MTLDevice>)device options:(nullable NSDictionary *)options;
/** @} */
/** @name Properties */
/** @{ */
/*!
The MTLDevice the server uses for drawing.
*/
@property (readonly) id<MTLDevice> device;
/*!
A string representing the name of the SyphonMetalServer.
*/
@property (nullable, strong) NSString* name;
/*!
A dictionary describing the server. Normally you won't need to access this, however if you created the server as private (using SyphonServerOptionIsPrivate) then you must pass this dictionary to any process in which you wish to create a SyphonClient. You should not rely on the presence of any particular keys in this dictionary. The content will always conform to the \<NSCoding\> protocol.
*/
@property (readonly) NSDictionary* serverDescription;
/*!
YES if clients are currently attached, NO otherwise. If you generate frames frequently (for instance on a display-link timer), you may choose to test this and only call publishFrameTexture:textureTarget:imageRegion:textureDimensions:flipped: when clients are attached.
*/
@property (readonly) BOOL hasClients;
/** @} */
/** @name Publishing Frames */
/** @{ */
/*!
Publishes the part of the texture described in region of the texture to clients. The texture is copied and can be safely modified once this method has returned.
@param textureToPublish The MTLTexture you wish to publish on the server.
@param commandBuffer Your commandBuffer on which Syphon will write its internal metal commands - You are responsible for comitting your commandBuffer yourself
@param region The sub-region of the texture to publish.
@param isFlipped Is the texture flipped?
*/
- (void)publishFrameTexture:(id<MTLTexture>)textureToPublish onCommandBuffer:(id<MTLCommandBuffer>)commandBuffer imageRegion:(NSRect)region flipped:(BOOL)isFlipped;
/*!
Returns a MTLTexture representing the current output from the server, valid on the server's MTLDevice. Call this method every time you wish to access the current server frame. This texture has a limited useful lifetime: you should release it as soon as you are finished drawing with it.
@returns A MTLTexture representing the current output from the server. YOU ARE RESPONSIBLE FOR RELEASING THIS OBJECT when you are finished with it.
*/
- (nullable id<MTLTexture>)newFrameImage;
/*!
Stops the server instance. Use of this method is optional and releasing all references to the server has the same effect.
*/
- (void)stop;
/** @} */
@end
NS_ASSUME_NONNULL_END