UAT_tree.py 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661
  1. # -*- coding:utf-8 -*-
  2. import os, sys, time,json
  3. from collections import OrderedDict
  4. from ssat_sdk.utils.string_util import strToList
  5. from UAT_log import error,info,debug
  6. DEBUG = True
  7. INFO = True
  8. ERROR = True
  9. class FirstLevel():
  10. ParentCol = 0
  11. ShortCutKeyCol = ParentCol + 1
  12. UIViewCol = ParentCol + 2
  13. MoveKeyCol = ParentCol + 3
  14. ToParentKeyCol = ParentCol + 4
  15. LayoutCol = ParentCol + 5
  16. OptionCol = ParentCol + 6
  17. OptionViewCol = ParentCol + 7
  18. FocusSelectCol = ParentCol + 8
  19. FocuseViewCol = ParentCol + 9
  20. EnterKeyCol = ParentCol + 10
  21. TextValueCol = ParentCol + 11
  22. InfoViewCol = ParentCol + 12
  23. OthersCol = ParentCol + 13
  24. class NLevel():
  25. ParentCol = 0
  26. UIViewCol = ParentCol + 1
  27. MoveKeyCol = ParentCol + 2
  28. ToParentKeyCol = ParentCol + 3
  29. LayoutCol = ParentCol + 4
  30. OptionCol = ParentCol + 5
  31. OptionViewCol = ParentCol + 6
  32. FocusSelectCol = ParentCol + 7
  33. FocuseViewCol = ParentCol + 8
  34. EnterKeyCol = ParentCol + 9
  35. TextValueCol = ParentCol + 10
  36. InfoViewCol = ParentCol + 11
  37. OthersCol = ParentCol + 12
  38. class DialogLevel():
  39. DialogCol = 0
  40. UIViewCol = DialogCol + 1
  41. MoveKeyCol = DialogCol + 2
  42. ToParentKeyCol = DialogCol + 3
  43. LayoutCol = DialogCol + 4
  44. OptionCol = DialogCol + 5
  45. OptionViewCol = DialogCol + 6
  46. FocusSelectCol = DialogCol + 7
  47. FocuseViewCol = DialogCol + 8
  48. EnterKeyCol = DialogCol + 9
  49. TextValueCol = DialogCol + 10
  50. InfoViewCol = DialogCol + 11
  51. OthersCol = DialogCol + 12
  52. FirstPrev = "first-prev"
  53. class UATTree():
  54. TAB_NAME = "name"
  55. TAB_SHORTCUT_KEY = "shortcut_key"
  56. TAB_UI_VIEW = "uiview"
  57. TAB_MOVE_KEY = "move_key"
  58. TAB_TOPARENT_KEY = "toparent_key"
  59. TAB_LAYOUT = "layout"
  60. TAB_OPTION = "option"
  61. TAB_LEVEL = "level"
  62. TAB_PREV_PARENT = "prev_parent"
  63. TAB_NEXT_PARENT = "next_parent"
  64. TAB_OPTION_VIEW = "optionView"
  65. TAB_FOCUS_SELECT = "focus-select"
  66. TAB_FOCUSE_VIEW = "focuseView"
  67. TAB_TEXT_VALUE = "textValue"
  68. TAB_ENTER_KEY = "enter_key"
  69. TAB_PARENT_NAME = "parentName"
  70. TAB_INFO_VIEW = "infoView"
  71. TAB_OTHERS = "others"
  72. def __init__(self):
  73. self.treeDict = OrderedDict()
  74. self.dialogDict = OrderedDict()
  75. self.cls = "UATTree"
  76. '''
  77. char为该项参数的括符符号,必须成对带入。默认为中括号[]
  78. '''
  79. #将数据从excel表格里取出来,只返回括号里面的内容
  80. def parseParam(self, key, params, char = "[]"):
  81. # 为防止key在其他地方存在相同关键字,添加一个"["做区别
  82. key1 = key + char[0]
  83. keyIndex = params.find(key1)
  84. if keyIndex == -1:
  85. return ""
  86. # key.__len__()-1 为去掉"["的处理
  87. str1 = params[keyIndex + key1.__len__()-1:params.__len__()]
  88. i1 = str1.find(char[0])
  89. if key == self.View_Bounds or key == self.View_sambounds:
  90. i2 = str1.find("]]")+1
  91. else:
  92. i2 = str1.find(char[1])
  93. if i1 == -1 or i2 == -1:
  94. return ""
  95. str2 = str1[i1 + 1: i2]
  96. return str2.strip()
  97. def findAllParam(self, key, params,seg="[]"):
  98. paramArr = []
  99. # for i in range(2):
  100. while True:
  101. keyIndex = params.find(key)
  102. if keyIndex == -1:
  103. break
  104. endIndex = params.find(seg[1])
  105. oneParam = params[keyIndex+key.__len__()+1:endIndex]
  106. params = params[endIndex+1:]
  107. paramArr.append(oneParam)
  108. return paramArr
  109. '''
  110. 返回:{key:value,key2:value2,...}
  111. '''
  112. def parseMulParam(self, keyList, params):
  113. paramDict = {}
  114. for key in keyList:
  115. if key == 'text':
  116. value = self.parseMulText(params)
  117. else:
  118. value = self.parseParam(key, params)
  119. paramDict[key] = value
  120. return paramDict
  121. '''
  122. 例如:enter_key,event[]ir[]同时存在多个
  123. 返回:[[key,value],[key,value],...]
  124. '''
  125. def parseMulParam_Same(self, keyList, params):
  126. mulParam=[]
  127. for key in keyList:
  128. paramArr = self.findAllParam(key, params)
  129. for param in paramArr:
  130. keyItem = [key]
  131. keyItem.append(param)
  132. mulParam.append(keyItem)
  133. return mulParam
  134. #KeyDict数据
  135. Key_AM = "am" #android am命令
  136. Key_Event = "event" #android KeyEvent
  137. Key_IR = "ir" #红外按键
  138. Key_Input = "input" #Android input命令
  139. Max_Try = "max_try"
  140. #根据key的字符串,解析出key的字典。格式:am[]event[]ir[]组合
  141. '''
  142. 用于解析move key参数
  143. '''
  144. def parseKey(self, keyStr):
  145. keyList = [self.Key_AM, self.Key_Event, self.Key_IR, self.Key_Input, self.Max_Try]
  146. keyDict = self.parseMulParam(keyList, keyStr)
  147. keyDict[self.Key_Event] = strToList(keyDict[self.Key_Event], ",")
  148. keyDict[self.Key_IR] = strToList(keyDict[self.Key_IR], ",")
  149. return keyDict
  150. '''
  151. 不考虑按键种类,解析按键名、等待时间等参数,enter,wait=1,enterParent=hdmi_settings
  152. 返回结果:{"keyvalue":[left,right,enter],"wait":'1',"times":"1"}
  153. '''
  154. def parseKeyParam(self, keyParamStr):
  155. paramDict = {self.Key_Value:[],self.Wait_Time:'0', self.Key_Times:'1', self.Duration_Time:'1'}
  156. paramArr = strToList(keyParamStr,",")
  157. keyValue=[]
  158. for param in paramArr:
  159. if "=" not in param:
  160. keyValue.append(param.strip())
  161. else:
  162. pArr = strToList(param,"=")
  163. paramDict[pArr[0].strip().lower()] = pArr[1].strip()
  164. paramDict[self.Key_Value] = keyValue
  165. return paramDict
  166. # enterKeyDict数据
  167. Wait_Time = "wait"
  168. Duration_Time = "duration"
  169. Enter_Parent = "enterparent"
  170. Key_Value = "keyvalue"
  171. Key_Type = "keytype"
  172. Key_Param = "key_param"
  173. Key_Times = "times"
  174. # 根据key的字符串,解析出key的字典。格式:am[]event[]ir[]组合
  175. '''
  176. 返回值:[{"enterParent":"","key_param":{"keyType","event","keyvalue":[left,right,enter],"wait":1,"enterParent":"hdmi_settings"}}
  177. ,...]
  178. '''
  179. def parseEnterKey(self, keyStr, optionName):
  180. keyList = [self.Key_Event, self.Key_IR, self.Key_Input]
  181. keyArr = self.parseMulParam_Same(keyList, keyStr)
  182. retArr = []
  183. for keyItem in keyArr:
  184. nextPDict = {} #{"enterParent":"","key_param":{"keyType","event","keyvalue":[left,right,enter],"wait":1,"enterParent":"hdmi_settings"}}
  185. keyParamDict = self.parseKeyParam(keyItem[1])
  186. keyParamDict[self.Key_Type] = keyItem[0]
  187. nextPDict[self.Key_Param] = keyParamDict
  188. keyParamDict[self.Wait_Time] = float(keyParamDict[self.Wait_Time])
  189. keyParamDict[self.Duration_Time] = float(keyParamDict[self.Duration_Time])
  190. keyParamDict[self.Key_Times] = int(keyParamDict[self.Key_Times])
  191. if keyParamDict.has_key(self.Enter_Parent) is False:
  192. keyParamDict[self.Enter_Parent] = optionName
  193. nextPDict[self.Enter_Parent] = keyParamDict[self.Enter_Parent]
  194. retArr.append(nextPDict)
  195. return retArr
  196. #Android View数据
  197. View_ID = "resid" #android view resource-id
  198. View_Text = "text" #android view 文本内容。 用于焦点定位,文本组件坐标被焦点组件坐标包含
  199. View_Desc = "desc" #android view描述
  200. View_Bounds = "bounds" #android view 坐标
  201. View_Index = "index"
  202. View_Class = "class"
  203. '''
  204. 主要用于infoView数据解析
  205. '''
  206. def parseView(self, viewStr):
  207. keyList = [self.View_ID, self.View_Text, self.View_Desc, self.View_Bounds, self.View_Index, self.View_Class]
  208. paramDict = self.parseMulParam(keyList, viewStr)
  209. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  210. return paramDict
  211. '''
  212. 将‘[801,116][1280,180]’转成数组[[801,116][1280,180]]
  213. '''
  214. def strToBounds(self, bstr):
  215. char = "[]"
  216. # print "strToBounds,bstr:", bstr,bstr.__len__()
  217. if bstr.__len__() < 10:
  218. return []
  219. keyIndex = 1
  220. # key.__len__()-1 为去掉"["的处理
  221. i1 = bstr.find(char[0])
  222. i2 = bstr.find(char[1])
  223. if i1 == -1 or i2 == -1:
  224. return []
  225. str1 = bstr[i1: i2 + 1]
  226. str2 = bstr[i2 + 1: bstr.__len__()]
  227. return [eval(str1), eval(str2)]
  228. '''
  229. 解析多文本option,更改key亦可作为其他参数
  230. '''
  231. def parseMulText(self,params, char="[]",key = 'text'):
  232. key1 = key + char[0] + char[0]
  233. keyIndex = params.find(key1)
  234. if keyIndex == -1:
  235. text = self.parseParam(key, params) # 只有一层中括号
  236. else:
  237. text = []
  238. str1 = params[keyIndex + key1.__len__() - 1:len(params)]
  239. i1 = str1.find(char[0])
  240. i2 = str1.find((char[1] + char[1]))
  241. if i1 == -1 or i2 == -1:
  242. return ""
  243. str2 = str1[i1:i2 + 1] # 只去掉外括号
  244. strList = strToList(str2, char[1] + "," + char[0])
  245. for strs in strList:
  246. text.append(strs.strip(char[0]).strip(char[1]))
  247. return text
  248. View_sambounds = "sambounds" #采样时的样本坐标,用于和select-focus、focusView的坐标做相对比较,计算相对位置,用于确定是否被选中。
  249. '''
  250. 用于optionView的数据解析
  251. '''
  252. def parseOptionView(self, viewStr):
  253. keyList = [self.View_ID, self.View_Text, self.View_Desc, self.View_Bounds, self.View_Index, self.View_Class
  254. ,self.View_sambounds]
  255. paramDict = self.parseMulParam(keyList, viewStr)
  256. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  257. paramDict[self.View_sambounds] = self.strToBounds(paramDict[self.View_sambounds])
  258. return paramDict
  259. # UI 界面数据
  260. UIView_Activity = "activity" # android activity
  261. UIVIew_Action = "action"
  262. UIView_ID = "resid" # android view resource-id
  263. UIView_Text = "text" # android view 文本内容
  264. UIView_Desc = "desc" # android view描述
  265. UIView_Bounds = "bounds" # android view 坐标
  266. UIView_Dialog_F = "dialog_forward" # 进入时可能出现的弹窗
  267. UIView_Dialog_B = "dialog_back" # 退出时可能出现的弹窗
  268. def parseUIView(self, viewStr):
  269. keyList = [self.UIView_Activity, self.UIVIew_Action, self.UIView_ID, self.UIView_Text, self.UIView_Desc,
  270. self.UIView_Bounds, self.UIView_Dialog_F, self.UIView_Dialog_B]
  271. uiView = self.parseMulParam(keyList, viewStr)
  272. return self.parseDialogParam(uiView)
  273. def parseDialogParam(self, uiView):
  274. dialog_F_List = strToList(uiView[self.UIView_Dialog_F], ",")
  275. dialog_B_List = strToList(uiView[self.UIView_Dialog_B], ",")
  276. self.addDialogList(dialog_F_List, uiView, True)
  277. self.addDialogList(dialog_B_List, uiView, False)
  278. return uiView
  279. def addDialogList(self, dialog_List, uiView, isForward):
  280. for dialog in dialog_List:
  281. dialog_A = strToList(dialog.lower(), "&")
  282. if dialog_A.__len__() == 2:
  283. dialog_Name = dialog_A[0]
  284. dialog_Choose = dialog_A[1]
  285. else:
  286. error(str(self.__class__), "parseDialogParam", "Dialog %s set error"%dialog, ERROR)
  287. return
  288. if self.dialogDict.has_key(dialog_Name):
  289. if isForward is True:
  290. dialog_Type = self.UIView_Dialog_F
  291. else:
  292. dialog_Type = self.UIView_Dialog_B
  293. uiView[dialog_Type] = {}
  294. uiView[dialog_Type][dialog_Name] = self.dialogDict[dialog_Name]
  295. uiView[dialog_Type][dialog_Name]["choose"] = self.dialogDict[dialog_Name][UATTree.TAB_OPTION][dialog_Choose]
  296. else:
  297. error(str(self.__class__), "parseDialogParam", "Dialog %s read fail"%dialog_Name, ERROR)
  298. # Android Layout数据
  299. Layout_ID = "resid" # android view resource-id
  300. Layout_Desc = "desc" # android view描述
  301. Layout_Bounds = "bounds" # android view 坐标
  302. Layout_Class = "class" #android view class类型
  303. Layout_Limit = "limit" #layout是否限制optionView焦点操作范围。0:不限制,1:限制,默认为0
  304. '''
  305. layout:各属性值,用于综合确定一个布局组件
  306. :return layout 字典:{"resid":"","desc":"","bounds":""}
  307. '''
  308. def parseLayout(self, viewStr):
  309. keyList = [self.Layout_ID, self.Layout_Desc, self.Layout_Bounds, self.Layout_Class, self.Layout_Limit]
  310. paramDict = self.parseMulParam(keyList, viewStr)
  311. if paramDict.has_key(self.Layout_Limit) and paramDict[self.Layout_Limit].__len__()>0:
  312. paramDict[self.Layout_Limit] = int(paramDict[self.Layout_Limit]) #字符'0'转数字0
  313. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  314. return paramDict
  315. #Android FocusView数据
  316. Focus_ID = "resid" #android view resource-id
  317. Focus_Text = "text" #android view 文本内容
  318. Focus_Desc = "desc" #android view描述
  319. View_Bounds = "bounds" #android view 坐标
  320. View_Class = "class"
  321. def parseFocus(self, viewStr):
  322. keyList = [self.Focus_ID, self.Focus_Text, self.Focus_Desc, self.View_Bounds, self.View_Class,
  323. self.View_sambounds]
  324. paramDict = self.parseMulParam(keyList, viewStr)
  325. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  326. paramDict[self.View_sambounds] = self.strToBounds(paramDict[self.View_sambounds])
  327. return paramDict
  328. #Value数据
  329. ValueView_ID = "resid" #android view resource-id
  330. ValueView_Text = "text" #android view 文本内容
  331. ValueView_Desc = "desc" #android view描述
  332. ValueView_Bounds = "bounds"
  333. ValueView_Class = "class"
  334. ValueView_Value = "value" # 输入的值范围。格式:first, second, ... 或者 0-100
  335. ValueView_Min = "minvalue" # 如果是数值范围形式的值,返回最小值
  336. ValueView_Max = "maxvalue" # 如果是数值范围形式的值,返回最小值
  337. ValueView_StepSize = "stepsize" # 如果是数值范围形式的值,每次调整数值的步长。读不到此参数时,默认为1。
  338. ValueView_Duration = "duration" # 如果是数值范围形式的值,每次调整数值的间隔时间。读不到此参数时,默认为0.2。
  339. ValueView_Sign = "sign" # 针对前缀为字母,后缀为数字形式的值,用来保存前缀
  340. def parseValueView(self, viewStr):
  341. keyList = [self.ValueView_ID, self.ValueView_Text, self.ValueView_Desc, self.ValueView_Value,
  342. self.ValueView_StepSize, self.ValueView_Duration, self.ValueView_Bounds, self.ValueView_Class,
  343. self.View_sambounds]
  344. paramDict = self.parseMulParam(keyList, viewStr)
  345. valueStr = paramDict[self.ValueView_Value]
  346. sign = []
  347. valueListDelStr = []
  348. flagList = []
  349. flag_v = False # value前缀不为字母
  350. if valueStr != "":
  351. i = valueStr.find(",")
  352. if i != -1:
  353. valueList = strToList(valueStr, ",")
  354. isRange = False
  355. # 前缀字母,后缀数字
  356. for val in valueList:
  357. if (ord(val[0])>57 or ord(val[0])<48) and (47 < ord(val[1]) < 58):
  358. sign.append(val[0])
  359. valueDelStr = val.strip(val[0])
  360. valueListDelStr.append(valueDelStr)
  361. flagList.append(True) #value前缀为字母
  362. else:
  363. flagList.append(False)
  364. for f in flagList:
  365. flag_v = f
  366. flag_v = flag_v and f
  367. if flag_v == False:
  368. sign = []
  369. # 处理range类型(数值)
  370. try:
  371. if valueList.__len__() == 2:
  372. if flag_v == True: #//
  373. valueList = valueListDelStr
  374. paramDict[self.ValueView_Min] = -float(valueList[0])#//
  375. else:
  376. paramDict[self.ValueView_Min] = float(valueList[0])
  377. paramDict[self.ValueView_Max] = float(valueList[1])
  378. isRange = True
  379. except Exception,ValueError:
  380. info(self.cls, "parseValueView", "valueList %s not range value.", INFO)
  381. # 处理非range类型(选项)
  382. if isRange is False:
  383. for value in valueList:
  384. valueViewStr = self.parseParam(value, viewStr, "{}")
  385. if valueViewStr == "":
  386. debug(self.cls, "parseValueView", "value %s 没有任何配置信息!!!请加入该value信息,否则可能将导致设值失败!!!"%value, DEBUG)
  387. # 读出来的数值未带大括号,需加上大括号,并且json格式化
  388. valueView = eval("{%s}" % valueViewStr)
  389. paramDict[value] = valueView
  390. paramDict[self.ValueView_Sign] = sign
  391. return paramDict
  392. #focus-select数据,不仅有select或者focus类型,还有指定组件属性情况,用于处理界面多个聚焦方式出现的场景
  393. FS_Type = "type"
  394. FS_ID = "resid" #android view resource-id
  395. FS_Text = "text" #android view 文本内容。
  396. FS_Desc = "desc" #android view描述
  397. FS_Bounds = "bounds" #android view 坐标
  398. FS_Class = "class"
  399. def parseFocusSelectType(self, fsType):
  400. keyList = [self.FS_Type,self.FS_ID,self.FS_Text,self.FS_Desc,self.FS_Bounds,
  401. self.View_sambounds,self.FS_Class]
  402. paramDict = self.parseMulParam(keyList, fsType)
  403. paramDict[self.View_sambounds] = self.strToBounds(paramDict[self.View_sambounds])
  404. return paramDict
  405. '''
  406. 扫描parent数据行时,要把建立当前parent的prevParent和nextParent关系。
  407. '''
  408. def addParent(self,level, parentName, shortkey, uiview, move_key, toparent_key, layout, others):
  409. # print "addParent, level,parentName:", level, parentName
  410. if not self.treeDict.has_key(level):
  411. self.treeDict[level] = {}
  412. parentDict = {}
  413. parentDict[UATTree.TAB_NAME] = parentName
  414. parentDict[UATTree.TAB_SHORTCUT_KEY] = self.parseKey(shortkey)
  415. parentDict[UATTree.TAB_UI_VIEW] = self.parseUIView(uiview)
  416. parentDict[UATTree.TAB_MOVE_KEY] = self.parseKey(move_key)
  417. parentDict[UATTree.TAB_TOPARENT_KEY] = self.parseKey(toparent_key)
  418. parentDict[UATTree.TAB_LAYOUT] = self.parseLayout(layout)
  419. parentDict[UATTree.TAB_OPTION] = {}
  420. parentDict[UATTree.TAB_LEVEL] = level
  421. parentDict[UATTree.TAB_PREV_PARENT] = None
  422. parentDict[UATTree.TAB_NEXT_PARENT] = {}
  423. parentDict[UATTree.TAB_OTHERS] = self.parseOthers(others)
  424. if "first" <> level:
  425. prevParent = self.getPreParentByParent(parentDict)
  426. if prevParent is not None:
  427. parentDict[UATTree.TAB_PREV_PARENT] = prevParent
  428. prevParent[UATTree.TAB_NEXT_PARENT][parentName] = parentDict
  429. self.treeDict[level][parentName] = parentDict
  430. '''
  431. 扫描option行的时候,会把option字典关联到相应的parent字典里
  432. '''
  433. def addOption(self, level, parentName, optionName, optionView, focusSelect, focusView, enterKey, textValue, infoView):
  434. # print "addOption, level,parentName,optionName:", level, parentName,optionName
  435. if self.treeDict.has_key(level) and self.treeDict[level].has_key(parentName):
  436. optionDict = {}
  437. optionDict[UATTree.TAB_NAME] = optionName
  438. optionDict[UATTree.TAB_OPTION_VIEW] = self.parseOptionView(optionView)
  439. optionDict[UATTree.TAB_FOCUS_SELECT] = self.parseFocusSelectType(focusSelect)
  440. optionDict[UATTree.TAB_FOCUSE_VIEW] = self.parseFocus(focusView)
  441. optionDict[UATTree.TAB_ENTER_KEY] = self.parseEnterKey(enterKey, optionName)
  442. optionDict[UATTree.TAB_TEXT_VALUE] = self.parseValueView(textValue)
  443. optionDict[UATTree.TAB_INFO_VIEW] = self.parseView(infoView)
  444. optionDict[UATTree.TAB_PARENT_NAME] = parentName
  445. optionDict[UATTree.TAB_LEVEL] = level
  446. self.treeDict[level][parentName][UATTree.TAB_OPTION][optionName] = optionDict
  447. def addDialog(self, parentName, shortkey, uiview, move_key, toparent_key, layout, others):
  448. # print "addDialog, parentName:", parentName
  449. parentDict = {}
  450. parentDict[UATTree.TAB_NAME] = parentName
  451. parentDict[UATTree.TAB_SHORTCUT_KEY] = self.parseKey(shortkey)
  452. parentDict[UATTree.TAB_UI_VIEW] = self.parseUIView(uiview)
  453. parentDict[UATTree.TAB_MOVE_KEY] = self.parseKey(move_key)
  454. parentDict[UATTree.TAB_TOPARENT_KEY] = self.parseKey(toparent_key)
  455. parentDict[UATTree.TAB_LAYOUT] = self.parseLayout(layout)
  456. parentDict[UATTree.TAB_OPTION] = {}
  457. parentDict[UATTree.TAB_OTHERS] = self.parseDialogOthers(others)
  458. self.dialogDict[parentName] = parentDict
  459. def addDialogOption(self, parentName, optionName, optionView, focusSelect, focusView, enterKey, textValue, infoView):
  460. # print "addDialogOption, parentName,optionName:", parentName, optionName
  461. if self.dialogDict.has_key(parentName):
  462. optionDict = {}
  463. optionDict[UATTree.TAB_NAME] = optionName
  464. optionDict[UATTree.TAB_OPTION_VIEW] = self.parseOptionView(optionView)
  465. optionDict[UATTree.TAB_FOCUS_SELECT] = self.parseFocusSelectType(focusSelect)
  466. optionDict[UATTree.TAB_FOCUSE_VIEW] = self.parseFocus(focusView)
  467. optionDict[UATTree.TAB_ENTER_KEY] = self.parseEnterKey(enterKey,optionName)
  468. optionDict[UATTree.TAB_TEXT_VALUE] = self.parseValueView(textValue)
  469. optionDict[UATTree.TAB_INFO_VIEW] = self.parseView(infoView)
  470. optionDict[UATTree.TAB_PARENT_NAME] = parentName
  471. self.dialogDict[parentName][UATTree.TAB_OPTION][optionName] = optionDict
  472. def findParentDict(self, parentName):
  473. parentName = parentName.lower()
  474. levelList = self.treeDict.keys()
  475. for index in range(levelList.__len__()-1, -1, -1):
  476. level = levelList[index]
  477. if self.treeDict[level].has_key(parentName):
  478. return self.treeDict[level][parentName]
  479. return None
  480. def getSubOptionDict(self, parentName):
  481. parentDict = self.findParentDict(parentName)
  482. if parentDict is not None:
  483. return parentDict[UATTree.TAB_OPTION]
  484. return None
  485. def findOption(self, optionName):
  486. optionName = optionName.lower()
  487. levelList = self.treeDict.keys()
  488. for index in range(levelList.__len__()-1, -1, -1):
  489. level = levelList[index]
  490. levelDict = self.treeDict[level]
  491. for parent in levelDict.keys():
  492. parentDict = levelDict[parent]
  493. for option in parentDict.keys():
  494. optionDict = parentDict[UATTree.TAB_OPTION]
  495. if optionDict.has_key(optionName):
  496. return optionDict[optionName]
  497. def getOpitonInLevel(self,targetOptionName, level):
  498. levelDict = self.treeDict[level]
  499. for parentName in levelDict.keys():
  500. parentDict = levelDict[parentName]
  501. for optionName in parentDict[UATTree.TAB_OPTION].keys():
  502. if targetOptionName == optionName:
  503. return parentDict[UATTree.TAB_OPTION][optionName]
  504. else:
  505. return None
  506. '''
  507. 检测option的enter_key中是否存在对应parentName
  508. '''
  509. def checkEnterParentEK(self, enterKey, parentName):
  510. # print "checkEnterParentEK,enterKey,parentName:",enterKey, parentName
  511. for keyItem in enterKey:
  512. if keyItem[self.Enter_Parent] == parentName:
  513. return True
  514. return False
  515. '''
  516. 检测option字典,是否下一级nextParent包含这一个parentName
  517. '''
  518. def checkOptionEnterParent(self, option, parentName):
  519. enterKey = option[self.TAB_ENTER_KEY]
  520. if option[self.TAB_NAME] == parentName:
  521. return True
  522. return self.checkEnterParentEK(enterKey, parentName)
  523. '''
  524. 根据parentName,在EnterKey所有列表中,找到匹配的enterKey字典选项
  525. 返回值:{"enterParent":"","key_param":{"keyType","event","keyvalue":[left,right,enter],"wait":1,"enterParent":"hdmi_settings"}
  526. '''
  527. def getEKByParent(self, enterKeys, parentName):
  528. for keyItem in enterKeys:
  529. if keyItem[self.Enter_Parent] == parentName:
  530. return keyItem[self.Key_Param]
  531. return None
  532. '''
  533. 获取option的parent
  534. '''
  535. def getParentByOption(self, option):
  536. parentName = option[UATTree.TAB_PARENT_NAME]
  537. levelName = option[UATTree.TAB_LEVEL]
  538. if self.treeDict[levelName].has_key(parentName):
  539. parent = self.treeDict[levelName][parentName]
  540. return parent
  541. else:
  542. return None
  543. '''
  544. 根据Parent数据,查上一级parent。
  545. '''
  546. def getPreParentByParent(self, parent):
  547. prevLevel = self.getPrevLevel(parent[self.TAB_LEVEL])
  548. levelDict = self.treeDict[prevLevel]
  549. # print "getPreParentByParent,levelDict:",levelDict
  550. for parentName in levelDict.keys():
  551. parentDict = levelDict[parentName]
  552. # print "getPreParentByParent,parentDict:", parentDict
  553. for optionName in parentDict[UATTree.TAB_OPTION].keys():
  554. option = parentDict[UATTree.TAB_OPTION][optionName]
  555. # print "getPreParentByParent,option:", option
  556. if self.checkOptionEnterParent(option, parent[self.TAB_NAME]):
  557. return parentDict
  558. error(str(self.__class__), "getPreParentByParent",
  559. "Parent %s's prevparent not found in level %s"%(parent[self.TAB_NAME], prevLevel), ERROR)
  560. return None
  561. '''
  562. 获取当前level的前一个level名
  563. '''
  564. def getPrevLevel(self, level):
  565. self.levelList = self.treeDict.keys()
  566. index = self.levelList.index(level)
  567. if index == 0:
  568. return FirstPrev
  569. else:
  570. return self.levelList[index-1]
  571. '''
  572. 获取当前Parent的上一级parent
  573. '''
  574. def getPrevParent(self, parent):
  575. return parent[UATTree.TAB_PREV_PARENT]
  576. '''
  577. 获取当前parent下一级所有parent的字典
  578. '''
  579. def getNextParentList(self, parent):
  580. return parent[UATTree.TAB_NEXT_PARENT]
  581. def printTree(self):
  582. for level in self.treeDict.keys():
  583. print level
  584. for parent in self.treeDict[level].keys():
  585. dict1 = self.treeDict[level][parent]
  586. print level, "::parent ", dict1["name"], "name", "shortcut_key", "uiview", "move_key", "toparent_key", "layout"
  587. print level, "::parent ", dict1["name"], dict1["shortcut_key"], dict1["uiview"], dict1["move_key"], dict1["toparent_key"], dict1["layout"]
  588. for option in dict1["option"].keys():
  589. dict2 = dict1["option"][option]
  590. print level, "::option ", dict2
  591. Key_HeartBeat = "heartbeat_key"
  592. def parseOthers(self, othersStr):
  593. othersDict = {}
  594. othersDict[self.Key_HeartBeat] = self.parseParam(self.Key_HeartBeat, othersStr, char="{}")
  595. hb_keyDict = {}
  596. if othersDict[self.Key_HeartBeat] != "":
  597. print "Key_HeartBeat_Str:",othersDict[self.Key_HeartBeat]
  598. hb_keyDict = self.parseHeartBeatKey(othersDict[self.Key_HeartBeat])
  599. othersDict[self.Key_HeartBeat] = hb_keyDict
  600. return othersDict
  601. def parseHeartBeatKey(self, hb_keyStr):
  602. keyList = [self.Key_Event, self.Key_IR]
  603. keyDict = self.parseMulParam(keyList, hb_keyStr)
  604. keyDict[self.Key_Event] = strToList(keyDict[self.Key_Event], ",")
  605. keyDict[self.Key_IR] = strToList(keyDict[self.Key_IR], ",")
  606. return keyDict
  607. def parseDialogOthers(self, othersStr):
  608. othersDict = {}
  609. othersDict[self.Key_HeartBeat] = self.parseParam(self.Key_HeartBeat, othersStr, char="{}")
  610. hb_keyDict = {}
  611. if othersDict[self.Key_HeartBeat] != "":
  612. print "Key_HeartBeat_Str:",othersDict[self.Key_HeartBeat]
  613. hb_keyDict = self.parseHeartBeatKey(othersDict[self.Key_HeartBeat])
  614. othersDict[self.Key_HeartBeat] = hb_keyDict
  615. return othersDict
  616. if __name__ == '__main__':
  617. uatTree = UATTree()