update example project

This commit is contained in:
Nick Fisher
2021-09-24 11:48:09 +08:00
parent 1361fc7d41
commit a0fc14c33b
3 changed files with 100 additions and 94 deletions

View File

@@ -26,7 +26,7 @@ PODS:
- Filament/utils (1.12.4) - Filament/utils (1.12.4)
- Flutter (1.0.0) - Flutter (1.0.0)
- mimetic_filament (0.0.1): - mimetic_filament (0.0.1):
- Filament (~> 1.12.3) - Filament (~> 1.12.4)
- Flutter - Flutter
DEPENDENCIES: DEPENDENCIES:
@@ -46,7 +46,7 @@ EXTERNAL SOURCES:
SPEC CHECKSUMS: SPEC CHECKSUMS:
Filament: 701abb8200237da11b6f74c318f2a875ef309b91 Filament: 701abb8200237da11b6f74c318f2a875ef309b91
Flutter: 50d75fe2f02b26cc09d224853bb45737f8b3214a Flutter: 50d75fe2f02b26cc09d224853bb45737f8b3214a
mimetic_filament: 089d6e6ef4a3061fa22b023a895e0a3e0e350254 mimetic_filament: 786c54c8c204e2898f9ca33c45ea7500042df62a
PODFILE CHECKSUM: 7adbc9d59f05e1b01f554ea99b6c79e97f2214a2 PODFILE CHECKSUM: 7adbc9d59f05e1b01f554ea99b6c79e97f2214a2

View File

@@ -285,7 +285,7 @@
buildSettings = { buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO; ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_ANALYZER_NONNULL = YES; CLANG_ANALYZER_NONNULL = YES;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; CLANG_CXX_LANGUAGE_STANDARD = "c++17";
CLANG_CXX_LIBRARY = "libc++"; CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES; CLANG_ENABLE_OBJC_ARC = YES;
@@ -315,6 +315,7 @@
ENABLE_NS_ASSERTIONS = NO; ENABLE_NS_ASSERTIONS = NO;
ENABLE_STRICT_OBJC_MSGSEND = YES; ENABLE_STRICT_OBJC_MSGSEND = YES;
GCC_C_LANGUAGE_STANDARD = gnu99; GCC_C_LANGUAGE_STANDARD = gnu99;
GCC_INPUT_FILETYPE = automatic;
GCC_NO_COMMON_BLOCKS = YES; GCC_NO_COMMON_BLOCKS = YES;
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
@@ -363,7 +364,7 @@
buildSettings = { buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO; ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_ANALYZER_NONNULL = YES; CLANG_ANALYZER_NONNULL = YES;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; CLANG_CXX_LANGUAGE_STANDARD = "c++17";
CLANG_CXX_LIBRARY = "libc++"; CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES; CLANG_ENABLE_OBJC_ARC = YES;
@@ -394,6 +395,7 @@
ENABLE_TESTABILITY = YES; ENABLE_TESTABILITY = YES;
GCC_C_LANGUAGE_STANDARD = gnu99; GCC_C_LANGUAGE_STANDARD = gnu99;
GCC_DYNAMIC_NO_PIC = NO; GCC_DYNAMIC_NO_PIC = NO;
GCC_INPUT_FILETYPE = automatic;
GCC_NO_COMMON_BLOCKS = YES; GCC_NO_COMMON_BLOCKS = YES;
GCC_OPTIMIZATION_LEVEL = 0; GCC_OPTIMIZATION_LEVEL = 0;
GCC_PREPROCESSOR_DEFINITIONS = ( GCC_PREPROCESSOR_DEFINITIONS = (
@@ -420,7 +422,7 @@
buildSettings = { buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO; ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_ANALYZER_NONNULL = YES; CLANG_ANALYZER_NONNULL = YES;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; CLANG_CXX_LANGUAGE_STANDARD = "c++17";
CLANG_CXX_LIBRARY = "libc++"; CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES; CLANG_ENABLE_OBJC_ARC = YES;
@@ -450,6 +452,7 @@
ENABLE_NS_ASSERTIONS = NO; ENABLE_NS_ASSERTIONS = NO;
ENABLE_STRICT_OBJC_MSGSEND = YES; ENABLE_STRICT_OBJC_MSGSEND = YES;
GCC_C_LANGUAGE_STANDARD = gnu99; GCC_C_LANGUAGE_STANDARD = gnu99;
GCC_INPUT_FILETYPE = automatic;
GCC_NO_COMMON_BLOCKS = YES; GCC_NO_COMMON_BLOCKS = YES;
GCC_WARN_64_TO_32_BIT_CONVERSION = YES; GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;

View File

@@ -23,7 +23,7 @@ class _MyAppState extends State<MyApp> {
bool _rotate = false; bool _rotate = false;
int _primitiveIndex = 0; int _primitiveIndex = 0;
double _weight = 0.0; final weights = List.filled(255, 0.0);
List<String> _targets = []; List<String> _targets = [];
@override @override
@@ -61,97 +61,100 @@ class _MyAppState extends State<MyApp> {
}, },
child: Stack(children: [ child: Stack(children: [
FilamentWidget(controller: _filamentController), FilamentWidget(controller: _filamentController),
Column( Positioned.fill(
mainAxisSize: MainAxisSize.min, top: 200,
children: [ child: SingleChildScrollView(
ElevatedButton( child: Column(
child: Text("initialize"), mainAxisSize: MainAxisSize.min,
onPressed: () async { children: [
await _filamentController.loadSkybox( SizedBox(
"assets/default_env/default_env_skybox.ktx", height: 100,
"assets/default_env/default_env_ibl.ktx"); child: Row(children: [
await _filamentController.loadGltf( ElevatedButton(
"assets/guy.gltf", "assets"); child: Text("initialize"),
_targets = await _filamentController onPressed: () async {
.getTargetNames("CC_Base_Body.002"); await _filamentController.loadSkybox(
setState(() {}); "assets/default_env/default_env_skybox.ktx",
"assets/default_env/default_env_ibl.ktx");
await _filamentController.loadGltf(
"assets/caleb_mouth_morph_target.gltf",
"assets");
_targets = await _filamentController
.getTargetNames("CC_Base_Body");
setState(() {});
// _filamentController.createMorpher( _filamentController.createMorpher(
// "CC_Base_Body.003", "CC_Base_Body.003", "CC_Base_Body", [1, 7, 8]);
// materialName: "Material"); }),
}), Checkbox(
// ElevatedButton( value: _rotate,
// child: Text("load skybox"), onChanged: (v) {
// onPressed: () { setState(() {
// _filamentController.loadSkybox( _rotate = v == true;
// "assets/default_env/default_env_skybox.ktx", });
// "assets/default_env/default_env_ibl.ktx"); }),
// }), ElevatedButton(
// ElevatedButton( onPressed: () =>
// child: Text("load gltf"), _filamentController.zoom(30.0),
// onPressed: () { child: const Text("-")),
// _filamentController.loadGltf( ElevatedButton(
// "assets/guy.gltf", "assets", "Material"); onPressed: () =>
// }), _filamentController.zoom(-30.0),
// ElevatedButton( child: const Text("+")),
// child: Text("create morpher"), ElevatedButton(
// onPressed: () { onPressed: () =>
// _filamentController.createMorpher( _filamentController.playAnimation(0),
// "CC_Base_Body.003", "CC_Base_Body.003", child: const Text("Play"))
// materialName: "Material"); ])),
// }), Column(
Row(children: [ children: _targets
Container( .asMap()
padding: EdgeInsets.all(10), .map((i, t) => MapEntry(
color: Colors.white, i,
child: Text(_primitiveIndex.toString())), Row(children: [
ElevatedButton( Text(t),
child: Text("+"), Slider(
onPressed: () { min: 0,
setState(() { max: 1,
_primitiveIndex = min(_primitiveIndex + 1, 5); divisions: 10,
}); value: weights[i],
}), onChanged: (v) {
ElevatedButton( setState(() {
child: Text("-"), weights[i] = v;
onPressed: () { _filamentController
setState(() { .applyWeights(weights);
_primitiveIndex = max(_primitiveIndex - 1, 0); });
}); })
}), ])))
]), .values
Slider( .toList(),
min: 0, )
max: 1, ],
divisions: 10, ),
value: _weight, )),
onChanged: (v) {
setState(() {
_weight = v;
_filamentController.applyWeights(
List.filled(255, _weight),
_primitiveIndex.toInt());
});
}),
Row(children: [
Checkbox(
value: _rotate,
onChanged: (v) {
setState(() {
_rotate = v == true;
});
}),
ElevatedButton(
onPressed: () => _filamentController.zoom(100.0),
child: const Text("+")),
ElevatedButton(
onPressed: () => _filamentController.zoom(-100.0),
child: const Text("-"))
]),
] +
_targets.map((t) => Text(t)).toList()),
])), ])),
), ),
); );
} }
} }
// ElevatedButton(
// child: Text("load skybox"),
// onPressed: () {
// _filamentController.loadSkybox(
// "assets/default_env/default_env_skybox.ktx",
// "assets/default_env/default_env_ibl.ktx");
// }),
// ElevatedButton(
// child: Text("load gltf"),
// onPressed: () {
// _filamentController.loadGltf(
// "assets/guy.gltf", "assets", "Material");
// }),
// ElevatedButton(
// child: Text("create morpher"),
// onPressed: () {
// _filamentController.createMorpher(
// "CC_Base_Body.003", "CC_Base_Body.003",
// materialName: "Material");
// }),