123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- //This file is automatically rebuilt by the Cesium build process.
- export default "in vec3 position3DHigh;\n\
- in vec3 position3DLow;\n\
- in vec3 position2DHigh;\n\
- in vec3 position2DLow;\n\
- in vec3 prevPosition3DHigh;\n\
- in vec3 prevPosition3DLow;\n\
- in vec3 prevPosition2DHigh;\n\
- in vec3 prevPosition2DLow;\n\
- in vec3 nextPosition3DHigh;\n\
- in vec3 nextPosition3DLow;\n\
- in vec3 nextPosition2DHigh;\n\
- in vec3 nextPosition2DLow;\n\
- in vec4 texCoordExpandAndBatchIndex;\n\
- \n\
- out vec2 v_st;\n\
- out float v_width;\n\
- out vec4 v_pickColor;\n\
- out float v_polylineAngle;\n\
- \n\
- void main()\n\
- {\n\
- float texCoord = texCoordExpandAndBatchIndex.x;\n\
- float expandDir = texCoordExpandAndBatchIndex.y;\n\
- bool usePrev = texCoordExpandAndBatchIndex.z < 0.0;\n\
- float batchTableIndex = texCoordExpandAndBatchIndex.w;\n\
- \n\
- vec2 widthAndShow = batchTable_getWidthAndShow(batchTableIndex);\n\
- float width = widthAndShow.x + 0.5;\n\
- float show = widthAndShow.y;\n\
- \n\
- if (width < 1.0)\n\
- {\n\
- show = 0.0;\n\
- }\n\
- \n\
- vec4 pickColor = batchTable_getPickColor(batchTableIndex);\n\
- \n\
- vec4 p, prev, next;\n\
- if (czm_morphTime == 1.0)\n\
- {\n\
- p = czm_translateRelativeToEye(position3DHigh.xyz, position3DLow.xyz);\n\
- prev = czm_translateRelativeToEye(prevPosition3DHigh.xyz, prevPosition3DLow.xyz);\n\
- next = czm_translateRelativeToEye(nextPosition3DHigh.xyz, nextPosition3DLow.xyz);\n\
- }\n\
- else if (czm_morphTime == 0.0)\n\
- {\n\
- p = czm_translateRelativeToEye(position2DHigh.zxy, position2DLow.zxy);\n\
- prev = czm_translateRelativeToEye(prevPosition2DHigh.zxy, prevPosition2DLow.zxy);\n\
- next = czm_translateRelativeToEye(nextPosition2DHigh.zxy, nextPosition2DLow.zxy);\n\
- }\n\
- else\n\
- {\n\
- p = czm_columbusViewMorph(\n\
- czm_translateRelativeToEye(position2DHigh.zxy, position2DLow.zxy),\n\
- czm_translateRelativeToEye(position3DHigh.xyz, position3DLow.xyz),\n\
- czm_morphTime);\n\
- prev = czm_columbusViewMorph(\n\
- czm_translateRelativeToEye(prevPosition2DHigh.zxy, prevPosition2DLow.zxy),\n\
- czm_translateRelativeToEye(prevPosition3DHigh.xyz, prevPosition3DLow.xyz),\n\
- czm_morphTime);\n\
- next = czm_columbusViewMorph(\n\
- czm_translateRelativeToEye(nextPosition2DHigh.zxy, nextPosition2DLow.zxy),\n\
- czm_translateRelativeToEye(nextPosition3DHigh.xyz, nextPosition3DLow.xyz),\n\
- czm_morphTime);\n\
- }\n\
- \n\
- #ifdef DISTANCE_DISPLAY_CONDITION\n\
- vec3 centerHigh = batchTable_getCenterHigh(batchTableIndex);\n\
- vec4 centerLowAndRadius = batchTable_getCenterLowAndRadius(batchTableIndex);\n\
- vec3 centerLow = centerLowAndRadius.xyz;\n\
- float radius = centerLowAndRadius.w;\n\
- vec2 distanceDisplayCondition = batchTable_getDistanceDisplayCondition(batchTableIndex);\n\
- \n\
- float lengthSq;\n\
- if (czm_sceneMode == czm_sceneMode2D)\n\
- {\n\
- lengthSq = czm_eyeHeight2D.y;\n\
- }\n\
- else\n\
- {\n\
- vec4 center = czm_translateRelativeToEye(centerHigh.xyz, centerLow.xyz);\n\
- lengthSq = max(0.0, dot(center.xyz, center.xyz) - radius * radius);\n\
- }\n\
- \n\
- float nearSq = distanceDisplayCondition.x * distanceDisplayCondition.x;\n\
- float farSq = distanceDisplayCondition.y * distanceDisplayCondition.y;\n\
- if (lengthSq < nearSq || lengthSq > farSq)\n\
- {\n\
- show = 0.0;\n\
- }\n\
- #endif\n\
- \n\
- float polylineAngle;\n\
- vec4 positionWC = getPolylineWindowCoordinates(p, prev, next, expandDir, width, usePrev, polylineAngle);\n\
- gl_Position = czm_viewportOrthographic * positionWC * show;\n\
- \n\
- v_st.s = texCoord;\n\
- v_st.t = czm_writeNonPerspective(clamp(expandDir, 0.0, 1.0), gl_Position.w);\n\
- \n\
- v_width = width;\n\
- v_pickColor = pickColor;\n\
- v_polylineAngle = polylineAngle;\n\
- }\n\
- ";
|