1

Let's say there is an arbitrary composite shape in PixiJS:

enter image description here

I need to project a texture onto it by some kind of a grid warp in a way, so the result would be:

enter image description here

I have tried to do it via PIXI.SimplePlane and it seems that default projection algorithm at this framework is affine transformation. And the result have to be based on quad bi-linear projection.

Yes, PixiJS has additional projections plugin (https://pixijs.io/examples/#/plugin-projection/quad-homo.js), but it seems that output could be controlled just by four corner points. In my case, I need more. At least 10 or even 15.

If I couldn't use projection plugin, maybe there is a way to implement a custom shader?!

let pattern64 = "";


 const app = new PIXI.Application({ width: 512, height: 324, antialias: true });
    document.body.appendChild(app.view);

    app.loader.add('pattern', pattern64).load(inits);

    function inits() {

        const graphics = new PIXI.Graphics();

        let path = [34, 100, 176, 100, 176, 224, 34, 224];

        graphics.lineStyle(0);
        graphics.beginFill(0xBCBCBC, 1);
        graphics.drawPolygon(path);
        graphics.endFill();

        path = [176, 100, 258, 60, 258, 264, 176, 224];

        graphics.lineStyle(0);
        graphics.beginFill(0xCDCDCD, 1);
        graphics.drawPolygon(path);
        graphics.endFill();

        path = [258, 60, 422, 104, 422, 220, 256, 264];

        graphics.lineStyle(0);
        graphics.beginFill(0x606060, 1);
        graphics.drawPolygon(path);
        graphics.endFill();

        path = [422, 104, 478, 104, 478, 220, 422, 220];

        graphics.lineStyle(0);
        graphics.beginFill(0x909090, 1);
        graphics.drawPolygon(path);
        graphics.endFill();

        app.stage.addChild(graphics);

        const texture = app.loader.resources.pattern.texture;

        const plane = new PIXI.SimplePlane(texture, 5, 3);
        app.stage.addChild(plane);

        let buffer = plane.geometry.getBuffer('aVertexPosition');

        // graphics.beginFill(0xFF0000);
        // graphics.drawRect(buffer.data[20], buffer.data[21], 8, 8);
        // graphics.endFill();

        //manually set just for this demo
        buffer.data[0] = 34;
        buffer.data[1] = 100;
        buffer.data[2] = 176;
        buffer.data[3] = 100;
        buffer.data[4] = 258;
        buffer.data[5] = 60;
        buffer.data[6] = 422;
        buffer.data[7] = 104;
        buffer.data[8] = 478;
        buffer.data[9] = 104;

        buffer.data[10] = 34;
        buffer.data[11] = 162;
        buffer.data[12] = 176;
        buffer.data[13] = 162;
        buffer.data[14] = 258;
        buffer.data[15] = 162;
        buffer.data[16] = 422;
        buffer.data[17] = 162;
        buffer.data[18] = 478;
        buffer.data[19] = 162;

        buffer.data[20] = 34;
        buffer.data[21] = 224;
        buffer.data[22] = 176;
        buffer.data[23] = 224;
        buffer.data[24] = 258;
        buffer.data[25] = 264;
        buffer.data[26] = 422;
        buffer.data[27] = 220;
        buffer.data[28] = 478;
        buffer.data[29] = 220;

        buffer.update();

    }
body { margin: 0; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/6.5.5/browser/pixi.js"></script>
toowren
  • 85
  • 7

0 Answers0