Titanium iOS 13暗模式在使用Tianium classic框架时不起作用

Titanium iOS 13暗模式在使用Tianium classic框架时不起作用,titanium,titanium-mobile,appcelerator-titanium,Titanium,Titanium Mobile,Appcelerator Titanium,我正在尝试在iOS 13及以上版本的应用程序中实现暗模式主题。我跟踪了这个链接。但我面临一些问题。我在下面附上了示例代码。我期待,如果我改变启用黑暗的外观,那么它应该改变窗口的颜色根据语义颜色文件 var deviceDetect = require('./deviceDetect'); var dialog = require('./dialogueBox'); var currentStyle = deviceDetect.isIos() ? Ti.App.iOS.userInterfac

我正在尝试在iOS 13及以上版本的应用程序中实现暗模式主题。我跟踪了这个链接。但我面临一些问题。我在下面附上了示例代码。我期待,如果我改变启用黑暗的外观,那么它应该改变窗口的颜色根据语义颜色文件

var deviceDetect = require('./deviceDetect');
var dialog = require('./dialogueBox');

var currentStyle = deviceDetect.isIos() ? Ti.App.iOS.userInterfaceStyle : undefined;
var colorWindow = Ti.UI.fetchSemanticColor("backgroundColor");

var win = Ti.UI.createWindow({
    title: 'Demo App',
    backgroundColor: colorWindow,
    layout: 'vertical'
});

var top = Ti.UI.createView({
    backgroundColor: 'red',
    layout: 'horizontal',
    height: Ti.UI.SIZE,
    width: Ti.UI.FILL,
    top: deviceDetect.isAndroid() ? 0 : '50%'
});

var view = Ti.UI.createView({
    center: { x: 205, y: 250 },
    height: 400,
    width: 300,
    backgroundColor: colorWindow,
    layout: 'vertical',
    top: '20%'
});
var img = Titanium.UI.createImageView({
    center: { x: 150, y: 110 },
    image: './logo.png',
    width: Ti.UI.SIZE,
    height: Ti.UI.SIZE
});
view.add(img);

var emailField = Ti.UI.createTextField({
    width: Ti.UI.FILL,
    height: 30,
    top: 30,
    left: 10,
    right: 10,
    borderStyle: Ti.UI.INPUT_BORDERSTYLE_ROUNDED,
    returnKeyType: Ti.UI.RETURNKEY_DONE
});

var passField = Ti.UI.createTextField({
    width: Ti.UI.FILL,
    height: 30,
    top: 10,
    left: 10,
    right: 10,
    borderStyle: Ti.UI.INPUT_BORDERSTYLE_ROUNDED,
    returnKeyType: Ti.UI.RETURNKEY_DONE
});

view.add(emailField);
view.add(passField);

if (deviceDetect.isIos() && currentStyle === Ti.App.iOS.USER_INTERFACE_STYLE_DARK) {
    // dark mode
    console.log("I am here", colorWindow, colorWindow[Ti.UI.semanticColorType]);
    //win.backgroundColor = 'green';
}

if (deviceDetect.isIos()) {
    Ti.App.iOS.addEventListener('traitcollectionchange', function (event) {
        if (currentStyle !== Ti.App.iOS.userInterfaceStyle) {
            currentStyle = Ti.App.iOS.userInterfaceStyle;
            if (currentStyle == 2) {
                //tfAmount.color = 'white';
                // dark mode
                //win.backgroundColor =  colorWindow;
                //view.backgroundColor =
            } else {
                //win.backgroundColor = '#AAAAFF';
                //view.backgroundColor = '#90EE90';
            }
            //console.log(colorWindow);
            //win.backgroundColor = colorWindow;
            //Ti.API.info('User Interface Style changed: ' + currentStyle);
        }
    });
}

win.add(view);
win.add(top);
win.open();
以下是semantic.colors.json文件内容:

{
 "backgroundColor": {
    "light": "#ffffff",
    "dark": "#000000"
  }
}
提前感谢!!!
如果我遗漏了什么,请告诉我。

我已经精简了示例,只看到了所需的部分,并且运行良好(iOS+Android[我已经使用了9.1.0]):

/app/controllers/index.js

var colorWindow = Ti.UI.fetchSemanticColor("windowBackgroundColor");
var bgColor = Ti.UI.fetchSemanticColor("viewColor");

var win = Ti.UI.createWindow({
    title: 'Demo App',
    backgroundColor: colorWindow
});


var view = Ti.UI.createView({
    height: 300,
    width: 300,
    backgroundColor: bgColor
});


win.add(view);
win.open();
/app/assets/semantic.colors.json

{
  "windowBackgroundColor": {
    "dark": "#666666",
    "light": "#ff0000"
  },
  "viewColor":{
    "dark": "#00ff00",
    "light": "#0000ff"
  }
}
确保使用9.0.3.GA(或更高版本)

它将显示灰色/绿色或红色/蓝色屏幕,具体取决于您的手机设置。在Android上更改黑暗模式时,也要确保关闭窗口