• Jump To … +
    ./demo/canvas-001.js ./demo/canvas-002.js ./demo/canvas-003.js ./demo/canvas-004.js ./demo/canvas-005.js ./demo/canvas-006.js ./demo/canvas-007.js ./demo/canvas-008.js ./demo/canvas-009.js ./demo/canvas-010.js ./demo/canvas-011.js ./demo/canvas-012.js ./demo/canvas-013.js ./demo/canvas-014.js ./demo/canvas-015.js ./demo/canvas-016.js ./demo/canvas-017.js ./demo/canvas-018.js ./demo/canvas-019.js ./demo/canvas-020.js ./demo/canvas-021.js ./demo/canvas-022.js ./demo/canvas-023.js ./demo/canvas-024.js ./demo/canvas-025.js ./demo/canvas-026.js ./demo/canvas-027.js ./demo/canvas-028.js ./demo/canvas-029.js ./demo/canvas-030.js ./demo/canvas-031.js ./demo/canvas-032.js ./demo/canvas-033.js ./demo/canvas-034.js ./demo/canvas-035.js ./demo/canvas-036.js ./demo/canvas-037.js ./demo/canvas-038.js ./demo/canvas-039.js ./demo/canvas-040.js ./demo/canvas-041.js ./demo/canvas-042.js ./demo/canvas-043.js ./demo/canvas-044.js ./demo/canvas-045.js ./demo/canvas-046.js ./demo/canvas-047.js ./demo/component-001.js ./demo/component-002.js ./demo/component-003.js ./demo/component-004.js ./demo/component-005.js ./demo/component-006.js ./demo/component-007.js ./demo/core-001.js ./demo/dom-001.js ./demo/dom-002.js ./demo/dom-003.js ./demo/dom-004.js ./demo/dom-005.js ./demo/dom-006.js ./demo/dom-007.js ./demo/dom-008.js ./demo/dom-009.js ./demo/dom-010.js ./demo/dom-011.js ./demo/dom-012.js ./demo/dom-013.js ./demo/dom-014a.js ./demo/dom-014b.js ./demo/dom-014c.js ./demo/dom-015.js ./demo/dom-016.js ./demo/filters-001.js ./demo/filters-002.js ./demo/filters-003.js ./demo/filters-004.js ./demo/filters-005.js ./demo/filters-006.js ./demo/filters-007.js ./demo/filters-008.js ./demo/filters-009.js ./demo/filters-010.js ./demo/filters-011.js ./demo/filters-012.js ./demo/filters-013.js ./demo/filters-014.js ./demo/filters-015.js ./demo/filters-016.js ./demo/filters-017.js ./demo/filters-018.js ./demo/filters-019.js ./demo/filters-020.js ./demo/filters-501.js ./demo/filters-502.js ./demo/filters-503.js ./demo/filters-504.js ./demo/filters-505.js ./demo/particles-001.js ./demo/particles-002.js ./demo/particles-003.js ./demo/particles-004.js ./demo/particles-005.js ./demo/particles-006.js ./demo/particles-007.js ./demo/particles-008.js ./demo/particles-009.js ./demo/particles-010.js ./demo/particles-011.js ./demo/particles-012.js ./demo/particles-013.js ./demo/particles-014.js ./demo/particles-015.js ./demo/particles-016.js ./demo/temp-001.js ./demo/temp-inkscapeSvgFilters.js
  • ¶

    Demo DOM 002

    Element mouse, pivot and mimic functionality

  • ¶

    Run code

    import scrawl from '../source/scrawl.js'
  • ¶

    Scene setup

    Create some useful variables for use elsewhere in the script

    let artefact = scrawl.library.artefact,
        stack = artefact.mystack,
        element = artefact.myelement,
        mimic = artefact.mymimic,
        pivot = artefact.mypivot;
  • ¶

    Give the stack element some depth

    stack.set({
        perspectiveZ: 1200
    });
  • ¶

    Setup the main element

    element.set({
        startX: 250,
        startY: 250,
        handleX: 125,
        handleY: 125,
        width: 250,
        height: 250,
        roll: 10,
        pitch: 20,
        yaw: 30
    });
  • ¶

    Setup the mimic element

    mimic.set({
        width: 20,
        height: 20,
        offsetX: 60,
    
        roll: 15,
        pitch: 15,
        yaw: 15,
    
        mimic: 'myelement',
        lockTo: 'mimic',
        
        useMimicDimensions: true,
        useMimicScale: true,
        useMimicStart: true,
        useMimicHandle: true,
        useMimicOffset: true,
        useMimicRotation: true,
        useMimicFlip: false,
    
        addOwnDimensionsToMimic: true,
        addOwnScaleToMimic: false,
        addOwnStartToMimic: false,
        addOwnHandleToMimic: false,
        addOwnOffsetToMimic: true,
        addOwnRotationToMimic: false,
    });
  • ¶

    Setup the pivot element

    pivot.set({
        pivot: 'myelement',
        lockTo: 'pivot',
    });
  • ¶

    Scene animation

    Function to check whether mouse cursor is over stack, and lock the element artefact accordingly

    let stackCheck = function () {
    
        let active = false;
    
        return function () {
    
            if (stack.here.active !== active) {
    
                active = stack.here.active;
    
                element.set({
                    lockTo: (active) ? 'mouse' : 'start'
                });
            }
        };
    }();
  • ¶

    Function to display frames-per-second data, and other information relevant to the demo

    let report = function () {
    
        let testTicker = Date.now(),
            testTime, testNow,
            testMessage = document.querySelector('#reportmessage');
    
        return function () {
    
            testNow = Date.now();
            testTime = testNow - testTicker;
            testTicker = testNow;
    
            testMessage.textContent = `Screen refresh: ${Math.ceil(testTime)}ms; fps: ${Math.floor(1000 / testTime)}
    lock to: «${element.lockTo}»; width: ${element.get('width')}; height: ${element.get('height')}
    start: [${element.start}]; handle: [${element.handle}]
    scale: ${element.get('scale')}; roll: ${element.get('roll')}°; pitch: ${element.get('pitch')}°; yaw: ${element.get('yaw')}°`;
        };
    }();
  • ¶

    Create the Display cycle animation

    scrawl.makeRender({
    
        name: 'demo-animation',
        target: stack,
        commence: stackCheck,
        afterShow: report,
    });
  • ¶

    User interaction

    Setup form observer functionality

    scrawl.observeAndUpdate({
    
        event: ['input', 'change'],
        origin: '.controlItem',
    
        target: element,
    
        useNativeListener: true,
        preventDefault: true,
    
        updates: {
    
            dims_widthPercent: ['width', '%'],
            dims_widthAbsolute: ['width', 'round'],
    
            dims_heightPercent: ['height', '%'],
            dims_heightAbsolute: ['height', 'round'],
    
            start_xPercent: ['startX', '%'],
            start_xAbsolute: ['startX', 'round'],
            start_xString: ['startX', 'raw'],
    
            start_yPercent: ['startY', '%'],
            start_yAbsolute: ['startY', 'round'],
            start_yString: ['startY', 'raw'],
    
            handle_xPercent: ['handleX', '%'],
            handle_xAbsolute: ['handleX', 'round'],
            handle_xString: ['handleX', 'raw'],
    
            handle_yPercent: ['handleY', '%'],
            handle_yAbsolute: ['handleY', 'round'],
            handle_yString: ['handleY', 'raw'],
    
            roll: ['roll', 'float'],
            pitch: ['pitch', 'float'],
            yaw: ['yaw', 'float'],
            scale: ['scale', 'float'],
        },
    });
  • ¶

    target doesn’t have to be a Scrawl-canvas object. We can use the object’s name, though we also have to tell the function where the object lives in the Scrawl-canvas library (usually this will be ‘artefact’)

    scrawl.observeAndUpdate({
    
        event: ['input', 'change'],
        origin: '.controlItem',
    
        target: 'mypivot',
        targetLibrarySection: 'artefact',
    
        useNativeListener: true,
        preventDefault: true,
    
        updates: {
    
            pivot_handle: ['addPivotHandle', 'boolean'],
            pivot_rotation: ['addPivotRotation', 'boolean'],
        },
    });
  • ¶

    Using the Scrawl-canvas listener functions directly, in this case because we want to update more than one attribute in a single set action, which the observeAndUpdate function cannot do (because: too much of an edge case to handle)

    let events = (e) => {
    
        e.preventDefault();
        e.returnValue = false;
    
        switch (e.target.id) {
    
            case 'mimic_dims':
                mimic.set({
                    width: parseFloat(e.target.value),
                    height: parseFloat(e.target.value),
                });
                break;
    
            case 'mimic_rotation':
                mimic.set({
                    addOwnRotationToMimic: (e.target.value === '1') ? true : false,
                });
                break;
        }
    };
    scrawl.addNativeListener(['input', 'change'], events, '.controlItem');
  • ¶

    Housekeeping - set the DOM input values to their starting values on each page reload

    document.querySelector('#dims_widthPercent').value = 50;
    document.querySelector('#dims_heightPercent').value = 50;
    document.querySelector('#dims_widthAbsolute').value = 250;
    document.querySelector('#dims_heightAbsolute').value = 250;
    document.querySelector('#start_xPercent').value = 50;
    document.querySelector('#start_yPercent').value = 50;
    document.querySelector('#start_xAbsolute').value = 250;
    document.querySelector('#start_yAbsolute').value = 250;
    document.querySelector('#start_xString').options.selectedIndex = 1;
    document.querySelector('#start_yString').options.selectedIndex = 1;
    document.querySelector('#handle_xPercent').value = 50;
    document.querySelector('#handle_yPercent').value = 50;
    document.querySelector('#handle_xAbsolute').value = 125;
    document.querySelector('#handle_yAbsolute').value = 125;
    document.querySelector('#handle_xString').options.selectedIndex = 1;
    document.querySelector('#handle_yString').options.selectedIndex = 1;
    document.querySelector('#roll').value = 10;
    document.querySelector('#pitch').value = 20;
    document.querySelector('#yaw').value = 30;
    document.querySelector('#scale').value = 1;
    document.querySelector('#pivot_handle').value = 0;
    document.querySelector('#pivot_rotation').value = 0;
    document.querySelector('#mimic_dims').value = 10;
    document.querySelector('#mimic_rotation').value = 0;
  • ¶

    Development and testing

    console.log(scrawl.library);