mirror of
				https://gitlab.freedesktop.org/wlroots/wlroots.git
				synced 2025-11-03 09:01:40 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			152 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			XML
		
	
	
	
	
	
<?xml version="1.0" encoding="UTF-8"?>
 | 
						|
<protocol name="wlr_virtual_pointer_unstable_v1">
 | 
						|
  <copyright>
 | 
						|
    Copyright © 2019 Josef Gajdusek
 | 
						|
 | 
						|
    Permission is hereby granted, free of charge, to any person obtaining a
 | 
						|
    copy of this software and associated documentation files (the "Software"),
 | 
						|
    to deal in the Software without restriction, including without limitation
 | 
						|
    the rights to use, copy, modify, merge, publish, distribute, sublicense,
 | 
						|
    and/or sell copies of the Software, and to permit persons to whom the
 | 
						|
    Software is furnished to do so, subject to the following conditions:
 | 
						|
 | 
						|
    The above copyright notice and this permission notice (including the next
 | 
						|
    paragraph) shall be included in all copies or substantial portions of the
 | 
						|
    Software.
 | 
						|
 | 
						|
    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
						|
    IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
						|
    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 | 
						|
    THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
						|
    LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | 
						|
    FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 | 
						|
    DEALINGS IN THE SOFTWARE.
 | 
						|
  </copyright>
 | 
						|
 | 
						|
  <interface name="zwlr_virtual_pointer_v1" version="2">
 | 
						|
    <description summary="virtual pointer">
 | 
						|
      This protocol allows clients to emulate a physical pointer device. The
 | 
						|
      requests are mostly mirror opposites of those specified in wl_pointer.
 | 
						|
    </description>
 | 
						|
 | 
						|
    <enum name="error">
 | 
						|
      <entry name="invalid_axis" value="0"
 | 
						|
        summary="client sent invalid axis enumeration value" />
 | 
						|
      <entry name="invalid_axis_source" value="1"
 | 
						|
        summary="client sent invalid axis source enumeration value" />
 | 
						|
    </enum>
 | 
						|
 | 
						|
    <request name="motion">
 | 
						|
      <description summary="pointer relative motion event">
 | 
						|
        The pointer has moved by a relative amount to the previous request.
 | 
						|
 | 
						|
        Values are in the global compositor space.
 | 
						|
      </description>
 | 
						|
      <arg name="time" type="uint" summary="timestamp with millisecond granularity"/>
 | 
						|
      <arg name="dx" type="fixed" summary="displacement on the x-axis"/>
 | 
						|
      <arg name="dy" type="fixed" summary="displacement on the y-axis"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="motion_absolute">
 | 
						|
      <description summary="pointer absolute motion event">
 | 
						|
        The pointer has moved in an absolute coordinate frame.
 | 
						|
 | 
						|
        Value of x can range from 0 to x_extent, value of y can range from 0
 | 
						|
        to y_extent.
 | 
						|
      </description>
 | 
						|
      <arg name="time" type="uint" summary="timestamp with millisecond granularity"/>
 | 
						|
      <arg name="x" type="uint" summary="position on the x-axis"/>
 | 
						|
      <arg name="y" type="uint" summary="position on the y-axis"/>
 | 
						|
      <arg name="x_extent" type="uint" summary="extent of the x-axis"/>
 | 
						|
      <arg name="y_extent" type="uint" summary="extent of the y-axis"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="button">
 | 
						|
      <description summary="button event">
 | 
						|
        A button was pressed or released.
 | 
						|
      </description>
 | 
						|
      <arg name="time" type="uint" summary="timestamp with millisecond granularity"/>
 | 
						|
      <arg name="button" type="uint" summary="button that produced the event"/>
 | 
						|
      <arg name="state" type="uint" enum="wl_pointer.button_state" summary="physical state of the button"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="axis">
 | 
						|
      <description summary="axis event">
 | 
						|
        Scroll and other axis requests.
 | 
						|
      </description>
 | 
						|
      <arg name="time" type="uint" summary="timestamp with millisecond granularity"/>
 | 
						|
      <arg name="axis" type="uint" enum="wl_pointer.axis" summary="axis type"/>
 | 
						|
      <arg name="value" type="fixed" summary="length of vector in touchpad coordinates"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="frame">
 | 
						|
      <description summary="end of a pointer event sequence">
 | 
						|
        Indicates the set of events that logically belong together.
 | 
						|
      </description>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="axis_source">
 | 
						|
      <description summary="axis source event">
 | 
						|
        Source information for scroll and other axis.
 | 
						|
      </description>
 | 
						|
      <arg name="axis_source" type="uint" enum="wl_pointer.axis_source" summary="source of the axis event"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="axis_stop">
 | 
						|
      <description summary="axis stop event">
 | 
						|
        Stop notification for scroll and other axes.
 | 
						|
      </description>
 | 
						|
      <arg name="time" type="uint" summary="timestamp with millisecond granularity"/>
 | 
						|
      <arg name="axis" type="uint" enum="wl_pointer.axis" summary="the axis stopped with this event"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="axis_discrete">
 | 
						|
      <description summary="axis click event">
 | 
						|
        Discrete step information for scroll and other axes.
 | 
						|
 | 
						|
        This event allows the client to extend data normally sent using the axis
 | 
						|
        event with discrete value.
 | 
						|
      </description>
 | 
						|
      <arg name="time" type="uint" summary="timestamp with millisecond granularity"/>
 | 
						|
      <arg name="axis" type="uint" enum="wl_pointer.axis" summary="axis type"/>
 | 
						|
      <arg name="value" type="fixed" summary="length of vector in touchpad coordinates"/>
 | 
						|
      <arg name="discrete" type="int" summary="number of steps"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="destroy" type="destructor" since="1">
 | 
						|
      <description summary="destroy the virtual pointer object"/>
 | 
						|
    </request>
 | 
						|
  </interface>
 | 
						|
 | 
						|
  <interface name="zwlr_virtual_pointer_manager_v1" version="2">
 | 
						|
    <description summary="virtual pointer manager">
 | 
						|
      This object allows clients to create individual virtual pointer objects.
 | 
						|
    </description>
 | 
						|
 | 
						|
    <request name="create_virtual_pointer">
 | 
						|
      <description summary="Create a new virtual pointer">
 | 
						|
        Creates a new virtual pointer. The optional seat is a suggestion to the
 | 
						|
        compositor.
 | 
						|
      </description>
 | 
						|
      <arg name="seat" type="object" interface="wl_seat" allow-null="true"/>
 | 
						|
      <arg name="id" type="new_id" interface="zwlr_virtual_pointer_v1"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <request name="destroy" type="destructor" since="1">
 | 
						|
      <description summary="destroy the virtual pointer manager"/>
 | 
						|
    </request>
 | 
						|
 | 
						|
    <!-- Version 2 additions -->
 | 
						|
    <request name="create_virtual_pointer_with_output" since="2">
 | 
						|
      <description summary="Create a new virtual pointer">
 | 
						|
        Creates a new virtual pointer. The seat and the output arguments are
 | 
						|
        optional. If the seat argument is set, the compositor should assign the
 | 
						|
        input device to the requested seat. If the output argument is set, the
 | 
						|
        compositor should map the input device to the requested output.
 | 
						|
      </description>
 | 
						|
      <arg name="seat" type="object" interface="wl_seat" allow-null="true"/>
 | 
						|
      <arg name="output" type="object" interface="wl_output" allow-null="true"/>
 | 
						|
      <arg name="id" type="new_id" interface="zwlr_virtual_pointer_v1"/>
 | 
						|
    </request>
 | 
						|
  </interface>
 | 
						|
</protocol>
 |