/// <summary> /// Return the extension mask for the given tag. /// </summary> /// <param name="tag_I"></param> /// <returns></returns> public static UInt32 GetExtensionMask(EWTXExtensionTag tag_I) { UInt32 extMask = 0; IntPtr buf = WMemUtils.AllocUnmanagedBuf(extMask); try { UInt32 extIndex = FindWTXExtensionIndex(tag_I); // Supported if extIndex != -1 if (extIndex != 0xffffffff) { int size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_EXTENSIONS + extIndex, (uint)EWTIExtensionIndex.EXT_MASK, buf); extMask = WMemUtils.MarshalUnmanagedBuf <UInt32>(buf, size); } } catch (Exception ex) { throw new Exception("FAILED GetExtensionMask: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(extMask); }
/// <summary> /// Returns extension index for given tag, if possible. /// </summary> /// <param name="tag_I">type of extension being searched for</param> /// <returns></returns> private static UInt32 FindWTXExtensionIndex(EWTXExtensionTag tag_I) { UInt32 thisTag = 0; UInt32 extIndex = 0xffffffff; IntPtr buf = WMemUtils.AllocUnmanagedBuf(thisTag); for (Int32 loopIdx = 0, size = -1; size != 0; loopIdx++) { size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_EXTENSIONS + (UInt32)loopIdx, (uint)EWTIExtensionIndex.EXT_TAG, buf); if (size > 0) { thisTag = WMemUtils.MarshalUnmanagedBuf <UInt32>(buf, size); if ((EWTXExtensionTag)thisTag == tag_I) { extIndex = (UInt32)loopIdx; break; } } } WMemUtils.FreeUnmanagedBuf(buf); return(extIndex); }
/// <summary> /// Marshal unmanaged data packets into managed WintabPacket data. /// </summary> /// <param name="numPkts_I">number of packets to marshal</param> /// <param name="buf_I">pointer to unmanaged heap memory containing data packets</param> /// <returns></returns> public static WintabPacket[] MarshalDataPackets(UInt32 numPkts_I, IntPtr buf_I) { WintabPacket[] packets = new WintabPacket[numPkts_I]; if (numPkts_I == 0 || buf_I == IntPtr.Zero) { return(null); } // Marshal each WintabPacket in the array separately. // This is "necessary" because none of the other ways I tried to marshal // seemed to work. It's ugly, but it works. int pktSize = Marshal.SizeOf(new WintabPacket()); Byte[] byteArray = new Byte[numPkts_I * pktSize]; Marshal.Copy(buf_I, byteArray, 0, (int)numPkts_I * pktSize); Byte[] byteArray2 = new Byte[pktSize]; for (int pktsIdx = 0; pktsIdx < numPkts_I; pktsIdx++) { for (int idx = 0; idx < pktSize; idx++) { byteArray2[idx] = byteArray[(pktsIdx * pktSize) + idx]; } IntPtr tmp = WMemUtils.AllocUnmanagedBuf(pktSize); Marshal.Copy(byteArray2, 0, tmp, pktSize); packets[pktsIdx] = WMemUtils.MarshalUnmanagedBuf <WintabPacket>(tmp, pktSize); } return(packets); }
/// <summary> /// Helper function to get digitizing or system default context. /// </summary> /// <param name="contextType_I">Use WTI_DEFCONTEXT for digital context or WTI_DEFSYSCTX for system context</param> /// <returns>Returns the default context or null on error.</returns> private static WContext GetDefaultContext(EWTICategoryIndex contextIndex_I) { WContext context = new WContext(); IntPtr buf = WMemUtils.AllocUnmanagedBuf(context.LogContext); try { int size = (int)WNativeMethods.WTInfo((uint)contextIndex_I, 0, buf); context.LogContext = WMemUtils.MarshalUnmanagedBuf <WintabLogContext>(buf, size); } catch (Exception ex) { throw new Exception("FAILED GetDefaultContext: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(context); }
/// <summary> /// Returns whether a stylus is currently connected to the active cursor. /// </summary> /// <returns></returns> public static bool IsStylusActive() { bool isStylusActive = false; IntPtr buf = WMemUtils.AllocUnmanagedBuf(isStylusActive); try { int size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_INTERFACE, (uint)EWTIInterfaceIndex.IFC_NDEVICES, buf); isStylusActive = WMemUtils.MarshalUnmanagedBuf <bool>(buf, size); } catch (Exception ex) { throw new Exception("FAILED GetNumberOfDevices: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(isStylusActive); }
/// <summary> /// Returns the number of devices connected. /// </summary> /// <returns></returns> public static UInt32 GetNumberOfDevices() { UInt32 numDevices = 0; IntPtr buf = WMemUtils.AllocUnmanagedBuf(numDevices); try { int size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_INTERFACE, (uint)EWTIInterfaceIndex.IFC_NDEVICES, buf); numDevices = WMemUtils.MarshalUnmanagedBuf <UInt32>(buf, size); } catch (Exception ex) { throw new Exception("FAILED GetNumberOfDevices: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(numDevices); }
/// <summary> /// Returns the default device. If this value is -1, then it also known as a "virtual device". /// </summary> /// <returns></returns> public static Int32 GetDefaultDeviceIndex() { Int32 devIndex = 0; IntPtr buf = WMemUtils.AllocUnmanagedBuf(devIndex); try { int size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_DEFCONTEXT, (uint)EWTIContextIndex.CTX_DEVICE, buf); devIndex = WMemUtils.MarshalUnmanagedBuf <Int32>(buf, size); } catch (Exception ex) { throw new Exception("FAILED GetDefaultDeviceIndex: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(devIndex); }
/// <summary> /// Returns the WintabAxis object for specified device and dimension. /// </summary> /// <param name="devIndex_I">Device index (-1 = virtual device)</param> /// <param name="dim_I">Dimension: AXIS_X, AXIS_Y or AXIS_Z</param> /// <returns></returns> public static WintabAxis GetDeviceAxis(Int32 devIndex_I, EAxisDimension dim_I) { WintabAxis axis = new WintabAxis(); IntPtr buf = WMemUtils.AllocUnmanagedBuf(axis); try { int size = (int)WNativeMethods.WTInfo( (uint)(EWTICategoryIndex.WTI_DEVICES + devIndex_I), (uint)dim_I, buf); // If size == 0, then returns a zeroed struct. axis = WMemUtils.MarshalUnmanagedBuf <WintabAxis>(buf, size); } catch (Exception ex) { throw new Exception("FAILED GetDeviceAxis: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(axis); }
/// <summary> /// Return max normal pressure supported by tablet. /// </summary> /// <param name="getNormalPressure_I">TRUE=> normal pressure; /// FALSE=> tangential pressure (not supported on all tablets)</param> /// <returns>maximum pressure value or zero on error</returns> public static Int32 GetMaxPressure(bool getNormalPressure_I = true) { WintabAxis pressureAxis = new WintabAxis(); IntPtr buf = WMemUtils.AllocUnmanagedBuf(pressureAxis); EWTIDevicesIndex devIdx = (getNormalPressure_I ? EWTIDevicesIndex.DVC_NPRESSURE : EWTIDevicesIndex.DVC_TPRESSURE); try { int size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_DEVICES, (uint)devIdx, buf); pressureAxis = WMemUtils.MarshalUnmanagedBuf <WintabAxis>(buf, size); } catch (Exception ex) { throw new Exception("FAILED GetMaxPressure: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(pressureAxis.axMax); }
/// <summary> /// Returns a 3-element array describing the tablet's rotation range and resolution capabilities /// </summary> /// <returns></returns> public static WintabAxisArray GetDeviceRotation(out bool rotationSupported_O) { WintabAxisArray axisArray = new WintabAxisArray(); rotationSupported_O = false; IntPtr buf = WMemUtils.AllocUnmanagedBuf(axisArray); try { int size = (int)WNativeMethods.WTInfo( (uint)EWTICategoryIndex.WTI_DEVICES, (uint)EWTIDevicesIndex.DVC_ROTATION, buf); // If size == 0, then returns a zeroed struct. axisArray = WMemUtils.MarshalUnmanagedBuf <WintabAxisArray>(buf, size); rotationSupported_O = (axisArray.array[0].axResolution != 0 && axisArray.array[1].axResolution != 0); } catch (Exception ex) { throw new Exception("FAILED GetDeviceRotation: " + ex.ToString()); } WMemUtils.FreeUnmanagedBuf(buf); return(axisArray); }