UAT_tree.py 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664
  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. # 即选中状态的坐标,option中组件选中状态下的坐标和focus-select/focusView中组件选中状态下的坐标
  250. # 分别写在optionView和focus-select/focusView中,其实就类似用sambounds做为组件
  251. '''
  252. 用于optionView的数据解析
  253. '''
  254. def parseOptionView(self, viewStr):
  255. keyList = [self.View_ID, self.View_Text, self.View_Desc, self.View_Bounds, self.View_Index, self.View_Class
  256. ,self.View_sambounds]
  257. paramDict = self.parseMulParam(keyList, viewStr)
  258. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  259. paramDict[self.View_sambounds] = self.strToBounds(paramDict[self.View_sambounds])
  260. return paramDict
  261. # UI 界面数据
  262. UIView_Activity = "activity" # android activity
  263. UIVIew_Action = "action"
  264. # UIView_ID = "resid" # android view resource-id
  265. # UIView_Text = "text" # android view 文本内容
  266. # UIView_Desc = "desc" # android view描述
  267. # UIView_Bounds = "bounds" # android view 坐标
  268. UIView_Dialog_F = "dialog_forward" # 进入时可能出现的弹窗
  269. UIView_Dialog_B = "dialog_back" # 退出时可能出现的弹窗
  270. def parseUIView(self, viewStr):
  271. keyList = [self.UIView_Activity, self.UIVIew_Action, self.View_ID, self.View_Text, self.View_Desc,
  272. self.View_Bounds, self.UIView_Dialog_F, self.UIView_Dialog_B]
  273. uiView = self.parseMulParam(keyList, viewStr)
  274. return self.parseDialogParam(uiView)
  275. def parseDialogParam(self, uiView):
  276. dialog_F_List = strToList(uiView[self.UIView_Dialog_F], ",")
  277. dialog_B_List = strToList(uiView[self.UIView_Dialog_B], ",")
  278. self.addDialogList(dialog_F_List, uiView, True)
  279. self.addDialogList(dialog_B_List, uiView, False)
  280. return uiView
  281. def addDialogList(self, dialog_List, uiView, isForward):
  282. for dialog in dialog_List:
  283. dialog_A = strToList(dialog.lower(), "&")
  284. if dialog_A.__len__() == 2:
  285. dialog_Name = dialog_A[0]
  286. dialog_Choose = dialog_A[1]
  287. else:
  288. error(str(self.__class__), "parseDialogParam", "Dialog %s set error"%dialog, ERROR)
  289. return
  290. if self.dialogDict.has_key(dialog_Name):
  291. if isForward is True:
  292. dialog_Type = self.UIView_Dialog_F
  293. else:
  294. dialog_Type = self.UIView_Dialog_B
  295. uiView[dialog_Type] = {}
  296. uiView[dialog_Type][dialog_Name] = self.dialogDict[dialog_Name]
  297. uiView[dialog_Type][dialog_Name]["choose"] = self.dialogDict[dialog_Name][UATTree.TAB_OPTION][dialog_Choose]
  298. else:
  299. error(str(self.__class__), "parseDialogParam", "Dialog %s read fail"%dialog_Name, ERROR)
  300. # Android Layout数据
  301. # Layout_ID = "resid" # android view resource-id
  302. # Layout_Desc = "desc" # android view描述
  303. # Layout_Bounds = "bounds" # android view 坐标
  304. # Layout_Class = "class" #android view class类型
  305. Layout_Limit = "limit" #layout是否限制optionView焦点操作范围。0:不限制,1:限制,默认为0
  306. '''
  307. layout:各属性值,用于综合确定一个布局组件
  308. :return layout 字典:{"resid":"","desc":"","bounds":""}
  309. '''
  310. def parseLayout(self, viewStr):
  311. keyList = [self.View_ID, self.View_Desc, self.View_Bounds, self.View_Class, self.Layout_Limit]
  312. paramDict = self.parseMulParam(keyList, viewStr)
  313. if paramDict.has_key(self.Layout_Limit) and paramDict[self.Layout_Limit].__len__()>0:
  314. paramDict[self.Layout_Limit] = int(paramDict[self.Layout_Limit]) #字符'0'转数字0
  315. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  316. return paramDict
  317. #Android FocusView数据
  318. # Focus_ID = "resid" #android view resource-id
  319. # Focus_Text = "text" #android view 文本内容
  320. # Focus_Desc = "desc" #android view描述
  321. # Focus_Bounds = "bounds" #android view 坐标
  322. # Focus_Class = "class"
  323. def parseFocus(self, viewStr):
  324. keyList = [self.View_ID, self.View_Text, self.View_Desc, self.View_Bounds, self.View_Class,
  325. self.View_sambounds]
  326. paramDict = self.parseMulParam(keyList, viewStr)
  327. paramDict[self.View_Bounds] = self.strToBounds(paramDict[self.View_Bounds])
  328. paramDict[self.View_sambounds] = self.strToBounds(paramDict[self.View_sambounds])
  329. return paramDict
  330. #Value数据
  331. # ValueView_ID = "resid" #android view resource-id
  332. # ValueView_Text = "text" #android view 文本内容
  333. # ValueView_Desc = "desc" #android view描述
  334. # ValueView_Bounds = "bounds"
  335. # ValueView_Class = "class"
  336. ValueView_Value = "value" # 输入的值范围。格式:first, second, ... 或者 0-100
  337. ValueView_Min = "minvalue" # 如果是数值范围形式的值,返回最小值
  338. ValueView_Max = "maxvalue" # 如果是数值范围形式的值,返回最小值
  339. ValueView_StepSize = "stepsize" # 如果是数值范围形式的值,每次调整数值的步长。读不到此参数时,默认为1。
  340. ValueView_Duration = "duration" # 如果是数值范围形式的值,每次调整数值的间隔时间。读不到此参数时,默认为0.2。
  341. ValueView_Sign = "sign" # 针对前缀为字母,后缀为数字形式的值,用来保存前缀
  342. def parseValueView(self, viewStr):
  343. keyList = [self.View_ID, self.View_Text, self.View_Desc, self.ValueView_Value,
  344. self.ValueView_StepSize, self.ValueView_Duration, self.View_Bounds, self.View_Class,
  345. self.View_sambounds]
  346. paramDict = self.parseMulParam(keyList, viewStr)
  347. valueStr = paramDict[self.ValueView_Value]
  348. sign = []
  349. valueListDelStr = []
  350. flagList = []
  351. flag_v = False # value前缀不为字母
  352. if valueStr != "":
  353. i = valueStr.find(",")
  354. if i != -1:
  355. valueList = strToList(valueStr, ",")
  356. isRange = False
  357. # 前缀字母,后缀数字
  358. for val in valueList:
  359. if (ord(val[0])>57 or ord(val[0])<48) and (47 < ord(val[1]) < 58):
  360. sign.append(val[0])
  361. valueDelStr = val.strip(val[0])
  362. valueListDelStr.append(valueDelStr)
  363. flagList.append(True) #value前缀为字母
  364. else:
  365. flagList.append(False)
  366. for f in flagList:
  367. flag_v = f
  368. flag_v = flag_v and f
  369. if flag_v == False:
  370. sign = []
  371. # 处理range类型(数值)
  372. try:
  373. if valueList.__len__() == 2:
  374. if flag_v == True: #//
  375. valueList = valueListDelStr
  376. paramDict[self.ValueView_Min] = -float(valueList[0])#//
  377. else:
  378. paramDict[self.ValueView_Min] = float(valueList[0])
  379. paramDict[self.ValueView_Max] = float(valueList[1])
  380. isRange = True
  381. except Exception,ValueError:
  382. info(self.cls, "parseValueView", "valueList %s not range value.", INFO)
  383. # 处理非range类型(选项)
  384. if isRange is False:
  385. for value in valueList:
  386. valueViewStr = self.parseParam(value, viewStr, "{}")
  387. if valueViewStr == "":
  388. debug(self.cls, "parseValueView", "value %s 没有任何配置信息!!!请加入该value信息,否则可能将导致设值失败!!!"%value, DEBUG)
  389. # 读出来的数值未带大括号,需加上大括号,并且json格式化
  390. valueView = eval("{%s}" % valueViewStr)
  391. paramDict[value] = valueView
  392. paramDict[self.ValueView_Sign] = sign
  393. return paramDict
  394. #focus-select数据,不仅有select或者focus类型,还有指定组件属性情况,用于处理界面多个聚焦方式出现的场景
  395. FS_Type = "type"
  396. FS_checkType = "checkType"
  397. # FS_ID = "resid" #android view resource-id
  398. # FS_Text = "text" #android view 文本内容。
  399. # FS_Desc = "desc" #android view描述
  400. # FS_Bounds = "bounds" #android view 坐标
  401. # FS_Class = "class"
  402. def parseFocusSelectType(self, fsType):
  403. keyList = [self.FS_Type,self.View_ID,self.View_Text,self.View_Desc,self.View_Bounds,
  404. self.View_sambounds,self.View_Class,self.FS_checkType]
  405. paramDict = self.parseMulParam(keyList, fsType)
  406. paramDict[self.View_sambounds] = self.strToBounds(paramDict[self.View_sambounds])
  407. return paramDict
  408. '''
  409. 扫描parent数据行时,要把建立当前parent的prevParent和nextParent关系。
  410. '''
  411. def addParent(self,level, parentName, shortkey, uiview, move_key, toparent_key, layout, others):
  412. # print "addParent, level,parentName:", level, parentName
  413. if not self.treeDict.has_key(level):
  414. self.treeDict[level] = {}
  415. parentDict = {}
  416. parentDict[UATTree.TAB_NAME] = parentName
  417. parentDict[UATTree.TAB_SHORTCUT_KEY] = self.parseKey(shortkey)
  418. parentDict[UATTree.TAB_UI_VIEW] = self.parseUIView(uiview)
  419. parentDict[UATTree.TAB_MOVE_KEY] = self.parseKey(move_key)
  420. parentDict[UATTree.TAB_TOPARENT_KEY] = self.parseKey(toparent_key)
  421. parentDict[UATTree.TAB_LAYOUT] = self.parseLayout(layout)
  422. parentDict[UATTree.TAB_OPTION] = {}
  423. parentDict[UATTree.TAB_LEVEL] = level
  424. parentDict[UATTree.TAB_PREV_PARENT] = None
  425. parentDict[UATTree.TAB_NEXT_PARENT] = {}
  426. parentDict[UATTree.TAB_OTHERS] = self.parseOthers(others)
  427. if "first" <> level:
  428. prevParent = self.getPreParentByParent(parentDict)
  429. if prevParent is not None:
  430. parentDict[UATTree.TAB_PREV_PARENT] = prevParent
  431. prevParent[UATTree.TAB_NEXT_PARENT][parentName] = parentDict
  432. self.treeDict[level][parentName] = parentDict
  433. '''
  434. 扫描option行的时候,会把option字典关联到相应的parent字典里
  435. '''
  436. def addOption(self, level, parentName, optionName, optionView, focusSelect, focusView, enterKey, textValue, infoView):
  437. # print "addOption, level,parentName,optionName:", level, parentName,optionName
  438. if self.treeDict.has_key(level) and self.treeDict[level].has_key(parentName):
  439. optionDict = {}
  440. optionDict[UATTree.TAB_NAME] = optionName
  441. optionDict[UATTree.TAB_OPTION_VIEW] = self.parseOptionView(optionView)
  442. optionDict[UATTree.TAB_FOCUS_SELECT] = self.parseFocusSelectType(focusSelect)
  443. optionDict[UATTree.TAB_FOCUSE_VIEW] = self.parseFocus(focusView)
  444. optionDict[UATTree.TAB_ENTER_KEY] = self.parseEnterKey(enterKey, optionName)
  445. optionDict[UATTree.TAB_TEXT_VALUE] = self.parseValueView(textValue)
  446. optionDict[UATTree.TAB_INFO_VIEW] = self.parseView(infoView)
  447. optionDict[UATTree.TAB_PARENT_NAME] = parentName
  448. optionDict[UATTree.TAB_LEVEL] = level
  449. self.treeDict[level][parentName][UATTree.TAB_OPTION][optionName] = optionDict
  450. def addDialog(self, parentName, shortkey, uiview, move_key, toparent_key, layout, others):
  451. # print "addDialog, parentName:", parentName
  452. parentDict = {}
  453. parentDict[UATTree.TAB_NAME] = parentName
  454. parentDict[UATTree.TAB_SHORTCUT_KEY] = self.parseKey(shortkey)
  455. parentDict[UATTree.TAB_UI_VIEW] = self.parseUIView(uiview)
  456. parentDict[UATTree.TAB_MOVE_KEY] = self.parseKey(move_key)
  457. parentDict[UATTree.TAB_TOPARENT_KEY] = self.parseKey(toparent_key)
  458. parentDict[UATTree.TAB_LAYOUT] = self.parseLayout(layout)
  459. parentDict[UATTree.TAB_OPTION] = {}
  460. parentDict[UATTree.TAB_OTHERS] = self.parseDialogOthers(others)
  461. self.dialogDict[parentName] = parentDict
  462. def addDialogOption(self, parentName, optionName, optionView, focusSelect, focusView, enterKey, textValue, infoView):
  463. # print "addDialogOption, parentName,optionName:", parentName, optionName
  464. if self.dialogDict.has_key(parentName):
  465. optionDict = {}
  466. optionDict[UATTree.TAB_NAME] = optionName
  467. optionDict[UATTree.TAB_OPTION_VIEW] = self.parseOptionView(optionView)
  468. optionDict[UATTree.TAB_FOCUS_SELECT] = self.parseFocusSelectType(focusSelect)
  469. optionDict[UATTree.TAB_FOCUSE_VIEW] = self.parseFocus(focusView)
  470. optionDict[UATTree.TAB_ENTER_KEY] = self.parseEnterKey(enterKey,optionName)
  471. optionDict[UATTree.TAB_TEXT_VALUE] = self.parseValueView(textValue)
  472. optionDict[UATTree.TAB_INFO_VIEW] = self.parseView(infoView)
  473. optionDict[UATTree.TAB_PARENT_NAME] = parentName
  474. self.dialogDict[parentName][UATTree.TAB_OPTION][optionName] = optionDict
  475. def findParentDict(self, parentName):
  476. parentName = parentName.lower()
  477. levelList = self.treeDict.keys()
  478. for index in range(levelList.__len__()-1, -1, -1):
  479. level = levelList[index]
  480. if self.treeDict[level].has_key(parentName):
  481. return self.treeDict[level][parentName]
  482. return None
  483. def getSubOptionDict(self, parentName):
  484. parentDict = self.findParentDict(parentName)
  485. if parentDict is not None:
  486. return parentDict[UATTree.TAB_OPTION]
  487. return None
  488. def findOption(self, optionName):
  489. optionName = optionName.lower()
  490. levelList = self.treeDict.keys()
  491. for index in range(levelList.__len__()-1, -1, -1):
  492. level = levelList[index]
  493. levelDict = self.treeDict[level]
  494. for parent in levelDict.keys():
  495. parentDict = levelDict[parent]
  496. for option in parentDict.keys():
  497. optionDict = parentDict[UATTree.TAB_OPTION]
  498. if optionDict.has_key(optionName):
  499. return optionDict[optionName]
  500. def getOpitonInLevel(self,targetOptionName, level):
  501. levelDict = self.treeDict[level]
  502. for parentName in levelDict.keys():
  503. parentDict = levelDict[parentName]
  504. for optionName in parentDict[UATTree.TAB_OPTION].keys():
  505. if targetOptionName == optionName:
  506. return parentDict[UATTree.TAB_OPTION][optionName]
  507. else:
  508. return None
  509. '''
  510. 检测option的enter_key中是否存在对应parentName
  511. '''
  512. def checkEnterParentEK(self, enterKey, parentName):
  513. # print "checkEnterParentEK,enterKey,parentName:",enterKey, parentName
  514. for keyItem in enterKey:
  515. if keyItem[self.Enter_Parent] == parentName:
  516. return True
  517. return False
  518. '''
  519. 检测option字典,是否下一级nextParent包含这一个parentName
  520. '''
  521. def checkOptionEnterParent(self, option, parentName):
  522. enterKey = option[self.TAB_ENTER_KEY]
  523. if option[self.TAB_NAME] == parentName:
  524. return True
  525. return self.checkEnterParentEK(enterKey, parentName)
  526. '''
  527. 根据parentName,在EnterKey所有列表中,找到匹配的enterKey字典选项
  528. 返回值:{"enterParent":"","key_param":{"keyType":"event","keyvalue":[left,right,enter],"wait":1,"enterParent":"hdmi_settings"}
  529. '''
  530. def getEKByParent(self, enterKeys, parentName):
  531. for keyItem in enterKeys:
  532. if keyItem[self.Enter_Parent] == parentName:
  533. return keyItem[self.Key_Param]
  534. return None
  535. '''
  536. 获取option的parent
  537. '''
  538. def getParentByOption(self, option):
  539. parentName = option[UATTree.TAB_PARENT_NAME]
  540. levelName = option[UATTree.TAB_LEVEL]
  541. if self.treeDict[levelName].has_key(parentName):
  542. parent = self.treeDict[levelName][parentName]
  543. return parent
  544. else:
  545. return None
  546. '''
  547. 根据Parent数据,查上一级parent。
  548. '''
  549. def getPreParentByParent(self, parent):
  550. prevLevel = self.getPrevLevel(parent[self.TAB_LEVEL])
  551. levelDict = self.treeDict[prevLevel]
  552. # print "getPreParentByParent,levelDict:",levelDict
  553. for parentName in levelDict.keys():
  554. parentDict = levelDict[parentName]
  555. # print "getPreParentByParent,parentDict:", parentDict
  556. for optionName in parentDict[UATTree.TAB_OPTION].keys():
  557. option = parentDict[UATTree.TAB_OPTION][optionName]
  558. # print "getPreParentByParent,option:", option
  559. if self.checkOptionEnterParent(option, parent[self.TAB_NAME]):
  560. return parentDict
  561. error(str(self.__class__), "getPreParentByParent",
  562. "Parent %s's prevparent not found in level %s"%(parent[self.TAB_NAME], prevLevel), ERROR)
  563. return None
  564. '''
  565. 获取当前level的前一个level名
  566. '''
  567. def getPrevLevel(self, level):
  568. self.levelList = self.treeDict.keys()
  569. index = self.levelList.index(level)
  570. if index == 0:
  571. return FirstPrev
  572. else:
  573. return self.levelList[index-1]
  574. '''
  575. 获取当前Parent的上一级parent
  576. '''
  577. def getPrevParent(self, parent):
  578. return parent[UATTree.TAB_PREV_PARENT]
  579. '''
  580. 获取当前parent下一级所有parent的字典
  581. '''
  582. def getNextParentList(self, parent):
  583. return parent[UATTree.TAB_NEXT_PARENT]
  584. def printTree(self):
  585. for level in self.treeDict.keys():
  586. print level
  587. for parent in self.treeDict[level].keys():
  588. dict1 = self.treeDict[level][parent]
  589. print level, "::parent ", dict1["name"], "name", "shortcut_key", "uiview", "move_key", "toparent_key", "layout"
  590. print level, "::parent ", dict1["name"], dict1["shortcut_key"], dict1["uiview"], dict1["move_key"], dict1["toparent_key"], dict1["layout"]
  591. for option in dict1["option"].keys():
  592. dict2 = dict1["option"][option]
  593. print level, "::option ", dict2
  594. Key_HeartBeat = "heartbeat_key"
  595. def parseOthers(self, othersStr):
  596. othersDict = {}
  597. othersDict[self.Key_HeartBeat] = self.parseParam(self.Key_HeartBeat, othersStr, char="{}")
  598. hb_keyDict = {}
  599. if othersDict[self.Key_HeartBeat] != "":
  600. print "Key_HeartBeat_Str:",othersDict[self.Key_HeartBeat]
  601. hb_keyDict = self.parseHeartBeatKey(othersDict[self.Key_HeartBeat])
  602. othersDict[self.Key_HeartBeat] = hb_keyDict
  603. return othersDict
  604. def parseHeartBeatKey(self, hb_keyStr):
  605. keyList = [self.Key_Event, self.Key_IR]
  606. keyDict = self.parseMulParam(keyList, hb_keyStr)
  607. keyDict[self.Key_Event] = strToList(keyDict[self.Key_Event], ",")
  608. keyDict[self.Key_IR] = strToList(keyDict[self.Key_IR], ",")
  609. return keyDict
  610. def parseDialogOthers(self, othersStr):
  611. othersDict = {}
  612. othersDict[self.Key_HeartBeat] = self.parseParam(self.Key_HeartBeat, othersStr, char="{}")
  613. hb_keyDict = {}
  614. if othersDict[self.Key_HeartBeat] != "":
  615. print "Key_HeartBeat_Str:",othersDict[self.Key_HeartBeat]
  616. hb_keyDict = self.parseHeartBeatKey(othersDict[self.Key_HeartBeat])
  617. othersDict[self.Key_HeartBeat] = hb_keyDict
  618. return othersDict
  619. if __name__ == '__main__':
  620. uatTree = UATTree()