On 11 November 2010 09:26, Dmitry Torokhov <dmitry.torokhov@xxxxxxxxx> wrote: > On Thu, Nov 11, 2010 at 09:06:14AM +0100, Michal Suchanek wrote: >> On 11 November 2010 02:22, Dmitry Torokhov <dmitry.torokhov@xxxxxxxxx> wrote: >> > On Thu, Nov 11, 2010 at 01:48:44AM +0100, Henrik Rydberg wrote: >> >> On 11/11/2010 12:53 AM, Peter Hutterer wrote: >> >> >> >> > On Wed, Nov 10, 2010 at 11:00:05AM +0100, Henrik Rydberg wrote: >> >> >> A comment on pixels and resolution: >> >> >> >> >> >> A pen and a thumb may have different resolution (signal-to-noise ratio), but >> >> >> there is no reason they cannot be reported on the same scale. In fact, it could >> >> >> be argued that it is natural for objects on the same surface to be reported in >> >> >> the coordinate system of the surface. >> >> > >> >> > it may be natural from a human perspective, but the computer doesn't care >> >> > about it. >> >> >> >> >> >> The fact that we discuss a computer protocol suggests the computer does care. >> >> ;-) The question is whether we need to be able to support different scales for >> >> different tools types. I argue that among the three things value range, physical >> >> range and SN ratio, the one most naturally seen as an attribute of a tool is the >> >> SN ratio. >> >> >> >> > And given that most input device interpretation is done in >> >> > software, the scale used doesn't matter as long as it's correct. >> >> >> >> > in the UI, even with different ranges for different tools, top-left should >> >> > refer to whatever coordinate that is. >> >> > >> >> > in other words, if the pure numbers matter in the UI, we've done something >> >> > wrong. >> >> >> >> > >> >> > what benefit do we get from reporting tools on the same scale if the HW >> >> > doesn't do so? >> >> >> >> >> >> The question is, given a set of tool types reported via MT events, what >> >> additional information is needed. Having tools share the same ABS axes, I would >> >> like to see that as a good thing. So what is missing from that picture? >> > >> > I think that with devices that share the same working surface with >> > different tools (touch/pen) it would make sense to normalize the data in >> > the kernel. If for no other reason but to simplify the protocol. >> > >> > In cases when tools are way to different driver writer might opt to >> > export the device as 2 separate logical input devices (and then take >> > care of coordinating them in userspace), in other cases treat them as >> > one input device and scale to the same range. >> > >> > I tend to think [at the moment] that the latter would be most sensible >> > option for Bamboo... >> > >> >> What is the purpose of scaling the inouts to the same range? >> >> Is that a workaround for na issue with current protocol design or does >> anybody think that it makes some sort of sense? >> > > I do not believe that current protocol design has an issue. MT protocol > is really for representing devices reporting multiple touches on the same > working surface which means that size stays the same for all touches. > >> I am asking because to me it does not make any sense to scale the values. >> >> Devices that have a touch layer superimposed over LCD screen have to >> be calibrated for the system to know which ABS_X/Y corresponds to >> which pixel. I suspect that Bamboo P&T may have similar issue with its >> two superimposed input devices. Alos somebody suggested that the input >> area usable for pen might be smaller than area usable for touch. >> >> This means we are most likely talking apples and oranges, even if we >> scale them to be the same size. >> > > No, I do not believe this is true. Consider touchscreen that you can > touch with either stylus or finger, with stylus having better > resolution suited for drawing/writing and finger just used for selecting > UI objects. Obviously they work with the same number of pixels even > though ranges reported by the hardware might differ. Still you have to perform some calibration to match the pen and finger inputs to screen objects and when implemented with different sensors then the sensors one to the other. This calibration needs to be done separately for each input sensor if the resulting date is to be precise within limits of the device resolution. Where would this calibration (which includes scaling) happen? In the kernel? Does that mean that only the administrator can calibrate the device? Or do we do one scaling in kernel and then rescale the data in X or other client again? Thanks Michal -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html