diff options
| author | Andy Rickert <andrew_rickert@brown.edu> | 2020-04-15 20:02:58 -0700 | 
|---|---|---|
| committer | Andy Rickert <andrew_rickert@brown.edu> | 2020-04-15 20:02:58 -0700 | 
| commit | 1d5c4510dff326a0f12b914868ac8614ab460e83 (patch) | |
| tree | 7173f465175c6eb6b5bbfe96c932b49fd621f0b0 /src/client/util/InteractionUtils.tsx | |
| parent | c7c146adbd0b188eba56139ab914edaf73774d3f (diff) | |
| parent | e0f16b89cba102a4fcd156bb3d4148432eca2ab7 (diff) | |
merge
Diffstat (limited to 'src/client/util/InteractionUtils.tsx')
| -rw-r--r-- | src/client/util/InteractionUtils.tsx | 36 | 
1 files changed, 20 insertions, 16 deletions
| diff --git a/src/client/util/InteractionUtils.tsx b/src/client/util/InteractionUtils.tsx index 2eec02a42..b1f136430 100644 --- a/src/client/util/InteractionUtils.tsx +++ b/src/client/util/InteractionUtils.tsx @@ -10,24 +10,9 @@ export namespace InteractionUtils {      const REACT_POINTER_PEN_BUTTON = 0;      const ERASER_BUTTON = 5; -    export function CreatePolyline(points: { X: number, Y: number }[], left: number, top: number, color: string, width: number) { -        const pts = points.reduce((acc: string, pt: { X: number, Y: number }) => acc + `${pt.X - left},${pt.Y - top} `, ""); -        return ( -            <polyline -                points={pts} -                style={{ -                    fill: "none", -                    stroke: color, -                    strokeWidth: width -                }} -            /> -        ); -    } -      export class MultiTouchEvent<T extends React.TouchEvent | TouchEvent> {          constructor(              readonly fingers: number, -            // readonly points: T extends React.TouchEvent ? React.TouchList : TouchList,              readonly targetTouches: T extends React.TouchEvent ? React.Touch[] : Touch[],              readonly touches: T extends React.TouchEvent ? React.Touch[] : Touch[],              readonly changedTouches: T extends React.TouchEvent ? React.Touch[] : Touch[], @@ -37,6 +22,11 @@ export namespace InteractionUtils {      export interface MultiTouchEventDisposer { (): void; } +    /** +     *  +     * @param element - element to turn into a touch target +     * @param startFunc - event handler, typically Touchable.onTouchStart (classes that inherit touchable can pass in this.onTouchStart) +     */      export function MakeMultiTouchTarget(          element: HTMLElement,          startFunc: (e: Event, me: MultiTouchEvent<React.TouchEvent>) => void @@ -62,6 +52,11 @@ export namespace InteractionUtils {          };      } +    /** +     * Turns an element onto a target for touch hold handling. +     * @param element - element to add events to +     * @param func - function to add to the event +     */      export function MakeHoldTouchTarget(          element: HTMLElement,          func: (e: Event, me: MultiTouchEvent<React.TouchEvent>) => void @@ -92,7 +87,6 @@ export namespace InteractionUtils {          return myTouches;      } -    // TODO: find a way to reference this function from InkingStroke instead of copy pastign here. copied bc of weird error when on mobile view      export function CreatePolyline(points: { X: number, Y: number }[], left: number, top: number, color: string, width: number) {          const pts = points.reduce((acc: string, pt: { X: number, Y: number }) => acc + `${pt.X - left},${pt.Y - top} `, "");          return ( @@ -107,6 +101,11 @@ export namespace InteractionUtils {          );      } +    /** +     * Returns whether or not the pointer event passed in is of the type passed in +     * @param e - pointer event. this event could be from a mouse, a pen, or a finger +     * @param type - InteractionUtils.(PENTYPE | ERASERTYPE | MOUSETYPE | TOUCHTYPE) +     */      export function IsType(e: PointerEvent | React.PointerEvent, type: string): boolean {          switch (type) {              // pen and eraser are both pointer type 'pen', but pen is button 0 and eraser is button 5. -syip2 @@ -119,6 +118,11 @@ export namespace InteractionUtils {          }      } +    /** +     * Returns euclidean distance between two points +     * @param pt1  +     * @param pt2  +     */      export function TwoPointEuclidist(pt1: React.Touch, pt2: React.Touch): number {          return Math.sqrt(Math.pow(pt1.clientX - pt2.clientX, 2) + Math.pow(pt1.clientY - pt2.clientY, 2));      } | 
