1
0
Fork 0

Update to Cubism 4 SDK for Web R5 beta1

hfjnulyz-patch-1
wada 2022-05-19 14:23:41 +09:00
parent 13ba60d1b2
commit dd67abe333
27 changed files with 3049 additions and 1264 deletions

View File

@ -4,7 +4,6 @@ extends:
- plugin:@typescript-eslint/recommended
- plugin:@typescript-eslint/recommended-requiring-type-checking
- plugin:prettier/recommended
- prettier/@typescript-eslint
plugins:
- '@typescript-eslint'
parser: '@typescript-eslint/parser'
@ -16,7 +15,35 @@ rules:
prettier/prettier:
- error
- singleQuote: true
'@typescript-eslint/camelcase': warn
camelcase: "off"
'@typescript-eslint/naming-convention':
- warn
- selector: default
format:
- camelCase
- selector: variable
format:
- camelCase
- UPPER_CASE
leadingUnderscore: allow
trailingUnderscore: allow
- selector: class
format:
- PascalCase
trailingUnderscore: allow
- selector: parameter
format:
- camelCase
leadingUnderscore: allow
- selector: memberLike
modifiers:
- private
format:
- camelCase
leadingUnderscore: require
- selector: typeLike
format:
- PascalCase
'@typescript-eslint/no-use-before-define': off
no-empty-function: off
'@typescript-eslint/no-empty-function':
@ -25,6 +52,12 @@ rules:
- constructors
'no-fallthrough': warn
'@typescript-eslint/unbound-method': off
'@typescript-eslint/no-unsafe-assignment': off
'@typescript-eslint/restrict-plus-operands': off
'@typescript-eslint/no-unsafe-return': off
'@typescript-eslint/no-unsafe-member-access': off
'@typescript-eslint/no-unsafe-argument': off
'@typescript-eslint/no-unsafe-call': off
'no-inner-declarations': off
'@typescript-eslint/class-name-casing': warn
'no-global-assign': off
'prefer-const': warn

View File

@ -4,6 +4,20 @@ All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
## [4-r.5-beta.1] - 2022-05-19
### Added
* Add processing related to multiply colors and screen colors added in Cubism 4.2.
### Fixed
* Fix usage of Anisotropy filtering.
* Fix model was not displayed when the number of masks exceeded the limit.
* Fix getTextureDirectory() to return the directory name of the 0th texture path.
## [4-r.4] - 2021-12-09
### Fixed
@ -66,6 +80,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
* Reformat code using Prettier and ESLint.
[4-r.5-beta.1]: https://github.com/Live2D/CubismWebFramework/compare/4-r.4...4-r.5-beta.1
[4-r.4]: https://github.com/Live2D/CubismWebFramework/compare/4-r.3...4-r.4
[4-r.3]: https://github.com/Live2D/CubismWebFramework/compare/4-r.3-beta.1...4-r.3
[4-r.3-beta.1]: https://github.com/Live2D/CubismWebFramework/compare/4-r.2...4-r.3-beta.1

View File

@ -17,14 +17,15 @@ Live2D Cubism 4 Editor で出力したモデルをアプリケーションで利
### Node.js
* 17.2.0
* 16.13.1
* 14.18.2
* 12.22.7
* 18.1.0
* 17.9.0
* 16.15.0
* 14.19.2
### TypeScript
4.5.2
4.6.4
## 開発環境構築
@ -140,4 +141,4 @@ JSONパーサーやログ出力などのユーティリティ機能を提供し
ユーザー同士でCubism SDKの活用方法の提案や質問をしたい場合は、是非コミュニティをご活用ください。
- [Live2D 公式コミュニティ](https://creatorsforum.live2d.com/)
- [Live2D community(English)](http://community.live2d.com/)
- [Live2D community(English)](https://community.live2d.com/)

2713
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -8,13 +8,13 @@
"clean": "rimraf dist"
},
"devDependencies": {
"@typescript-eslint/eslint-plugin": "^2.18.0",
"@typescript-eslint/parser": "^2.18.0",
"eslint": "^6.8.0",
"eslint-config-prettier": "^6.10.0",
"eslint-plugin-prettier": "^3.1.2",
"prettier": "^1.19.1",
"rimraf": "^3.0.1",
"typescript": "^3.7.5"
"@typescript-eslint/eslint-plugin": "^5.23.0",
"@typescript-eslint/parser": "^5.23.0",
"eslint": "^8.15.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-prettier": "^4.0.0",
"prettier": "^2.6.2",
"rimraf": "^3.0.2",
"typescript": "^4.6.4"
}
}

View File

@ -60,7 +60,7 @@ export const CubismDefaultParameterId = Object.freeze<Record<string, string>>({
ParamBustY: 'ParamBustY',
ParamBaseX: 'ParamBaseX',
ParamBaseY: 'ParamBaseY',
ParamNONE: 'NONE:'
ParamNONE: 'NONE:',
});
// Namespace definition for compatibility.

View File

@ -73,7 +73,7 @@ enum FrequestNode {
FrequestNode_Textures, // getRoot().getValueByString(FileReferences).getValueByString(Textures)
FrequestNode_Physics, // getRoot().getValueByString(FileReferences).getValueByString(Physics)
FrequestNode_Pose, // getRoot().getValueByString(FileReferences).getValueByString(Pose)
FrequestNode_HitAreas // getRoot().getValueByString(HitAreas)
FrequestNode_HitAreas, // getRoot().getValueByString(HitAreas)
}
/**
@ -183,9 +183,25 @@ export class CubismModelSettingJson extends ICubismModelSetting {
* @return
*/
public getTextureDirectory(): string {
return this._jsonValue
const texturePath = this._jsonValue
.at(FrequestNode.FrequestNode_Textures)
.getValueByIndex(0)
.getRawString();
const pathArray = texturePath.split('/');
// 最後の要素はテクスチャ名なので不要
const arrayLength = pathArray.length - 1;
let textureDirectoryStr = '';
// 分割したパスを結合
for (let i = 0; i < arrayLength; i++) {
textureDirectoryStr += pathArray[i];
if (i < arrayLength - 1) {
textureDirectoryStr += '/';
}
}
return textureDirectoryStr;
}
/**
@ -496,10 +512,7 @@ export class CubismModelSettingJson extends ICubismModelSetting {
}
if (refI.getValueByString(Name).getRawString() == EyeBlink) {
num = refI
.getValueByString(Ids)
.getVector()
.getSize();
num = refI.getValueByString(Ids).getVector().getSize();
break;
}
}
@ -531,10 +544,7 @@ export class CubismModelSettingJson extends ICubismModelSetting {
if (refI.getValueByString(Name).getRawString() == EyeBlink) {
return CubismFramework.getIdManager().getId(
refI
.getValueByString(Ids)
.getValueByIndex(index)
.getRawString()
refI.getValueByString(Ids).getValueByIndex(index).getRawString()
);
}
}
@ -564,10 +574,7 @@ export class CubismModelSettingJson extends ICubismModelSetting {
}
if (refI.getValueByString(Name).getRawString() == LipSync) {
num = refI
.getValueByString(Ids)
.getVector()
.getSize();
num = refI.getValueByString(Ids).getVector().getSize();
break;
}
}
@ -599,10 +606,7 @@ export class CubismModelSettingJson extends ICubismModelSetting {
if (refI.getValueByString(Name).getRawString() == LipSync) {
return CubismFramework.getIdManager().getId(
refI
.getValueByString(Ids)
.getValueByIndex(index)
.getRawString()
refI.getValueByString(Ids).getValueByIndex(index).getRawString()
);
}
}

View File

@ -219,7 +219,7 @@ export enum EyeState {
EyeState_Interval, // まばたきしていない状態
EyeState_Closing, // まぶたが閉じていく途中の状態
EyeState_Closed, // まぶたが閉じている状態
EyeState_Opening // まぶたが開いていく途中の状態
EyeState_Opening, // まぶたが開いていく途中の状態
}
// Namespace definition for compatibility.

View File

@ -60,9 +60,10 @@ export class CubismPose {
for (let groupIndex = 0; groupIndex < idCount; ++groupIndex) {
const partInfo: Value = idListInfo.getValueByIndex(groupIndex);
const partData: PartData = new PartData();
const parameterId: CubismIdHandle = CubismFramework.getIdManager().getId(
partInfo.getValueByString(Id).getRawString()
);
const parameterId: CubismIdHandle =
CubismFramework.getIdManager().getId(
partInfo.getValueByString(Id).getRawString()
);
partData.partId = parameterId;
@ -163,10 +164,7 @@ export class CubismPose {
model.setParameterValueByIndex(paramIndex, j == beginIndex ? 1.0 : 0.0);
for (let k = 0; k < this._partGroups.at(j).link.getSize(); ++k) {
this._partGroups
.at(j)
.link.at(k)
.initialize(model);
this._partGroups.at(j).link.at(k).initialize(model);
}
}

View File

@ -96,12 +96,7 @@ export class CubismIdManager {
*/
private findId(id: string): CubismId {
for (let i = 0; i < this._ids.getSize(); ++i) {
if (
this._ids
.at(i)
.getString()
.isEqual(id)
) {
if (this._ids.at(i).getString().isEqual(id)) {
return this._ids.at(i);
}
}

View File

@ -10,7 +10,7 @@ import { CubismRenderer } from './rendering/cubismrenderer';
import {
CSM_ASSERT,
CubismLogInfo,
CubismLogWarning
CubismLogWarning,
} from './utils/cubismdebug';
import { Value } from './utils/cubismjson';
@ -56,7 +56,7 @@ let s_cubismIdManager: CubismIdManager = null;
*/
export const Constant = Object.freeze<Record<string, number>>({
vertexOffset: 0, // メッシュ頂点のオフセット値
vertexStep: 2 // メッシュ頂点のステップ値
vertexStep: 2, // メッシュ頂点のステップ値
});
export function csmDelete<T>(address: T): void {
@ -263,7 +263,7 @@ export enum LogLevel {
LogLevel_Info, // Infoログ
LogLevel_Warning, // 警告ログ
LogLevel_Error, // エラーログ
LogLevel_Off // ログ出力無効
LogLevel_Off, // ログ出力無効
}
// Namespace definition for compatibility.

View File

@ -32,22 +32,8 @@ export class CubismMatrix44 {
dst: Float32Array
): void {
const c: Float32Array = new Float32Array([
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0,
0.0
]);
const n = 4;
@ -70,22 +56,8 @@ export class CubismMatrix44 {
*/
public loadIdentity(): void {
const c: Float32Array = new Float32Array([
1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0,
1.0,
0.0,
0.0,
0.0,
0.0,
1.0,
0.0,
0.0,
0.0,
0.0,
1.0,
0.0,
0.0,
0.0,
0.0,
1.0
]);
this.setMatrix(c);
@ -203,7 +175,7 @@ export class CubismMatrix44 {
x,
y,
0.0,
1.0
1.0,
]);
CubismMatrix44.multiply(tr1, this._tr, this._tr);
@ -263,7 +235,7 @@ export class CubismMatrix44 {
0.0,
0.0,
0.0,
1.0
1.0,
]);
CubismMatrix44.multiply(tr1, this._tr, this._tr);

View File

@ -72,7 +72,7 @@ export class CubismViewMatrix extends CubismMatrix44 {
x,
y,
0.0,
1.0
1.0,
]);
CubismMatrix44.multiply(tr1, this._tr, this._tr);
@ -117,7 +117,7 @@ export class CubismViewMatrix extends CubismMatrix44 {
cx,
cy,
0.0,
1.0
1.0,
]);
const tr2: Float32Array = new Float32Array([
@ -136,7 +136,7 @@ export class CubismViewMatrix extends CubismMatrix44 {
0.0,
0.0,
0.0,
1.0
1.0,
]);
const tr3: Float32Array = new Float32Array([
@ -155,7 +155,7 @@ export class CubismViewMatrix extends CubismMatrix44 {
-cx,
-cy,
0.0,
1.0
1.0,
]);
CubismMatrix44.multiply(tr3, this._tr, this._tr);

View File

@ -19,9 +19,8 @@ export class CubismMoc {
*/
public static create(mocBytes: ArrayBuffer): CubismMoc {
let cubismMoc: CubismMoc = null;
const moc: Live2DCubismCore.Moc = Live2DCubismCore.Moc.fromArrayBuffer(
mocBytes
);
const moc: Live2DCubismCore.Moc =
Live2DCubismCore.Moc.fromArrayBuffer(mocBytes);
if (moc) {
cubismMoc = new CubismMoc(moc);

View File

@ -7,11 +7,23 @@
import { CubismIdHandle } from '../id/cubismid';
import { CubismFramework } from '../live2dcubismframework';
import { CubismBlendMode } from '../rendering/cubismrenderer';
import {
CubismBlendMode,
CubismTextureColor,
} from '../rendering/cubismrenderer';
import { csmMap } from '../type/csmmap';
import { csmVector } from '../type/csmvector';
import { CSM_ASSERT } from '../utils/cubismdebug';
/**
* SDKDrawable
*
*/
export class DrawableColorData {
isOverwritten = false;
Color: CubismTextureColor = new CubismTextureColor();
}
/**
*
*
@ -70,6 +82,190 @@ export class CubismModel {
}
}
/**
*
* @param index Drawables
* @returns drawable(RGBA)
*/
public getMultiplyColor(index: number): CubismTextureColor {
// Drawableとモデル全体の乗算色上書きフラグがどちらもtrueな場合、モデル全体の上書きフラグが優先される
if (
this.getOverwriteFlagForModelMultiplyColors() ||
this.getOverwriteFlagForDrawableMultiplyColors(index)
) {
return this._userMultiplyColors.at(index).Color;
}
const color = this.getDrawableMultiplyColor(index);
return color;
}
/**
*
* @param index Drawables
* @returns drawable(RGBA)
*/
public getScreenColor(index: number): CubismTextureColor {
// Drawableとモデル全体のスクリーン色上書きフラグがどちらもtrueな場合、モデル全体の上書きフラグが優先される
if (
this.getOverwriteFlagForModelScreenColors() ||
this.getOverwriteFlagForDrawableScreenColors(index)
) {
return this._userScreenColors.at(index).Color;
}
const color = this.getDrawableScreenColor(index);
return color;
}
/**
*
* @param index Drawables
* @param color (CubismTextureColor)
*/
public setMultiplyColorByTextureColor(
index: number,
color: CubismTextureColor
) {
this.setMultiplyColorByRGBA(index, color.R, color.G, color.B, color.A);
}
/**
*
* @param index Drawables
* @param r R
* @param g G
* @param b B
* @param a A
*/
public setMultiplyColorByRGBA(
index: number,
r: number,
g: number,
b: number,
a = 1.0
) {
this._userMultiplyColors.at(index).Color.R = r;
this._userMultiplyColors.at(index).Color.G = g;
this._userMultiplyColors.at(index).Color.B = b;
this._userMultiplyColors.at(index).Color.A = a;
}
/**
*
* @param index Drawables
* @param color (CubismTextureColor)
*/
public setScreenColorByTextureColor(
index: number,
color: CubismTextureColor
) {
this.setScreenColorByRGBA(index, color.R, color.G, color.B, color.A);
}
/**
*
* @param index Drawables
* @param r R
* @param g G
* @param b B
* @param a A
*/
public setScreenColorByRGBA(
index: number,
r: number,
g: number,
b: number,
a = 1.0
) {
this._userScreenColors.at(index).Color.R = r;
this._userScreenColors.at(index).Color.G = g;
this._userScreenColors.at(index).Color.B = b;
this._userScreenColors.at(index).Color.A = a;
}
/**
* SDK
* @returns true -> SDK
* false -> 使
*/
public getOverwriteFlagForModelMultiplyColors(): boolean {
return this._isOverwrittenModelMultiplyColors;
}
/**
* SDK
* @returns true -> SDK
* false -> 使
*/
public getOverwriteFlagForModelScreenColors(): boolean {
return this._isOverwrittenModelScreenColors;
}
/**
* SDK
* @param value true -> SDK
* false -> 使
*/
public setOverwriteFlagForModelMultiplyColors(value: boolean) {
this._isOverwrittenModelMultiplyColors = value;
}
/**
* SDK
* @param value true -> SDK
* false -> 使
*/
public setOverwriteFlagForModelScreenColors(value: boolean) {
this._isOverwrittenModelScreenColors = value;
}
/**
* SDKDrawableIndex
* @returns true -> SDK
* false -> 使
*/
public getOverwriteFlagForDrawableMultiplyColors(
drawableindex: number
): boolean {
return this._userMultiplyColors.at(drawableindex).isOverwritten;
}
/**
* SDKDrawableIndex
* @returns true -> SDK
* false -> 使
*/
public getOverwriteFlagForDrawableScreenColors(
drawableindex: number
): boolean {
return this._userMultiplyColors.at(drawableindex).isOverwritten;
}
/**
* SDKDrawableIndex
* @param value true -> SDK
* false -> 使
*/
public setOverwriteFlagForDrawableMultiplyColors(
drawableindex: number,
value: boolean
) {
this._userMultiplyColors.at(drawableindex).isOverwritten = value;
}
/**
* SDKDrawableIndex
* @param value true -> SDK
* false -> 使
*/
public setOverwriteFlagForDrawableScreenColors(
drawableindex: number,
value: boolean
) {
this._userScreenColors.at(drawableindex).isOverwritten = value;
}
/**
*
*/
@ -546,6 +742,40 @@ export class CubismModel {
return opacities[drawableIndex];
}
/**
* Drawable
* @param drawableIndex Drawable
* @return drawable(RGBA)
* RGBAA0
*/
public getDrawableMultiplyColor(drawableIndex: number): CubismTextureColor {
const multiplyColors: Float32Array = this._model.drawables.multiplyColors;
const index = drawableIndex * 4;
const multiplyColor: CubismTextureColor = new CubismTextureColor();
multiplyColor.R = multiplyColors[index];
multiplyColor.G = multiplyColors[index + 1];
multiplyColor.B = multiplyColors[index + 2];
multiplyColor.A = multiplyColors[index + 3];
return multiplyColor;
}
/**
* Drawable
* @param drawableIndex Drawable
* @return drawable(RGBA)
* RGBAA0
*/
public getDrawableScreenColor(drawableIndex: number): CubismTextureColor {
const screenColors: Float32Array = this._model.drawables.screenColors;
const index = drawableIndex * 4;
const screenColor: CubismTextureColor = new CubismTextureColor();
screenColor.R = screenColors[index];
screenColor.G = screenColors[index + 1];
screenColor.B = screenColors[index + 2];
screenColor.A = screenColors[index + 3];
return screenColor;
}
/**
* Drawable
* @param drawableIndex Drawable
@ -695,6 +925,24 @@ export class CubismModel {
);
}
/**
* Drawable
*
* CubismModel.updateDrawable
*
* @param drawableIndex Drawable
* @return true DrawableCubismModel.update
* @return false DrawableCubismModel.update
*/
public getDrawableDynamicFlagBlendColorDidChange(
drawableIndex: number
): boolean {
const dynamicFlags: Uint8Array = this._model.drawables.dynamicFlags;
return Live2DCubismCore.Utils.hasBlendColorDidChangeBit(
dynamicFlags[drawableIndex]
);
}
/**
*
*/
@ -750,11 +998,25 @@ export class CubismModel {
const drawableIds: string[] = this._model.drawables.ids;
const drawableCount: number = this._model.drawables.count;
this._userMultiplyColors = new csmVector<DrawableColorData>();
this._userMultiplyColors.updateSize(
drawableCount,
DrawableColorData,
true
);
this._userScreenColors = new csmVector<DrawableColorData>();
this._userScreenColors.updateSize(drawableCount, DrawableColorData, true);
this._drawableIds.prepareCapacity(drawableCount);
for (let i = 0; i < drawableCount; ++i) {
this._drawableIds.pushBack(
CubismFramework.getIdManager().getId(drawableIds[i])
);
// shaderに影響しない色で初期化
this.setMultiplyColorByRGBA(i, 1.0, 1.0, 1.0, 1.0);
this.setScreenColorByRGBA(i, 0.0, 0.0, 0.0, 1.0);
}
}
}
@ -773,6 +1035,10 @@ export class CubismModel {
this._parameterIds = new csmVector<CubismIdHandle>();
this._drawableIds = new csmVector<CubismIdHandle>();
this._partIds = new csmVector<CubismIdHandle>();
this._isOverwrittenModelMultiplyColors = false;
this._isOverwrittenModelScreenColors = false;
this._userMultiplyColors = null;
this._userScreenColors = null;
this._notExistPartId = new csmMap<CubismIdHandle, number>();
this._notExistParameterId = new csmMap<CubismIdHandle, number>();
@ -796,6 +1062,11 @@ export class CubismModel {
private _savedParameters: csmVector<number>; // 保存されたパラメータ
private _isOverwrittenModelMultiplyColors: boolean; // SDK上でモデル全体の乗算色を上書きするか判定するフラグ
private _isOverwrittenModelScreenColors: boolean; // SDK上でモデル全体のスクリーン色を上書きするか判定するフラグ
private _userMultiplyColors: csmVector<DrawableColorData>; // Drawableごとに設定する乗算色と上書きフラグを管理するリスト
private _userScreenColors: csmVector<DrawableColorData>; // Drawableごとに設定するスクリーン色と上書きフラグを管理するリスト
private _model: Live2DCubismCore.Model; // モデル
private _parameterValues: Float32Array; // パラメータの値のリスト

View File

@ -174,7 +174,7 @@ export class CubismExpressionMotion extends ACubismMotion {
export enum ExpressionBlendType {
ExpressionBlendType_Add = 0, // 加算
ExpressionBlendType_Multiply = 1, // 乗算
ExpressionBlendType_Overwrite = 2 // 上書き
ExpressionBlendType_Overwrite = 2, // 上書き
}
/**

View File

@ -14,7 +14,7 @@ import { csmVector } from '../type/csmvector';
import {
CSM_ASSERT,
CubismLogDebug,
CubismLogWarning
CubismLogWarning,
} from '../utils/cubismdebug';
import { ACubismMotion, FinishedMotionCallback } from './acubismmotion';
import {
@ -24,7 +24,7 @@ import {
CubismMotionEvent,
CubismMotionPoint,
CubismMotionSegment,
CubismMotionSegmentType
CubismMotionSegmentType,
} from './cubismmotioninternal';
import { CubismMotionJson, EvaluationOptionFlag } from './cubismmotionjson';
import { CubismMotionQueueEntry } from './cubismmotionqueueentry';
@ -275,15 +275,13 @@ export class CubismMotion extends ACubismMotion {
motionQueueEntry: CubismMotionQueueEntry
): void {
if (this._modelCurveIdEyeBlink == null) {
this._modelCurveIdEyeBlink = CubismFramework.getIdManager().getId(
EffectNameEyeBlink
);
this._modelCurveIdEyeBlink =
CubismFramework.getIdManager().getId(EffectNameEyeBlink);
}
if (this._modelCurveIdLipSync == null) {
this._modelCurveIdLipSync = CubismFramework.getIdManager().getId(
EffectNameLipSync
);
this._modelCurveIdLipSync =
CubismFramework.getIdManager().getId(EffectNameLipSync);
}
let timeOffsetSeconds: number =
@ -381,9 +379,8 @@ export class CubismMotion extends ACubismMotion {
continue;
}
const sourceValue: number = model.getParameterValueByIndex(
parameterIndex
);
const sourceValue: number =
model.getParameterValueByIndex(parameterIndex);
// Evaluate curve and apply value.
value = evaluateCurve(this._motionData, c, time);
@ -793,24 +790,20 @@ export class CubismMotion extends ACubismMotion {
);
}
this._motionData.curves.at(curveCount).id = json.getMotionCurveId(
curveCount
);
this._motionData.curves.at(curveCount).id =
json.getMotionCurveId(curveCount);
this._motionData.curves.at(
curveCount
).baseSegmentIndex = totalSegmentCount;
this._motionData.curves.at(curveCount).baseSegmentIndex =
totalSegmentCount;
this._motionData.curves.at(
curveCount
).fadeInTime = json.isExistMotionCurveFadeInTime(curveCount)
? json.getMotionCurveFadeInTime(curveCount)
: -1.0;
this._motionData.curves.at(
curveCount
).fadeOutTime = json.isExistMotionCurveFadeOutTime(curveCount)
? json.getMotionCurveFadeOutTime(curveCount)
: -1.0;
this._motionData.curves.at(curveCount).fadeInTime =
json.isExistMotionCurveFadeInTime(curveCount)
? json.getMotionCurveFadeInTime(curveCount)
: -1.0;
this._motionData.curves.at(curveCount).fadeOutTime =
json.isExistMotionCurveFadeOutTime(curveCount)
? json.getMotionCurveFadeOutTime(curveCount)
: -1.0;
// Segments
for (
@ -819,16 +812,13 @@ export class CubismMotion extends ACubismMotion {
) {
if (segmentPosition == 0) {
this._motionData.segments.at(
totalSegmentCount
).basePointIndex = totalPointCount;
this._motionData.segments.at(totalSegmentCount).basePointIndex =
totalPointCount;
this._motionData.points.at(
totalPointCount
).time = json.getMotionCurveSegment(curveCount, segmentPosition);
this._motionData.points.at(
totalPointCount
).value = json.getMotionCurveSegment(curveCount, segmentPosition + 1);
this._motionData.points.at(totalPointCount).time =
json.getMotionCurveSegment(curveCount, segmentPosition);
this._motionData.points.at(totalPointCount).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 1);
totalPointCount += 1;
segmentPosition += 2;
@ -845,22 +835,13 @@ export class CubismMotion extends ACubismMotion {
case CubismMotionSegmentType.CubismMotionSegmentType_Linear: {
this._motionData.segments.at(totalSegmentCount).segmentType =
CubismMotionSegmentType.CubismMotionSegmentType_Linear;
this._motionData.segments.at(
totalSegmentCount
).evaluate = linearEvaluate;
this._motionData.segments.at(totalSegmentCount).evaluate =
linearEvaluate;
this._motionData.points.at(
totalPointCount
).time = json.getMotionCurveSegment(
curveCount,
segmentPosition + 1
);
this._motionData.points.at(
totalPointCount
).value = json.getMotionCurveSegment(
curveCount,
segmentPosition + 2
);
this._motionData.points.at(totalPointCount).time =
json.getMotionCurveSegment(curveCount, segmentPosition + 1);
this._motionData.points.at(totalPointCount).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 2);
totalPointCount += 1;
segmentPosition += 3;
@ -872,53 +853,27 @@ export class CubismMotion extends ACubismMotion {
CubismMotionSegmentType.CubismMotionSegmentType_Bezier;
if (areBeziersRestructed || UseOldBeziersCurveMotion) {
this._motionData.segments.at(
totalSegmentCount
).evaluate = bezierEvaluate;
this._motionData.segments.at(totalSegmentCount).evaluate =
bezierEvaluate;
} else {
this._motionData.segments.at(
totalSegmentCount
).evaluate = bezierEvaluateCardanoInterpretation;
this._motionData.segments.at(totalSegmentCount).evaluate =
bezierEvaluateCardanoInterpretation;
}
this._motionData.points.at(
totalPointCount
).time = json.getMotionCurveSegment(
curveCount,
segmentPosition + 1
);
this._motionData.points.at(
totalPointCount
).value = json.getMotionCurveSegment(
curveCount,
segmentPosition + 2
);
this._motionData.points.at(totalPointCount).time =
json.getMotionCurveSegment(curveCount, segmentPosition + 1);
this._motionData.points.at(totalPointCount).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 2);
this._motionData.points.at(
totalPointCount + 1
).time = json.getMotionCurveSegment(
curveCount,
segmentPosition + 3
);
this._motionData.points.at(
totalPointCount + 1
).value = json.getMotionCurveSegment(
curveCount,
segmentPosition + 4
);
this._motionData.points.at(totalPointCount + 1).time =
json.getMotionCurveSegment(curveCount, segmentPosition + 3);
this._motionData.points.at(totalPointCount + 1).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 4);
this._motionData.points.at(
totalPointCount + 2
).time = json.getMotionCurveSegment(
curveCount,
segmentPosition + 5
);
this._motionData.points.at(
totalPointCount + 2
).value = json.getMotionCurveSegment(
curveCount,
segmentPosition + 6
);
this._motionData.points.at(totalPointCount + 2).time =
json.getMotionCurveSegment(curveCount, segmentPosition + 5);
this._motionData.points.at(totalPointCount + 2).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 6);
totalPointCount += 3;
segmentPosition += 7;
@ -929,22 +884,13 @@ export class CubismMotion extends ACubismMotion {
case CubismMotionSegmentType.CubismMotionSegmentType_Stepped: {
this._motionData.segments.at(totalSegmentCount).segmentType =
CubismMotionSegmentType.CubismMotionSegmentType_Stepped;
this._motionData.segments.at(
totalSegmentCount
).evaluate = steppedEvaluate;
this._motionData.segments.at(totalSegmentCount).evaluate =
steppedEvaluate;
this._motionData.points.at(
totalPointCount
).time = json.getMotionCurveSegment(
curveCount,
segmentPosition + 1
);
this._motionData.points.at(
totalPointCount
).value = json.getMotionCurveSegment(
curveCount,
segmentPosition + 2
);
this._motionData.points.at(totalPointCount).time =
json.getMotionCurveSegment(curveCount, segmentPosition + 1);
this._motionData.points.at(totalPointCount).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 2);
totalPointCount += 1;
segmentPosition += 3;
@ -955,22 +901,13 @@ export class CubismMotion extends ACubismMotion {
case CubismMotionSegmentType.CubismMotionSegmentType_InverseStepped: {
this._motionData.segments.at(totalSegmentCount).segmentType =
CubismMotionSegmentType.CubismMotionSegmentType_InverseStepped;
this._motionData.segments.at(
totalSegmentCount
).evaluate = inverseSteppedEvaluate;
this._motionData.segments.at(totalSegmentCount).evaluate =
inverseSteppedEvaluate;
this._motionData.points.at(
totalPointCount
).time = json.getMotionCurveSegment(
curveCount,
segmentPosition + 1
);
this._motionData.points.at(
totalPointCount
).value = json.getMotionCurveSegment(
curveCount,
segmentPosition + 2
);
this._motionData.points.at(totalPointCount).time =
json.getMotionCurveSegment(curveCount, segmentPosition + 1);
this._motionData.points.at(totalPointCount).value =
json.getMotionCurveSegment(curveCount, segmentPosition + 2);
totalPointCount += 1;
segmentPosition += 3;
@ -993,12 +930,10 @@ export class CubismMotion extends ACubismMotion {
userdatacount < json.getEventCount();
++userdatacount
) {
this._motionData.events.at(userdatacount).fireTime = json.getEventTime(
userdatacount
);
this._motionData.events.at(userdatacount).value = json.getEventValue(
userdatacount
);
this._motionData.events.at(userdatacount).fireTime =
json.getEventTime(userdatacount);
this._motionData.events.at(userdatacount).value =
json.getEventValue(userdatacount);
}
json.release();

View File

@ -17,7 +17,7 @@ import { csmVector } from '../type/csmvector';
export enum CubismMotionCurveTarget {
CubismMotionCurveTarget_Model, // モデルに対して
CubismMotionCurveTarget_Parameter, // パラメータに対して
CubismMotionCurveTarget_PartOpacity // パーツの不透明度に対して
CubismMotionCurveTarget_PartOpacity, // パーツの不透明度に対して
}
/**
@ -29,7 +29,7 @@ export enum CubismMotionSegmentType {
CubismMotionSegmentType_Linear = 0, // リニア
CubismMotionSegmentType_Bezier = 1, // ベジェ曲線
CubismMotionSegmentType_Stepped = 2, // ステップ
CubismMotionSegmentType_InverseStepped = 3 // インバースステップ
CubismMotionSegmentType_InverseStepped = 3, // インバースステップ
}
/**
@ -152,5 +152,6 @@ export namespace Live2DCubismFramework {
export type CubismMotionSegment = $.CubismMotionSegment;
export const CubismMotionSegmentType = $.CubismMotionSegmentType;
export type CubismMotionSegmentType = $.CubismMotionSegmentType;
export type csmMotionSegmentEvaluationFunction = $.csmMotionSegmentEvaluationFunction;
export type csmMotionSegmentEvaluationFunction =
$.csmMotionSegmentEvaluationFunction;
}

View File

@ -371,7 +371,7 @@ export class CubismMotionJson {
* @brief
*/
export enum EvaluationOptionFlag {
EvaluationOptionFlag_AreBeziersRistricted = 0 ///< ベジェハンドルの規制状態
EvaluationOptionFlag_AreBeziersRistricted = 0, ///< ベジェハンドルの規制状態
}
// Namespace definition for compatibility.

View File

@ -9,7 +9,7 @@ import { CubismModel } from '../model/cubismmodel';
import { ACubismMotion } from './acubismmotion';
import {
CubismMotionQueueEntryHandle,
CubismMotionQueueManager
CubismMotionQueueManager,
} from './cubismmotionqueuemanager';
/**

View File

@ -327,7 +327,8 @@ export interface CubismMotionEventFunction {
*
*/
export declare type CubismMotionQueueEntryHandle = any;
export const InvalidMotionQueueEntryHandleValue: CubismMotionQueueEntryHandle = -1;
export const InvalidMotionQueueEntryHandleValue: CubismMotionQueueEntryHandle =
-1;
// Namespace definition for compatibility.
import * as $ from './cubismmotionqueuemanager';

View File

@ -16,7 +16,7 @@ import {
CubismPhysicsRig,
CubismPhysicsSource,
CubismPhysicsSubRig,
CubismPhysicsTargetType
CubismPhysicsTargetType,
} from './cubismphysicsinternal';
import { CubismPhysicsJson } from './cubismphysicsjson';
@ -294,31 +294,19 @@ export class CubismPhysics {
particleIndex = 0;
for (let i = 0; i < this._physicsRig.settings.getSize(); ++i) {
this._physicsRig.settings.at(
i
).normalizationPosition.minimum = json.getNormalizationPositionMinimumValue(
i
);
this._physicsRig.settings.at(
i
).normalizationPosition.maximum = json.getNormalizationPositionMaximumValue(
i
);
this._physicsRig.settings.at(
i
).normalizationPosition.defalut = json.getNormalizationPositionDefaultValue(
i
);
this._physicsRig.settings.at(i).normalizationPosition.minimum =
json.getNormalizationPositionMinimumValue(i);
this._physicsRig.settings.at(i).normalizationPosition.maximum =
json.getNormalizationPositionMaximumValue(i);
this._physicsRig.settings.at(i).normalizationPosition.defalut =
json.getNormalizationPositionDefaultValue(i);
this._physicsRig.settings.at(
i
).normalizationAngle.minimum = json.getNormalizationAngleMinimumValue(i);
this._physicsRig.settings.at(
i
).normalizationAngle.maximum = json.getNormalizationAngleMaximumValue(i);
this._physicsRig.settings.at(
i
).normalizationAngle.defalut = json.getNormalizationAngleDefaultValue(i);
this._physicsRig.settings.at(i).normalizationAngle.minimum =
json.getNormalizationAngleMinimumValue(i);
this._physicsRig.settings.at(i).normalizationAngle.maximum =
json.getNormalizationAngleMaximumValue(i);
this._physicsRig.settings.at(i).normalizationAngle.defalut =
json.getNormalizationAngleDefaultValue(i);
// Input
this._physicsRig.settings.at(i).inputCount = json.getInputCount(i);
@ -330,9 +318,8 @@ export class CubismPhysics {
i,
j
);
this._physicsRig.inputs.at(
inputIndex + j
).reflect = json.getInputReflect(i, j);
this._physicsRig.inputs.at(inputIndex + j).reflect =
json.getInputReflect(i, j);
if (json.getInputType(i, j) == PhysicsTypeTagX) {
this._physicsRig.inputs.at(inputIndex + j).type =
@ -356,9 +343,8 @@ export class CubismPhysics {
this._physicsRig.inputs.at(inputIndex + j).source.targetType =
CubismPhysicsTargetType.CubismPhysicsTargetType_Parameter;
this._physicsRig.inputs.at(
inputIndex + j
).source.id = json.getInputSourceId(i, j);
this._physicsRig.inputs.at(inputIndex + j).source.id =
json.getInputSourceId(i, j);
}
inputIndex += this._physicsRig.settings.at(i).inputCount;
@ -367,57 +353,45 @@ export class CubismPhysics {
this._physicsRig.settings.at(i).baseOutputIndex = outputIndex;
for (let j = 0; j < this._physicsRig.settings.at(i).outputCount; ++j) {
this._physicsRig.outputs.at(
outputIndex + j
).destinationParameterIndex = -1;
this._physicsRig.outputs.at(
outputIndex + j
).vertexIndex = json.getOutputVertexIndex(i, j);
this._physicsRig.outputs.at(
outputIndex + j
).angleScale = json.getOutputAngleScale(i, j);
this._physicsRig.outputs.at(
outputIndex + j
).weight = json.getOutputWeight(i, j);
this._physicsRig.outputs.at(outputIndex + j).destinationParameterIndex =
-1;
this._physicsRig.outputs.at(outputIndex + j).vertexIndex =
json.getOutputVertexIndex(i, j);
this._physicsRig.outputs.at(outputIndex + j).angleScale =
json.getOutputAngleScale(i, j);
this._physicsRig.outputs.at(outputIndex + j).weight =
json.getOutputWeight(i, j);
this._physicsRig.outputs.at(outputIndex + j).destination.targetType =
CubismPhysicsTargetType.CubismPhysicsTargetType_Parameter;
this._physicsRig.outputs.at(
outputIndex + j
).destination.id = json.getOutputDestinationId(i, j);
this._physicsRig.outputs.at(outputIndex + j).destination.id =
json.getOutputDestinationId(i, j);
if (json.getOutputType(i, j) == PhysicsTypeTagX) {
this._physicsRig.outputs.at(outputIndex + j).type =
CubismPhysicsSource.CubismPhysicsSource_X;
this._physicsRig.outputs.at(
outputIndex + j
).getValue = getOutputTranslationX;
this._physicsRig.outputs.at(
outputIndex + j
).getScale = getOutputScaleTranslationX;
this._physicsRig.outputs.at(outputIndex + j).getValue =
getOutputTranslationX;
this._physicsRig.outputs.at(outputIndex + j).getScale =
getOutputScaleTranslationX;
} else if (json.getOutputType(i, j) == PhysicsTypeTagY) {
this._physicsRig.outputs.at(outputIndex + j).type =
CubismPhysicsSource.CubismPhysicsSource_Y;
this._physicsRig.outputs.at(
outputIndex + j
).getValue = getOutputTranslationY;
this._physicsRig.outputs.at(
outputIndex + j
).getScale = getOutputScaleTranslationY;
this._physicsRig.outputs.at(outputIndex + j).getValue =
getOutputTranslationY;
this._physicsRig.outputs.at(outputIndex + j).getScale =
getOutputScaleTranslationY;
} else if (json.getOutputType(i, j) == PhysicsTypeTagAngle) {
this._physicsRig.outputs.at(outputIndex + j).type =
CubismPhysicsSource.CubismPhysicsSource_Angle;
this._physicsRig.outputs.at(
outputIndex + j
).getValue = getOutputAngle;
this._physicsRig.outputs.at(
outputIndex + j
).getScale = getOutputScaleAngle;
this._physicsRig.outputs.at(outputIndex + j).getValue =
getOutputAngle;
this._physicsRig.outputs.at(outputIndex + j).getScale =
getOutputScaleAngle;
}
this._physicsRig.outputs.at(
outputIndex + j
).reflect = json.getOutputReflect(i, j);
this._physicsRig.outputs.at(outputIndex + j).reflect =
json.getOutputReflect(i, j);
}
outputIndex += this._physicsRig.settings.at(i).outputCount;
@ -426,21 +400,16 @@ export class CubismPhysics {
this._physicsRig.settings.at(i).baseParticleIndex = particleIndex;
for (let j = 0; j < this._physicsRig.settings.at(i).particleCount; ++j) {
this._physicsRig.particles.at(
particleIndex + j
).mobility = json.getParticleMobility(i, j);
this._physicsRig.particles.at(
particleIndex + j
).delay = json.getParticleDelay(i, j);
this._physicsRig.particles.at(
particleIndex + j
).acceleration = json.getParticleAcceleration(i, j);
this._physicsRig.particles.at(
particleIndex + j
).radius = json.getParticleRadius(i, j);
this._physicsRig.particles.at(
particleIndex + j
).position = json.getParticlePosition(i, j);
this._physicsRig.particles.at(particleIndex + j).mobility =
json.getParticleMobility(i, j);
this._physicsRig.particles.at(particleIndex + j).delay =
json.getParticleDelay(i, j);
this._physicsRig.particles.at(particleIndex + j).acceleration =
json.getParticleAcceleration(i, j);
this._physicsRig.particles.at(particleIndex + j).radius =
json.getParticleRadius(i, j);
this._physicsRig.particles.at(particleIndex + j).position =
json.getParticlePosition(i, j);
}
particleIndex += this._physicsRig.settings.at(i).particleCount;

View File

@ -13,7 +13,7 @@ import { csmVector } from '../type/csmvector';
*
*/
export enum CubismPhysicsTargetType {
CubismPhysicsTargetType_Parameter // パラメータに対して適用
CubismPhysicsTargetType_Parameter, // パラメータに対して適用
}
/**
@ -22,7 +22,7 @@ export enum CubismPhysicsTargetType {
export enum CubismPhysicsSource {
CubismPhysicsSource_X, // X軸の位置から
CubismPhysicsSource_Y, // Y軸の位置から
CubismPhysicsSource_Angle // 角度から
CubismPhysicsSource_Angle, // 角度から
}
/**
@ -243,7 +243,8 @@ export namespace Live2DCubismFramework {
export type CubismPhysicsTargetType = $.CubismPhysicsTargetType;
export const PhysicsJsonEffectiveForces = $.PhysicsJsonEffectiveForces;
export type PhysicsJsonEffectiveForces = $.PhysicsJsonEffectiveForces;
export type normalizedPhysicsParameterValueGetter = $.normalizedPhysicsParameterValueGetter;
export type normalizedPhysicsParameterValueGetter =
$.normalizedPhysicsParameterValueGetter;
export type physicsScaleGetter = $.physicsScaleGetter;
export type physicsValueGetter = $.physicsValueGetter;
}

View File

@ -159,7 +159,7 @@ export abstract class CubismRenderer {
* @param n
*/
public setAnisotropy(n: number): void {
this._anisortopy = n;
this._anisotropy = n;
}
/**
@ -167,7 +167,7 @@ export abstract class CubismRenderer {
* @return
*/
public getAnisotropy(): number {
return this._anisortopy;
return this._anisotropy;
}
/**
@ -184,7 +184,7 @@ export abstract class CubismRenderer {
protected constructor() {
this._isCulling = false;
this._isPremultipliedAlpha = false;
this._anisortopy = 0.0;
this._anisotropy = 0.0;
this._model = null;
this._modelColor = new CubismTextureColor();
@ -218,6 +218,8 @@ export abstract class CubismRenderer {
indexArray: Uint16Array,
vertexArray: Float32Array,
uvArray: Float32Array,
multiplyColor: CubismTextureColor,
screenColor: CubismTextureColor,
opacity: number,
colorBlendMode: CubismBlendMode,
invertedMask: boolean
@ -226,20 +228,20 @@ export abstract class CubismRenderer {
/**
*
*/
public static staticRelease: Function;
public static staticRelease: any;
protected _mvpMatrix4x4: CubismMatrix44; // Model-View-Projection 行列
protected _modelColor: CubismTextureColor; // モデル自体のカラーRGBA
protected _isCulling: boolean; // カリングが有効ならtrue
protected _isPremultipliedAlpha: boolean; // 乗算済みαならtrue
protected _anisortopy: any; // テクスチャの異方性フィルタリングのパラメータ
protected _anisotropy: any; // テクスチャの異方性フィルタリングのパラメータ
protected _model: CubismModel; // レンダリング対象のモデル
}
export enum CubismBlendMode {
CubismBlendMode_Normal = 0, // 通常
CubismBlendMode_Additive = 1, // 加算
CubismBlendMode_Multiplicative = 2 // 乗算
CubismBlendMode_Multiplicative = 2, // 乗算
}
/**

File diff suppressed because it is too large Load Diff

View File

@ -11,7 +11,7 @@ import {
CSM_LOG_LEVEL_ERROR,
CSM_LOG_LEVEL_INFO,
CSM_LOG_LEVEL_VERBOSE,
CSM_LOG_LEVEL_WARNING
CSM_LOG_LEVEL_WARNING,
} from '../cubismframeworkconfig';
import { CubismFramework, LogLevel } from '../live2dcubismframework';

View File

@ -307,7 +307,7 @@ export class CubismJson {
* return false:
*/
public parseBytes(buffer: ArrayBuffer, size: number): boolean {
const endPos: number[] = new Array(1); // 参照渡しにするため配列
const endPos: number[] = new Array<number>(1); // 参照渡しにするため配列
const decodeBuffer: string = this.arrayBufferToString(buffer);
this._root = this.parseValue(decodeBuffer, size, 0, endPos);