blobt 4 years ago
parent
commit
2d1a2435f0
  1. 0
      public/data/pic0.png
  2. 0
      public/data/pic1.jpg
  3. 0
      public/data/test.txt
  4. 0
      public/data/textureUV.jpg
  5. 31
      src/App.tsx
  6. 78
      src/renderi/commons/HttpRequest.ts
  7. 9
      src/renderi/core/ImageInfo.ts
  8. 50
      src/renderi/lib/AsyncLoadTestApplication.ts
  9. 16
      src/renderi/lib/CameraApplication.ts
  10. 6
      src/renderi/webgl/GLApplication.ts

data/pic0.png → public/data/pic0.png

data/pic1.jpg → public/data/pic1.jpg

data/test.txt → public/data/test.txt

data/textureUV.jpg → public/data/textureUV.jpg

31
src/App.tsx

@ -1,27 +1,26 @@
import React from 'react'; import React from 'react';
import './App.css'; import './App.css';
import { Demo1 } from "./examples/Demo1";
import { Test } from "./examples/Test";
import { Application } from "./renderi/core/Application";
import { AsyncLoadTestApplication } from "./renderi/lib/AsyncLoadTestApplication";
function fCallback(app: Application): void {
console.log(app.fps);
}
let canvas: HTMLCanvasElement | null = document.getElementById('render') as HTMLCanvasElement;
let app: AsyncLoadTestApplication = new AsyncLoadTestApplication(canvas);
//app.run();
let p: Promise<string> = new Promise((resolve, rejected) => {
resolve("ok");
});
function test() {
let canvas: HTMLCanvasElement | null = document.getElementById('render') as HTMLCanvasElement;
let rect: ClientRect = canvas.getBoundingClientRect();
console.log(rect);
let instance = new Test(canvas);
//instance.frameCallback = fCallback;
instance.start();
}
p.then((value) => {
console.log(value);
}).then(() =>{
console.log("ending");
});
function App() {
console.log("runing");
test();
//console.log(p);
function App() {
return ( return (
<div className="App"> <div className="App">
</div> </div>

78
src/renderi/commons/HttpRequest.ts

@ -0,0 +1,78 @@
import { rejects } from "node:assert";
import { ImageInfo } from "../core/ImageInfo";
export class HttpRequest {
/**
*
* tsconfig.json中将default的es5改成ES2015
* @param url
*/
public static loadImageAsync(url: string): Promise<HTMLImageElement> {
return new Promise((resolve, reject): void => {
const image: HTMLImageElement = new Image();
image.src = url;
image.onload = function () {
resolve(image);
}
image.onerror = function () {
reject(new Error("Cloud not load image '" + url + "'."));
}
});
}
/**
*
* @param url
* @param name
* @returns
*/
public static loadImageAsyncSafe(url: string, name: string = url): Promise<ImageInfo | null> {
return new Promise((resolve, rehect): void => {
let image: HTMLImageElement = new Image();
image.onload = function () {
let info: ImageInfo = new ImageInfo(name, image);
resolve(info);
}
image.onerror = function () {
resolve(null);
}
image.src = url;
});
}
/**
*
* @param url
*/
public static loadTextFileAsync(url: string): Promise<string> {
return new Promise((resolve, reject): void => {
let xhr: XMLHttpRequest = new XMLHttpRequest();
xhr.onreadystatechange = (ev: Event): any => {
if (xhr.readyState === 4 && xhr.status === 200) {
resolve(xhr.responseText);
}
}
xhr.open("get", url, true, null, null);
xhr.send();
});
}
/**
*
* @param url
*/
public static loadArrayBufferAsync(url: string): Promise<ArrayBuffer> {
return new Promise((resolve, reject): void => {
let xhr: XMLHttpRequest = new XMLHttpRequest();
xhr.responseType = "arraybuffer";
xhr.onreadystatechange = (ev: Event): any => {
if (xhr.readyState === 4 && xhr.status === 2000) {
resolve(xhr.response as ArrayBuffer);
}
}
xhr.open("get", url, true, null, null);
xhr.send();
});
}
}

9
src/renderi/core/ImageInfo.ts

@ -0,0 +1,9 @@
export class ImageInfo {
public name: string;
public image: HTMLElement;
public constructor(path: string, image: HTMLElement) {
this.name = path;
this.image = image;
}
}

50
src/renderi/lib/AsyncLoadTestApplication.ts

@ -0,0 +1,50 @@
import { HttpRequest } from "../commons/HttpRequest";
import { Application } from "../core/Application";
export class AsyncLoadTestApplication extends Application {
/**
* @var
*/
private _urls: string[] = ["data/pic0.png", "data/pic1.jpg", "data/textureUV.jpg"];
/**
*
* await使async关键字
*/
public async loadImageSequence(): Promise<void> {
for (let i = 0; i < this._urls.length; i++) {
let image: HTMLImageElement = await HttpRequest.loadImageAsync(this._urls[i]);
console.log("Load image sequence ", i, image);
}
}
/**
*
*/
public loadImageParallel(): void {
let _promises: Promise<HTMLImageElement>[] = [];
for (let i = 0; i < this._urls.length; i++) {
_promises.push(HttpRequest.loadImageAsync(this._urls[i]));
}
Promise.all(_promises).then((images: HTMLImageElement[]) => {
for (let i: number = 0; i < images.length; i++) {
console.log("Load image parallel", images[i]);
}
});
}
/**
* txt文件
*/
public async loadTextFile(): Promise<void> {
let str: string = await HttpRequest.loadTextFileAsync("data/test.txt");
console.log(str);
}
public async run(): Promise<void> {
await this.loadImageSequence();
await this.loadTextFile();
this.loadImageParallel();
}
}

16
src/renderi/lib/CameraApplication.ts

@ -1,15 +1,17 @@
import { CanvasKeyBoardEvent } from "../core/Event";
import { GLApplication } from "../webgl/GLApplication"; import { GLApplication } from "../webgl/GLApplication";
export class CameraApplication extends GLApplication { export class CameraApplication extends GLApplication {
/** /**
* @var * @var
*/ */
public camera: Camera;
//public camera: Camera;
public constructor(canvas: HTMLCanvasElement, contextAttributes: WebGLContextAttributes = { premultipliedAlpha: false }, need2d: boolean = false) { public constructor(canvas: HTMLCanvasElement, contextAttributes: WebGLContextAttributes = { premultipliedAlpha: false }, need2d: boolean = false) {
super(canvas, contextAttributes, need2d);
this.camera = new Camera(this.gl, canvas.width, canvas.height, 45, 1, 200);
this.camera.z = 4;
super(canvas);
//super(canvas, contextAttributes, need2d);
//this.camera = new Camera(this.gl, canvas.width, canvas.height, 45, 1, 200);
//this.camera.z = 4;
} }
/** /**
@ -19,7 +21,7 @@ export class CameraApplication extends GLApplication {
* @param intervalSec * @param intervalSec
*/ */
public update(elapsedMsec: number, intervalSec: number) { public update(elapsedMsec: number, intervalSec: number) {
this.camera.update(intervalSec);
//this.camera.update(intervalSec);
} }
/** /**
@ -27,7 +29,7 @@ export class CameraApplication extends GLApplication {
* @param evt * @param evt
*/ */
public onKeyPress(evt: CanvasKeyBoardEvent): void { public onKeyPress(evt: CanvasKeyBoardEvent): void {
if (evt.key === "w") {
/*if (evt.key === "w") {
this.camera.moveForward(-1); // 摄像机向前运行 this.camera.moveForward(-1); // 摄像机向前运行
} else if (evt.key === "s") { } else if (evt.key === "s") {
this.camera.moveForward(1); // 摄像机向后运行 this.camera.moveForward(1); // 摄像机向后运行
@ -45,6 +47,6 @@ export class CameraApplication extends GLApplication {
this.camera.roll(1); // 摄像机绕本身的Z轴旋转 this.camera.roll(1); // 摄像机绕本身的Z轴旋转
} else if (evt.key == "p") { } else if (evt.key == "p") {
this.camera.pitch(1); // 摄像机绕本身的X轴旋转 this.camera.pitch(1); // 摄像机绕本身的X轴旋转
}
}*/
} }
} }

6
src/renderi/webgl/GLApplication.ts

@ -4,17 +4,17 @@ export class GLApplication extends Application {
/** /**
* @var WebGL * @var WebGL
*/ */
public gl: WebGLRenderingContext;
//public gl: WebGLRenderingContext;
/** /**
* @var OpenGL1.1 * @var OpenGL1.1
*/ */
public matStack: GLWordMatrixStack;
//public matStack: GLWordMatrixStack;
/** /**
* @var OpenGL1.1 * @var OpenGL1.1
*/ */
public builder: GLMeshBuilder;
//public builder: GLMeshBuilder;
/** /**
* @var canvas * @var canvas

Loading…
Cancel
Save