merge code
This commit is contained in:
@@ -112,10 +112,13 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
FIELD_TYPE_NULL -> rowMap[columnName] = ""
|
||||
FIELD_TYPE_INTEGER -> rowMap[columnName] =
|
||||
getInt(columnIndex)
|
||||
|
||||
FIELD_TYPE_FLOAT -> rowMap[columnName] =
|
||||
getFloat(columnIndex)
|
||||
|
||||
FIELD_TYPE_BLOB -> rowMap[columnName] =
|
||||
String(getBlob(columnIndex), Charsets.UTF_8)
|
||||
|
||||
else -> rowMap[columnName] = getString(columnIndex)
|
||||
}
|
||||
}
|
||||
@@ -134,7 +137,8 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
* @param omdbZipFile omdb数据抽取生成的Zip文件
|
||||
* @param configFile 对应的配置文件
|
||||
* */
|
||||
suspend fun importOmdbZipFile(omdbZipFile: File, task: TaskBean): Flow<String> = withContext(Dispatchers.IO) {
|
||||
suspend fun importOmdbZipFile(omdbZipFile: File, task: TaskBean): Flow<String> =
|
||||
withContext(Dispatchers.IO) {
|
||||
val unZipFolder = File(omdbZipFile.parentFile, "result")
|
||||
flow {
|
||||
if (unZipFolder.exists()) {
|
||||
@@ -143,8 +147,7 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
unZipFolder.mkdirs()
|
||||
// 开始解压zip文件
|
||||
val unZipFiles = ZipUtils.unzipFile(omdbZipFile, unZipFolder)
|
||||
// 将listResult数据插入到Realm数据库中
|
||||
val realm = Realm.getDefaultInstance()
|
||||
|
||||
// 先获取当前配置的所有图层的个数,方便后续计算数据解析进度
|
||||
var tableNum = 0
|
||||
var processIndex = 0
|
||||
@@ -152,23 +155,27 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
tableNum += importConfig.tableMap.size
|
||||
}
|
||||
|
||||
realm.beginTransaction()
|
||||
try {
|
||||
|
||||
//缓存任务link信息,便于下面与数据进行任务link匹配
|
||||
val hashMap:HashMap<String,HadLinkDvoBean> = HashMap<String,HadLinkDvoBean>() //define empty hashmap
|
||||
val hashMap: HashMap<String, HadLinkDvoBean> =
|
||||
HashMap<String, HadLinkDvoBean>() //define empty hashmap
|
||||
task.hadLinkDvoList.forEach {
|
||||
hashMap.put(it.linkPid, it);
|
||||
}
|
||||
|
||||
val resHashMap:HashMap<String,RenderEntity> = HashMap<String,RenderEntity>() //define empty hashmap
|
||||
val resHashMap: HashMap<String, RenderEntity> =
|
||||
HashMap<String, RenderEntity>() //define empty hashmap
|
||||
|
||||
// 遍历解压后的文件,读取该数据返回
|
||||
for (importConfig in importConfigList) {
|
||||
try {
|
||||
for ((index, currentEntry) in importConfig.tableMap.entries.withIndex()) {
|
||||
val currentConfig = currentEntry.value
|
||||
val txtFile = unZipFiles.find {
|
||||
it.name == currentConfig.table
|
||||
}
|
||||
// 将listResult数据插入到Realm数据库中
|
||||
val realm = Realm.getDefaultInstance()
|
||||
val listResult = mutableListOf<RenderEntity>()
|
||||
currentConfig?.let {
|
||||
val list = FileIOUtils.readFile2List(txtFile, "UTF-8")
|
||||
@@ -180,11 +187,15 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
continue
|
||||
}
|
||||
Log.d("ImportOMDBHelper", "解析第:${index + 1}行")
|
||||
val map = gson.fromJson<Map<String, Any>>(line, object:TypeToken<Map<String, Any>>(){}.getType())
|
||||
val map = gson.fromJson<Map<String, Any>>(
|
||||
line,
|
||||
object : TypeToken<Map<String, Any>>() {}.getType()
|
||||
)
|
||||
.toMutableMap()
|
||||
map["qi_table"] = currentConfig.table
|
||||
map["qi_name"] = currentConfig.name
|
||||
map["qi_code"] = if (currentConfig.code == 0) currentConfig.code else currentEntry.key
|
||||
map["qi_code"] =
|
||||
if (currentConfig.code == 0) currentConfig.code else currentEntry.key
|
||||
map["qi_zoomMin"] = currentConfig.zoomMin
|
||||
map["qi_zoomMax"] = currentConfig.zoomMax
|
||||
|
||||
@@ -201,17 +212,23 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
renderEntity.geometry = map["geometry"].toString()
|
||||
// 其他数据插入到Properties中
|
||||
if (!currentConfig.is3D) { // 如果是非3d要素,则自动将Z轴坐标全部置为0
|
||||
val coordinates = renderEntity.wkt?.coordinates?.map {
|
||||
coordinate -> coordinate.z = 0.0
|
||||
val coordinates =
|
||||
renderEntity.wkt?.coordinates?.map { coordinate ->
|
||||
coordinate.z = 0.0
|
||||
coordinate
|
||||
}?.toTypedArray()
|
||||
var newGeometry: Geometry? = null
|
||||
if (renderEntity.wkt?.geometryType == Geometry.TYPENAME_POINT) {
|
||||
newGeometry = GeometryTools.createPoint(coordinates!![0].x, coordinates!![0].y)
|
||||
newGeometry = GeometryTools.createPoint(
|
||||
coordinates!![0].x,
|
||||
coordinates!![0].y
|
||||
)
|
||||
} else if (renderEntity.wkt?.geometryType == Geometry.TYPENAME_LINESTRING) {
|
||||
newGeometry = GeometryTools.createLineString(coordinates)
|
||||
newGeometry =
|
||||
GeometryTools.createLineString(coordinates)
|
||||
} else if (renderEntity.wkt?.geometryType == Geometry.TYPENAME_POLYGON) {
|
||||
newGeometry = GeometryTools.createLineString(coordinates)
|
||||
newGeometry =
|
||||
GeometryTools.createLineString(coordinates)
|
||||
}
|
||||
if (newGeometry != null) {
|
||||
renderEntity.geometry = newGeometry.toString()
|
||||
@@ -225,11 +242,16 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
key,
|
||||
value.toInt().toString()
|
||||
)
|
||||
|
||||
is Double -> renderEntity.properties.put(
|
||||
key,
|
||||
value.toDouble().toString()
|
||||
)
|
||||
else -> renderEntity.properties.put(key, value.toString())
|
||||
|
||||
else -> renderEntity.properties.put(
|
||||
key,
|
||||
value.toString()
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -260,12 +282,16 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
continue
|
||||
}
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_LANE_MARK_BOUNDARYTYPE.code) {
|
||||
var boundaryType = renderEntity.properties["boundaryType"]
|
||||
var boundaryType =
|
||||
renderEntity.properties["boundaryType"]
|
||||
if (boundaryType != null) {
|
||||
when (boundaryType) {
|
||||
"0", "1", "6", "8", "9" -> {
|
||||
renderEntity.enable = 0
|
||||
Log.e("qj","过滤不显示数据${renderEntity.table}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"过滤不显示数据${renderEntity.table}"
|
||||
)
|
||||
continue
|
||||
}
|
||||
}
|
||||
@@ -273,24 +299,32 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_RDBOUND_BOUNDARYTYPE.code) {
|
||||
|
||||
//过滤不需要渲染的要素
|
||||
var boundaryType = renderEntity.properties["boundaryType"]
|
||||
var boundaryType =
|
||||
renderEntity.properties["boundaryType"]
|
||||
if (boundaryType != null) {
|
||||
when (boundaryType) {
|
||||
"0", "3", "4", "5", "7", "9" -> {
|
||||
renderEntity.enable = 0
|
||||
Log.e("qj","过滤不显示数据${renderEntity.table}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"过滤不显示数据${renderEntity.table}"
|
||||
)
|
||||
continue
|
||||
}
|
||||
}
|
||||
}
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_OBJECT_STOPLOCATION.code) {
|
||||
//过滤不需要渲染的要素
|
||||
var locationType = renderEntity.properties["locationType"]
|
||||
var locationType =
|
||||
renderEntity.properties["locationType"]
|
||||
if (locationType != null) {
|
||||
when (locationType) {
|
||||
"3", "4" -> {
|
||||
renderEntity.enable = 0
|
||||
Log.e("qj","过滤不显示数据${renderEntity.table}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"过滤不显示数据${renderEntity.table}"
|
||||
)
|
||||
continue
|
||||
}
|
||||
}
|
||||
@@ -299,13 +333,19 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
|
||||
//交限增加相同LinkIn与LinkOut过滤原则
|
||||
if (renderEntity.code == DataCodeEnum.OMDB_RESTRICTION.code) {
|
||||
if(renderEntity.properties.containsKey("linkIn")&&renderEntity.properties.containsKey("linkOut")){
|
||||
if (renderEntity.properties.containsKey("linkIn") && renderEntity.properties.containsKey(
|
||||
"linkOut"
|
||||
)
|
||||
) {
|
||||
var linkIn = renderEntity.properties["linkIn"]
|
||||
var linkOut = renderEntity.properties["linkOut"]
|
||||
if (linkIn != null && linkOut != null) {
|
||||
var checkMsg = "$linkIn$linkOut"
|
||||
if (resHashMap.containsKey(checkMsg)) {
|
||||
Log.e("qj","${renderEntity.name}==过滤交限linkin与linkout相同且存在多条数据")
|
||||
Log.e(
|
||||
"qj",
|
||||
"${renderEntity.name}==过滤交限linkin与linkout相同且存在多条数据"
|
||||
)
|
||||
continue
|
||||
} else {
|
||||
resHashMap.put(checkMsg, renderEntity)
|
||||
@@ -319,7 +359,8 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
|
||||
if (renderEntity.properties.containsKey("linkPid")) {
|
||||
|
||||
var currentLinkPid = renderEntity.properties["linkPid"]
|
||||
var currentLinkPid =
|
||||
renderEntity.properties["linkPid"]
|
||||
|
||||
if (!currentLinkPid.isNullOrEmpty() && currentLinkPid != "null") {
|
||||
|
||||
@@ -329,33 +370,53 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
m@ for (linkPid in list) {
|
||||
if (hashMap.containsKey(linkPid)) {
|
||||
renderEntity.enable = 1
|
||||
Log.e("qj","${renderEntity.name}==包括任务link")
|
||||
Log.e(
|
||||
"qj",
|
||||
"${renderEntity.name}==包括任务link"
|
||||
)
|
||||
break@m
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}else if(renderEntity.code == DataCodeEnum.OMDB_INTERSECTION.code && renderEntity.properties.containsKey("linkList")){
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_INTERSECTION.code && renderEntity.properties.containsKey(
|
||||
"linkList"
|
||||
)
|
||||
) {
|
||||
|
||||
if (renderEntity.properties["linkList"] != null) {
|
||||
|
||||
Log.e("qj", "linkList==开始${renderEntity.name}==${renderEntity.properties["linkList"]}}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"linkList==开始${renderEntity.name}==${renderEntity.properties["linkList"]}}"
|
||||
)
|
||||
|
||||
val linkList = renderEntity.properties["linkList"]
|
||||
val linkList =
|
||||
renderEntity.properties["linkList"]
|
||||
|
||||
if (!linkList.isNullOrEmpty() && linkList != "null") {
|
||||
|
||||
Log.e("qj", "linkList==${renderEntity.name}==${renderEntity.properties["linkList"]}}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"linkList==${renderEntity.name}==${renderEntity.properties["linkList"]}}"
|
||||
)
|
||||
|
||||
val list: List<LinkList> = gson.fromJson(linkList, object : TypeToken<List<LinkList>>() {}.type)
|
||||
val list: List<LinkList> = gson.fromJson(
|
||||
linkList,
|
||||
object :
|
||||
TypeToken<List<LinkList>>() {}.type
|
||||
)
|
||||
|
||||
if (list != null) {
|
||||
m@ for (link in list) {
|
||||
if (hashMap.containsKey(link.linkPid)) {
|
||||
renderEntity.enable = 1
|
||||
break@m
|
||||
Log.e("qj","${renderEntity.name}==包括任务link")
|
||||
Log.e(
|
||||
"qj",
|
||||
"${renderEntity.name}==包括任务link"
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -366,7 +427,10 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
}
|
||||
} else {
|
||||
renderEntity.enable = 2
|
||||
Log.e("qj","${renderEntity.name}==不包括任务linkPid")
|
||||
Log.e(
|
||||
"qj",
|
||||
"${renderEntity.name}==不包括任务linkPid"
|
||||
)
|
||||
}
|
||||
} else {
|
||||
renderEntity.enable = 2
|
||||
@@ -375,9 +439,10 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
|
||||
|
||||
// 对renderEntity做预处理后再保存
|
||||
val resultEntity = importConfig.transformProperties(renderEntity)
|
||||
val resultEntity =
|
||||
importConfig.transformProperties(renderEntity)
|
||||
|
||||
if(renderEntity!=null){
|
||||
if (resultEntity != null) {
|
||||
if (currentConfig.catch) {
|
||||
renderEntity.catchEnable = 0
|
||||
} else {
|
||||
@@ -392,26 +457,34 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
var type = renderEntity.properties["sa"]
|
||||
|
||||
if (type != null && type == "1") {
|
||||
renderEntity.code = DataCodeEnum.OMDB_LINK_ATTRIBUTE_SA.code
|
||||
renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_ATTRIBUTE_SA.code
|
||||
Log.e("qj", "道路属性===1")
|
||||
} else {
|
||||
type = renderEntity.properties["pa"]
|
||||
if (type != null && type == "1") {
|
||||
renderEntity.code = DataCodeEnum.OMDB_LINK_ATTRIBUTE_PA.code
|
||||
renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_ATTRIBUTE_PA.code
|
||||
Log.e("qj", "道路属性===2")
|
||||
} else {
|
||||
type = renderEntity.properties["frontage"]
|
||||
if (type != null && type == "1") {
|
||||
renderEntity.code = DataCodeEnum.OMDB_LINK_ATTRIBUTE_FORNTAGE.code
|
||||
renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_ATTRIBUTE_FORNTAGE.code
|
||||
Log.e("qj", "道路属性===3")
|
||||
} else {
|
||||
type = renderEntity.properties["mainSideAccess"]
|
||||
type =
|
||||
renderEntity.properties["mainSideAccess"]
|
||||
if (type != null && type == "1") {
|
||||
renderEntity.code = DataCodeEnum.OMDB_LINK_ATTRIBUTE_MAIN_SIDE_ACCESS.code
|
||||
renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_ATTRIBUTE_MAIN_SIDE_ACCESS.code
|
||||
Log.e("qj", "道路属性===4")
|
||||
} else {
|
||||
renderEntity.enable = 0
|
||||
Log.e("qj","过滤不显示数据${renderEntity.table}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"过滤不显示数据${renderEntity.table}"
|
||||
)
|
||||
Log.e("qj", "道路属性===5")
|
||||
continue
|
||||
}
|
||||
@@ -423,13 +496,26 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
var formWay = renderEntity.properties["formOfWay"]
|
||||
if (formWay != null) {
|
||||
when (formWay) {
|
||||
"93"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_1.code
|
||||
"98"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_2.code
|
||||
"99"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_3.code
|
||||
"100"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_4.code
|
||||
"102"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_5.code
|
||||
"103"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_6.code
|
||||
"104"-> renderEntity.code = DataCodeEnum.OMDB_RAMP_7.code
|
||||
"93" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_1.code
|
||||
|
||||
"98" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_2.code
|
||||
|
||||
"99" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_3.code
|
||||
|
||||
"100" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_4.code
|
||||
|
||||
"102" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_5.code
|
||||
|
||||
"103" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_6.code
|
||||
|
||||
"104" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_RAMP_7.code
|
||||
}
|
||||
}
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_LINK_FORM1.code) {
|
||||
@@ -437,30 +523,63 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
var formWay = renderEntity.properties["formOfWay"]
|
||||
if (formWay != null) {
|
||||
when (formWay) {
|
||||
"35"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM1_1.code
|
||||
"37"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM1_2.code
|
||||
"38"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM1_3.code
|
||||
"35" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM1_1.code
|
||||
|
||||
"37" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM1_2.code
|
||||
|
||||
"38" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM1_3.code
|
||||
}
|
||||
}
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_LINK_FORM2.code) {
|
||||
Log.e("qj","道路形态2${renderEntity.properties["formOfWay"]}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"道路形态2${renderEntity.properties["formOfWay"]}"
|
||||
)
|
||||
/*道路形态2*/
|
||||
var formWay = renderEntity.properties["formOfWay"]
|
||||
if (formWay != null) {
|
||||
when (formWay) {
|
||||
"10"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_1.code
|
||||
"11"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_2.code
|
||||
"17"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_3.code
|
||||
"18"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_4.code
|
||||
"20"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_5.code
|
||||
"22"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_6.code
|
||||
"36"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_7.code
|
||||
"52"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_8.code
|
||||
"53"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_9.code
|
||||
"54"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_10.code
|
||||
"60"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_11.code
|
||||
"84"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_12.code
|
||||
"85"-> renderEntity.code = DataCodeEnum.OMDB_LINK_FORM2_13.code
|
||||
"10" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_1.code
|
||||
|
||||
"11" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_2.code
|
||||
|
||||
"17" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_3.code
|
||||
|
||||
"18" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_4.code
|
||||
|
||||
"20" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_5.code
|
||||
|
||||
"22" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_6.code
|
||||
|
||||
"36" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_7.code
|
||||
|
||||
"52" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_8.code
|
||||
|
||||
"53" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_9.code
|
||||
|
||||
"54" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_10.code
|
||||
|
||||
"60" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_11.code
|
||||
|
||||
"84" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_12.code
|
||||
|
||||
"85" -> renderEntity.code =
|
||||
DataCodeEnum.OMDB_LINK_FORM2_13.code
|
||||
}
|
||||
}
|
||||
} else if (renderEntity.table == DataCodeEnum.OMDB_NODE_FORM.name) {//特殊处理,因为code相同,使用表名判断
|
||||
@@ -468,19 +587,28 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
var formOfWay = renderEntity.properties["formOfWay"]
|
||||
if (formOfWay != null && formOfWay == "30") {
|
||||
renderEntity.enable = 2
|
||||
renderEntity.code = DataCodeEnum.OMDB_NODE_FORM.code
|
||||
renderEntity.code =
|
||||
DataCodeEnum.OMDB_NODE_FORM.code
|
||||
} else {
|
||||
Log.e("qj","过滤不显示数据${renderEntity.table}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"过滤不显示数据${renderEntity.table}"
|
||||
)
|
||||
continue
|
||||
}
|
||||
} else if (renderEntity.table == DataCodeEnum.OMDB_NODE_PA.name) {//特殊处理,因为code相同,使用表名判断
|
||||
//过滤不需要渲染的要素
|
||||
var attributeType = renderEntity.properties["attributeType"]
|
||||
var attributeType =
|
||||
renderEntity.properties["attributeType"]
|
||||
if (attributeType != null && attributeType == "30") {
|
||||
renderEntity.enable = 2
|
||||
renderEntity.code = DataCodeEnum.OMDB_NODE_PA.code
|
||||
renderEntity.code =
|
||||
DataCodeEnum.OMDB_NODE_PA.code
|
||||
} else {
|
||||
Log.e("qj","过滤不显示数据${renderEntity.table}")
|
||||
Log.e(
|
||||
"qj",
|
||||
"过滤不显示数据${renderEntity.table}"
|
||||
)
|
||||
continue
|
||||
}
|
||||
} else if (renderEntity.code == DataCodeEnum.OMDB_LANE_CONSTRUCTION.code) {
|
||||
@@ -490,32 +618,27 @@ class ImportOMDBHelper @AssistedInject constructor(
|
||||
renderEntity.properties["startTime"] = "null"
|
||||
}
|
||||
}
|
||||
|
||||
realm.insert(renderEntity)
|
||||
}
|
||||
|
||||
|
||||
listResult.add(renderEntity)
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
// 1个文件发送一次flow流
|
||||
emit("${++processIndex}/${tableNum}")
|
||||
realm.beginTransaction()
|
||||
realm.insert(listResult)
|
||||
realm.commitTransaction()
|
||||
realm.close()
|
||||
// 如果当前解析的是OMDB_RD_LINK数据,将其缓存在预处理类中,以便后续处理其他要素时使用
|
||||
if (currentConfig.table == "OMDB_RD_LINK") {
|
||||
importConfig.preProcess.cacheRdLink =
|
||||
listResult.associateBy { it.properties["linkPid"] }
|
||||
}
|
||||
}
|
||||
}
|
||||
realm.commitTransaction()
|
||||
realm.close()
|
||||
} catch (e: Exception) {
|
||||
realm.cancelTransaction()
|
||||
throw e
|
||||
}
|
||||
}
|
||||
emit("finish")
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user