根据我在文档中的理解,可以使用Metal或GL着色器来修改iOS 9和Xcode 7中的SceneKit渲染.文档建议这与GL着色器一样.
我的方法是尝试获取.Metal文件的路径,然后将其加载到字符串中,以[String:String]字典的形式在SCNMaterial shaderModifIErs属性中使用,就像使用GL着色器一样(尽管我还没有让它正常工作).
我的代码是:
var shaders = [String: String]()let path = NSBundle.mainBundle().pathForResource("AAPLCelShader",ofType: "Metal")!do{ let celShader = try String(contentsOffile: path,enCoding: NSUTF8StringEnCoding) shaders[SCNShaderModifIErEntryPointlightingModel] = celShader}catch let error as NSError{ error.description}scene.rootNode.enumerateChildNodesUsingBlock({ (node,stop) -> VoID in node.geometry?.firstMaterial?.shaderModifIErs = shaders})
这是在测试场景上运行的,其中包含从.scn文件加载的单个框几何体.文件加载工作正常,这不是一个问题.
错误来自我尝试找到路径的第二行,它给了我“在展开可选值时找到nil”,这可以通过强制解包来预期,除了它试图加载的文件最多的事实当然在捆绑包中,相同的代码与其他文件类型一起正常工作,而不是.Metal.
我完全错误地采取了这种方式吗?我无法理解为什么它不会访问该文件,而不是我滥用金属文件的问题.
是否有更简单或更好的方法来实现单元格着色并最终在边缘上使用粗体轮廓?
解决方法 AAPLCelShader.Metal是一个完整的顶点/ rastex /片段实现,它不是shaderModifIErs的源代码:将被注入已完成着色器的源代码.相反,您可以使用AAPLCelShader.Metal中的顶点和片段函数创建SCNProgram.与GLSL相比,Metal的优点在于您可以使用names of Metal functions而不是源代码字符串,这更容易使用,并且导致在运行时编译函数,而GLSL不支持这些函数. (这仍然不如它应该是那样好,Swift会将Metal函数识别为正确类型,可重构,命名空间的闭包.)当然,虽然GLSL SCNPrograms将转换为Metal,但对于兼容硬件,Metal SCNPrograms不会被翻译为过时的设备.
至于从SceneKit到rastex(错误命名的colorInOut)成员的映射:
float4 position [[position]];float shine;float3 normal_cameraspace;float3 eye_direction_cameraspace;float3 light_direction_cameraspace;
……遗憾的是,我还没有找到答案.
总结以上是内存溢出为你收集整理的swift – 在SceneKit中使用Metal着色器全部内容,希望文章能够帮你解决swift – 在SceneKit中使用Metal着色器所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)