diff --git a/RMAGEN/2dm_linear.2dm b/RMAGEN/2dm_linear.2dm new file mode 100644 index 0000000..8d4d103 --- /dev/null +++ b/RMAGEN/2dm_linear.2dm @@ -0,0 +1,129 @@ +MESH2D +MESHNAME "default coverage" +E4Q 1 3 1 2 4 1 +E4Q 2 4 2 5 9 1 +E4Q 3 6 3 4 8 1 +E4Q 4 8 4 9 13 1 +E4Q 5 9 5 10 14 1 +E3T 6 6 12 7 1 +E3T 7 12 6 8 1 +E4Q 8 18 11 7 12 1 +E3T 9 8 13 12 1 +E4Q 10 13 9 14 20 1 +E4Q 11 14 10 15 21 1 +E4Q 12 28 17 11 18 1 +E3T 13 19 12 13 1 +E4Q 14 29 18 12 19 1 +E3T 15 20 19 13 1 +E4Q 16 20 14 21 31 1 +E4Q 17 21 15 16 22 1 +E4Q 18 22 16 23 32 1 +E3T 19 24 17 28 1 +E4Q 20 37 28 18 29 1 +E3T 21 30 19 20 1 +E4Q 22 38 29 19 30 1 +E3T 23 30 20 31 1 +E3T 24 31 21 22 1 +E4Q 25 31 22 32 40 1 +E4Q 26 32 23 27 36 1 +E3T 27 28 33 24 1 +E3T 28 25 24 33 1 +E4Q 29 42 34 26 35 1 +E4Q 30 36 27 34 42 1 +E3T 31 33 28 37 1 +E4Q 32 46 37 29 38 1 +E3T 33 30 31 39 1 +E3T 34 39 38 30 1 +E3T 35 39 31 40 1 +E4Q 36 40 32 36 44 1 +E3T 37 37 41 33 1 +E4Q 38 50 42 35 43 1 +E4Q 39 44 36 42 50 1 +E3T 40 41 37 45 1 +E3T 41 46 45 37 1 +E3T 42 46 38 39 1 +E3T 43 40 47 39 1 +E3T 44 54 46 39 1 +E3T 45 40 44 47 1 +E3T 46 41 45 49 1 +E3T 47 50 43 51 1 +E3T 48 50 52 44 1 +E3T 49 44 52 47 1 +E3T 50 45 46 53 1 +E3T 51 53 48 45 1 +E3T 52 48 49 45 1 +E3T 53 46 54 53 1 +E3T 54 57 54 47 1 +E3T 55 53 55 48 1 +E3T 56 49 48 55 1 +E3T 57 50 56 52 1 +E3T 58 50 51 56 1 +E3T 59 59 57 52 1 +E3T 60 54 58 53 1 +E3T 61 55 53 58 1 +E3T 62 58 54 57 1 +E3T 63 58 57 60 1 +E3T 64 59 60 57 1 +E3T 65 59 52 56 1 +E3T 66 57 47 52 1 +E3T 67 54 39 47 1 +ND 1 6.83115000e+005 8.65270800e+006 0.00000000e+000 +ND 2 6.82066000e+005 8.65270156e+006 0.00000000e+000 +ND 3 6.82837136e+005 8.65185167e+006 0.00000000e+000 +ND 4 6.81846398e+005 8.65182937e+006 0.00000000e+000 +ND 5 6.81017000e+005 8.65269511e+006 0.00000000e+000 +ND 6 6.82507000e+005 8.65101400e+006 0.00000000e+000 +ND 7 6.82565000e+005 8.65029000e+006 0.00000000e+000 +ND 8 6.81464500e+005 8.65096875e+006 0.00000000e+000 +ND 9 6.80855661e+005 8.65180708e+006 0.00000000e+000 +ND 10 6.79968000e+005 8.65268867e+006 0.00000000e+000 +ND 11 6.82548810e+005 8.64951489e+006 0.00000000e+000 +ND 12 6.81521500e+005 8.65018550e+006 0.00000000e+000 +ND 13 6.80422000e+005 8.65092350e+006 0.00000000e+000 +ND 14 6.79864924e+005 8.65178478e+006 0.00000000e+000 +ND 15 6.78919000e+005 8.65268222e+006 0.00000000e+000 +ND 16 6.77870000e+005 8.65267578e+006 0.00000000e+000 +ND 17 6.82532619e+005 8.64873978e+006 0.00000000e+000 +ND 18 6.81569158e+005 8.64945958e+006 0.00000000e+000 +ND 19 6.80478000e+005 8.65008100e+006 0.00000000e+000 +ND 20 6.79379500e+005 8.65087825e+006 0.00000000e+000 +ND 21 6.78874186e+005 8.65176248e+006 0.00000000e+000 +ND 22 6.77883449e+005 8.65174019e+006 0.00000000e+000 +ND 23 6.76821000e+005 8.65266933e+006 0.00000000e+000 +ND 24 6.82512810e+005 8.64779139e+006 0.00000000e+000 +ND 25 6.82493000e+005 8.64684300e+006 0.00000000e+000 +ND 26 6.73674000e+005 8.65265000e+006 0.00000000e+000 +ND 27 6.75772000e+005 8.65266289e+006 0.00000000e+000 +ND 28 6.81464183e+005 8.64873265e+006 0.00000000e+000 +ND 29 6.80589507e+005 8.64940428e+006 0.00000000e+000 +ND 30 6.79434500e+005 8.64997650e+006 0.00000000e+000 +ND 31 6.78337000e+005 8.65083300e+006 0.00000000e+000 +ND 32 6.76892712e+005 8.65171789e+006 0.00000000e+000 +ND 33 6.81378000e+005 8.64685267e+006 0.00000000e+000 +ND 34 6.74723000e+005 8.65265644e+006 0.00000000e+000 +ND 35 6.73920500e+005 8.65165100e+006 0.00000000e+000 +ND 36 6.75901975e+005 8.65169559e+006 0.00000000e+000 +ND 37 6.80395746e+005 8.64872552e+006 0.00000000e+000 +ND 38 6.79609856e+005 8.64934897e+006 0.00000000e+000 +ND 39 6.78391000e+005 8.64987200e+006 0.00000000e+000 +ND 40 6.77294500e+005 8.65078775e+006 0.00000000e+000 +ND 41 6.80263000e+005 8.64686233e+006 0.00000000e+000 +ND 42 6.74911237e+005 8.65167330e+006 0.00000000e+000 +ND 43 6.74167000e+005 8.65065200e+006 0.00000000e+000 +ND 44 6.76252000e+005 8.65074250e+006 0.00000000e+000 +ND 45 6.79617734e+005 8.64780276e+006 0.00000000e+000 +ND 46 6.79327310e+005 8.64871839e+006 0.00000000e+000 +ND 47 6.77347500e+005 8.64976750e+006 0.00000000e+000 +ND 48 6.79007180e+005 8.64752197e+006 0.00000000e+000 +ND 49 6.79148000e+005 8.64687200e+006 0.00000000e+000 +ND 50 6.75209500e+005 8.65069725e+006 0.00000000e+000 +ND 51 6.74713750e+005 8.65010525e+006 0.00000000e+000 +ND 52 6.76304000e+005 8.64966300e+006 0.00000000e+000 +ND 53 6.78702478e+005 8.64803225e+006 0.00000000e+000 +ND 54 6.78258873e+005 8.64871126e+006 0.00000000e+000 +ND 55 6.78357934e+005 8.64727123e+006 0.00000000e+000 +ND 56 6.75260500e+005 8.64955850e+006 0.00000000e+000 +ND 57 6.77190437e+005 8.64870413e+006 0.00000000e+000 +ND 58 6.77586972e+005 8.64770291e+006 0.00000000e+000 +ND 59 6.76122000e+005 8.64869700e+006 0.00000000e+000 +ND 60 6.76854486e+005 8.64819996e+006 0.00000000e+000 diff --git a/RMAGEN/2dm_quad.2dm b/RMAGEN/2dm_quad.2dm new file mode 100644 index 0000000..8cd4869 --- /dev/null +++ b/RMAGEN/2dm_quad.2dm @@ -0,0 +1,255 @@ +MESH2D +MESHNAME "default coverage" +E8Q 1 3 61 1 62 2 63 4 64 1 +E8Q 2 4 63 2 65 5 66 9 67 1 +E8Q 3 6 68 3 64 4 69 8 70 1 +E8Q 4 8 69 4 67 9 71 13 72 1 +E8Q 5 9 66 5 73 10 74 14 75 1 +E6T 6 6 76 12 77 7 78 1 +E6T 7 12 76 6 70 8 79 1 +E8Q 8 18 80 11 81 7 77 12 82 1 +E6T 9 8 72 13 83 12 79 1 +E8Q 10 13 71 9 75 14 84 20 85 1 +E8Q 11 14 74 10 86 15 87 21 88 1 +E8Q 12 28 89 17 90 11 80 18 91 1 +E6T 13 19 92 12 83 13 93 1 +E8Q 14 29 94 18 82 12 92 19 95 1 +E6T 15 20 96 19 93 13 85 1 +E8Q 16 20 84 14 88 21 97 31 98 1 +E8Q 17 21 87 15 99 16 100 22 101 1 +E8Q 18 22 100 16 102 23 103 32 104 1 +E6T 19 24 105 17 89 28 106 1 +E8Q 20 37 107 28 91 18 94 29 108 1 +E6T 21 30 109 19 96 20 110 1 +E8Q 22 38 111 29 95 19 109 30 112 1 +E6T 23 30 110 20 98 31 113 1 +E6T 24 31 97 21 101 22 114 1 +E8Q 25 31 114 22 104 32 115 40 116 1 +E8Q 26 32 103 23 117 27 118 36 119 1 +E6T 27 28 120 33 121 24 106 1 +E6T 28 25 122 24 121 33 123 1 +E8Q 29 42 124 34 125 26 126 35 127 1 +E8Q 30 36 118 27 128 34 124 42 129 1 +E6T 31 33 120 28 107 37 130 1 +E8Q 32 46 131 37 108 29 111 38 132 1 +E6T 33 30 113 31 133 39 134 1 +E6T 34 39 135 38 112 30 134 1 +E6T 35 39 133 31 116 40 136 1 +E8Q 36 40 115 32 119 36 137 44 138 1 +E6T 37 37 139 41 140 33 130 1 +E8Q 38 50 141 42 127 35 142 43 143 1 +E8Q 39 44 137 36 129 42 141 50 144 1 +E6T 40 41 139 37 145 45 146 1 +E6T 41 46 147 45 145 37 131 1 +E6T 42 46 132 38 135 39 148 1 +E6T 43 40 149 47 150 39 136 1 +E6T 44 54 151 46 148 39 152 1 +E6T 45 40 138 44 153 47 149 1 +E6T 46 41 146 45 154 49 155 1 +E6T 47 50 143 43 156 51 157 1 +E6T 48 50 158 52 159 44 144 1 +E6T 49 44 159 52 160 47 153 1 +E6T 50 45 147 46 161 53 162 1 +E6T 51 53 163 48 164 45 162 1 +E6T 52 48 165 49 154 45 164 1 +E6T 53 46 151 54 166 53 161 1 +E6T 54 57 167 54 168 47 169 1 +E6T 55 53 170 55 171 48 163 1 +E6T 56 49 165 48 171 55 172 1 +E6T 57 50 173 56 174 52 158 1 +E6T 58 50 157 51 175 56 173 1 +E6T 59 59 176 57 177 52 178 1 +E6T 60 54 179 58 180 53 166 1 +E6T 61 55 170 53 180 58 181 1 +E6T 62 58 179 54 167 57 182 1 +E6T 63 58 182 57 183 60 184 1 +E6T 64 59 185 60 183 57 176 1 +E6T 65 59 178 52 174 56 186 1 +E6T 66 57 169 47 160 52 177 1 +E6T 67 54 152 39 150 47 168 1 +ND 1 6.83115000e+005 8.65270800e+006 0.00000000e+000 +ND 2 6.82066000e+005 8.65270156e+006 0.00000000e+000 +ND 3 6.82837136e+005 8.65185167e+006 0.00000000e+000 +ND 4 6.81846398e+005 8.65182937e+006 0.00000000e+000 +ND 5 6.81017000e+005 8.65269511e+006 0.00000000e+000 +ND 6 6.82507000e+005 8.65101400e+006 0.00000000e+000 +ND 7 6.82565000e+005 8.65029000e+006 0.00000000e+000 +ND 8 6.81464500e+005 8.65096875e+006 0.00000000e+000 +ND 9 6.80855661e+005 8.65180708e+006 0.00000000e+000 +ND 10 6.79968000e+005 8.65268867e+006 0.00000000e+000 +ND 11 6.82548810e+005 8.64951489e+006 0.00000000e+000 +ND 12 6.81521500e+005 8.65018550e+006 0.00000000e+000 +ND 13 6.80422000e+005 8.65092350e+006 0.00000000e+000 +ND 14 6.79864924e+005 8.65178478e+006 0.00000000e+000 +ND 15 6.78919000e+005 8.65268222e+006 0.00000000e+000 +ND 16 6.77870000e+005 8.65267578e+006 0.00000000e+000 +ND 17 6.82532619e+005 8.64873978e+006 0.00000000e+000 +ND 18 6.81569158e+005 8.64945958e+006 0.00000000e+000 +ND 19 6.80478000e+005 8.65008100e+006 0.00000000e+000 +ND 20 6.79379500e+005 8.65087825e+006 0.00000000e+000 +ND 21 6.78874186e+005 8.65176248e+006 0.00000000e+000 +ND 22 6.77883449e+005 8.65174019e+006 0.00000000e+000 +ND 23 6.76821000e+005 8.65266933e+006 0.00000000e+000 +ND 24 6.82512810e+005 8.64779139e+006 0.00000000e+000 +ND 25 6.82493000e+005 8.64684300e+006 0.00000000e+000 +ND 26 6.73674000e+005 8.65265000e+006 0.00000000e+000 +ND 27 6.75772000e+005 8.65266289e+006 0.00000000e+000 +ND 28 6.81464183e+005 8.64873265e+006 0.00000000e+000 +ND 29 6.80589507e+005 8.64940428e+006 0.00000000e+000 +ND 30 6.79434500e+005 8.64997650e+006 0.00000000e+000 +ND 31 6.78337000e+005 8.65083300e+006 0.00000000e+000 +ND 32 6.76892712e+005 8.65171789e+006 0.00000000e+000 +ND 33 6.81378000e+005 8.64685267e+006 0.00000000e+000 +ND 34 6.74723000e+005 8.65265644e+006 0.00000000e+000 +ND 35 6.73920500e+005 8.65165100e+006 0.00000000e+000 +ND 36 6.75901975e+005 8.65169559e+006 0.00000000e+000 +ND 37 6.80395746e+005 8.64872552e+006 0.00000000e+000 +ND 38 6.79609856e+005 8.64934897e+006 0.00000000e+000 +ND 39 6.78391000e+005 8.64987200e+006 0.00000000e+000 +ND 40 6.77294500e+005 8.65078775e+006 0.00000000e+000 +ND 41 6.80263000e+005 8.64686233e+006 0.00000000e+000 +ND 42 6.74911237e+005 8.65167330e+006 0.00000000e+000 +ND 43 6.74167000e+005 8.65065200e+006 0.00000000e+000 +ND 44 6.76252000e+005 8.65074250e+006 0.00000000e+000 +ND 45 6.79617734e+005 8.64780276e+006 0.00000000e+000 +ND 46 6.79327310e+005 8.64871839e+006 0.00000000e+000 +ND 47 6.77347500e+005 8.64976750e+006 0.00000000e+000 +ND 48 6.79007180e+005 8.64752197e+006 0.00000000e+000 +ND 49 6.79148000e+005 8.64687200e+006 0.00000000e+000 +ND 50 6.75209500e+005 8.65069725e+006 0.00000000e+000 +ND 51 6.74713750e+005 8.65010525e+006 0.00000000e+000 +ND 52 6.76304000e+005 8.64966300e+006 0.00000000e+000 +ND 53 6.78702478e+005 8.64803225e+006 0.00000000e+000 +ND 54 6.78258873e+005 8.64871126e+006 0.00000000e+000 +ND 55 6.78357934e+005 8.64727123e+006 0.00000000e+000 +ND 56 6.75260500e+005 8.64955850e+006 0.00000000e+000 +ND 57 6.77190437e+005 8.64870413e+006 0.00000000e+000 +ND 58 6.77586972e+005 8.64770291e+006 0.00000000e+000 +ND 59 6.76122000e+005 8.64869700e+006 0.00000000e+000 +ND 60 6.76854486e+005 8.64819996e+006 0.00000000e+000 +ND 61 6.82976068e+005 8.65227984e+006 0.00000000e+000 +ND 62 6.82590500e+005 8.65270478e+006 0.00000000e+000 +ND 63 6.81956199e+005 8.65226547e+006 0.00000000e+000 +ND 64 6.82341767e+005 8.65184052e+006 0.00000000e+000 +ND 65 6.81541500e+005 8.65269833e+006 0.00000000e+000 +ND 66 6.80936331e+005 8.65225109e+006 0.00000000e+000 +ND 67 6.81351030e+005 8.65181823e+006 0.00000000e+000 +ND 68 6.82672068e+005 8.65143284e+006 0.00000000e+000 +ND 69 6.81655449e+005 8.65139906e+006 0.00000000e+000 +ND 70 6.81985750e+005 8.65099138e+006 0.00000000e+000 +ND 71 6.80638831e+005 8.65136529e+006 0.00000000e+000 +ND 72 6.80943250e+005 8.65094613e+006 0.00000000e+000 +ND 73 6.80492500e+005 8.65269189e+006 0.00000000e+000 +ND 74 6.79916462e+005 8.65223672e+006 0.00000000e+000 +ND 75 6.80360292e+005 8.65179593e+006 0.00000000e+000 +ND 76 6.82014250e+005 8.65059975e+006 0.00000000e+000 +ND 77 6.82043250e+005 8.65023775e+006 0.00000000e+000 +ND 78 6.82536000e+005 8.65065200e+006 0.00000000e+000 +ND 79 6.81493000e+005 8.65057713e+006 0.00000000e+000 +ND 80 6.82058984e+005 8.64948724e+006 0.00000000e+000 +ND 81 6.82556905e+005 8.64990244e+006 0.00000000e+000 +ND 82 6.81545329e+005 8.64982254e+006 0.00000000e+000 +ND 83 6.80971750e+005 8.65055450e+006 0.00000000e+000 +ND 84 6.79622212e+005 8.65133152e+006 0.00000000e+000 +ND 85 6.79900750e+005 8.65090088e+006 0.00000000e+000 +ND 86 6.79443500e+005 8.65268544e+006 0.00000000e+000 +ND 87 6.78896593e+005 8.65222235e+006 0.00000000e+000 +ND 88 6.79369555e+005 8.65177363e+006 0.00000000e+000 +ND 89 6.81998401e+005 8.64873621e+006 0.00000000e+000 +ND 90 6.82540715e+005 8.64912733e+006 0.00000000e+000 +ND 91 6.81516671e+005 8.64909612e+006 0.00000000e+000 +ND 92 6.80999750e+005 8.65013325e+006 0.00000000e+000 +ND 93 6.80450000e+005 8.65050225e+006 0.00000000e+000 +ND 94 6.81079333e+005 8.64943193e+006 0.00000000e+000 +ND 95 6.80533753e+005 8.64974264e+006 0.00000000e+000 +ND 96 6.79928750e+005 8.65047963e+006 0.00000000e+000 +ND 97 6.78605593e+005 8.65129774e+006 0.00000000e+000 +ND 98 6.78858250e+005 8.65085563e+006 0.00000000e+000 +ND 99 6.78394500e+005 8.65267900e+006 0.00000000e+000 +ND 100 6.77876725e+005 8.65220798e+006 0.00000000e+000 +ND 101 6.78378818e+005 8.65175134e+006 0.00000000e+000 +ND 102 6.77345500e+005 8.65267256e+006 0.00000000e+000 +ND 103 6.76856856e+005 8.65219361e+006 0.00000000e+000 +ND 104 6.77388081e+005 8.65172904e+006 0.00000000e+000 +ND 105 6.82522715e+005 8.64826558e+006 0.00000000e+000 +ND 106 6.81988496e+005 8.64826202e+006 0.00000000e+000 +ND 107 6.80929965e+005 8.64872908e+006 0.00000000e+000 +ND 108 6.80492627e+005 8.64906490e+006 0.00000000e+000 +ND 109 6.79956250e+005 8.65002875e+006 0.00000000e+000 +ND 110 6.79407000e+005 8.65042738e+006 0.00000000e+000 +ND 111 6.80099681e+005 8.64937663e+006 0.00000000e+000 +ND 112 6.79522178e+005 8.64966274e+006 0.00000000e+000 +ND 113 6.78885750e+005 8.65040475e+006 0.00000000e+000 +ND 114 6.78110225e+005 8.65128659e+006 0.00000000e+000 +ND 115 6.77093606e+005 8.65125282e+006 0.00000000e+000 +ND 116 6.77815750e+005 8.65081038e+006 0.00000000e+000 +ND 117 6.76296500e+005 8.65266611e+006 0.00000000e+000 +ND 118 6.75836987e+005 8.65217924e+006 0.00000000e+000 +ND 119 6.76397343e+005 8.65170674e+006 0.00000000e+000 +ND 120 6.81421091e+005 8.64779266e+006 0.00000000e+000 +ND 121 6.81945405e+005 8.64732203e+006 0.00000000e+000 +ND 122 6.82502905e+005 8.64731719e+006 0.00000000e+000 +ND 123 6.81935500e+005 8.64684783e+006 0.00000000e+000 +ND 124 6.74817119e+005 8.65216487e+006 0.00000000e+000 +ND 125 6.74198500e+005 8.65265322e+006 0.00000000e+000 +ND 126 6.73797250e+005 8.65215050e+006 0.00000000e+000 +ND 127 6.74415869e+005 8.65166215e+006 0.00000000e+000 +ND 128 6.75247500e+005 8.65265967e+006 0.00000000e+000 +ND 129 6.75406606e+005 8.65168445e+006 0.00000000e+000 +ND 130 6.80886873e+005 8.64778909e+006 0.00000000e+000 +ND 131 6.79861528e+005 8.64872195e+006 0.00000000e+000 +ND 132 6.79468583e+005 8.64903368e+006 0.00000000e+000 +ND 133 6.78364000e+005 8.65035250e+006 0.00000000e+000 +ND 134 6.78912750e+005 8.64992425e+006 0.00000000e+000 +ND 135 6.79000428e+005 8.64961049e+006 0.00000000e+000 +ND 136 6.77842750e+005 8.65032988e+006 0.00000000e+000 +ND 137 6.76076987e+005 8.65121905e+006 0.00000000e+000 +ND 138 6.76773250e+005 8.65076513e+006 0.00000000e+000 +ND 139 6.80329373e+005 8.64779393e+006 0.00000000e+000 +ND 140 6.80820500e+005 8.64685750e+006 0.00000000e+000 +ND 141 6.75060369e+005 8.65118527e+006 0.00000000e+000 +ND 142 6.74043750e+005 8.65115150e+006 0.00000000e+000 +ND 143 6.74688250e+005 8.65067463e+006 0.00000000e+000 +ND 144 6.75730750e+005 8.65071988e+006 0.00000000e+000 +ND 145 6.80006740e+005 8.64826414e+006 0.00000000e+000 +ND 146 6.79940367e+005 8.64733255e+006 0.00000000e+000 +ND 147 6.79472522e+005 8.64826057e+006 0.00000000e+000 +ND 148 6.78859155e+005 8.64929519e+006 0.00000000e+000 +ND 149 6.77321000e+005 8.65027763e+006 0.00000000e+000 +ND 150 6.77869250e+005 8.64981975e+006 0.00000000e+000 +ND 151 6.78793091e+005 8.64871482e+006 0.00000000e+000 +ND 152 6.78324937e+005 8.64929163e+006 0.00000000e+000 +ND 153 6.76799750e+005 8.65025500e+006 0.00000000e+000 +ND 154 6.79382867e+005 8.64733738e+006 0.00000000e+000 +ND 155 6.79705500e+005 8.64686717e+006 0.00000000e+000 +ND 156 6.74440375e+005 8.65037863e+006 0.00000000e+000 +ND 157 6.74961625e+005 8.65040125e+006 0.00000000e+000 +ND 158 6.75756750e+005 8.65018013e+006 0.00000000e+000 +ND 159 6.76278000e+005 8.65020275e+006 0.00000000e+000 +ND 160 6.76825750e+005 8.64971525e+006 0.00000000e+000 +ND 161 6.79014894e+005 8.64837532e+006 0.00000000e+000 +ND 162 6.79160106e+005 8.64791750e+006 0.00000000e+000 +ND 163 6.78854829e+005 8.64777711e+006 0.00000000e+000 +ND 164 6.79312457e+005 8.64766237e+006 0.00000000e+000 +ND 165 6.79077590e+005 8.64719699e+006 0.00000000e+000 +ND 166 6.78480675e+005 8.64837175e+006 0.00000000e+000 +ND 167 6.77724655e+005 8.64870769e+006 0.00000000e+000 +ND 168 6.77803187e+005 8.64923938e+006 0.00000000e+000 +ND 169 6.77268968e+005 8.64923581e+006 0.00000000e+000 +ND 170 6.78530206e+005 8.64765174e+006 0.00000000e+000 +ND 171 6.78682557e+005 8.64739660e+006 0.00000000e+000 +ND 172 6.78752967e+005 8.64707161e+006 0.00000000e+000 +ND 173 6.75235000e+005 8.65012788e+006 0.00000000e+000 +ND 174 6.75782250e+005 8.64961075e+006 0.00000000e+000 +ND 175 6.74987125e+005 8.64983188e+006 0.00000000e+000 +ND 176 6.76656218e+005 8.64870056e+006 0.00000000e+000 +ND 177 6.76747218e+005 8.64918356e+006 0.00000000e+000 +ND 178 6.76213000e+005 8.64918000e+006 0.00000000e+000 +ND 179 6.77922923e+005 8.64820709e+006 0.00000000e+000 +ND 180 6.78144725e+005 8.64786758e+006 0.00000000e+000 +ND 181 6.77972453e+005 8.64748707e+006 0.00000000e+000 +ND 182 6.77388704e+005 8.64820352e+006 0.00000000e+000 +ND 183 6.77022461e+005 8.64845204e+006 0.00000000e+000 +ND 184 6.77220729e+005 8.64795143e+006 0.00000000e+000 +ND 185 6.76488243e+005 8.64844848e+006 0.00000000e+000 +ND 186 6.75691250e+005 8.64912775e+006 0.00000000e+000 diff --git a/RMAGEN/GEOMETRY-FILE-FORMATS.txt b/RMAGEN/GEOMETRY-FILE-FORMATS.txt new file mode 100644 index 0000000..4d2eb2f --- /dev/null +++ b/RMAGEN/GEOMETRY-FILE-FORMATS.txt @@ -0,0 +1,33 @@ +FILE FORMAT FOR GEOMETRY FILE + + READ (IFILE,ERR=63,END=63) + + 1 N,M,((CORDS(J,K),K=1,2), ALFA(J),AO(J),J=1,N), + 2 ((NOPS(J,K),K=1,8),IMAT(J),TH(J),NFIXHS(J),J=1,M), + + (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,N) + +c +c Part 1 of the geo file contains +c +c 1 N Number of nodes on geo file INTEGER*4 +c 2 M Number of elements on "geo" file INTEGER*4 +c 3 CORD(J,1) x-coordinate - node J REAL*8 ARRAY SIZE (NUMBER OF NODES, 2) +C 4 CORD(J,2) y-coordinate - node J REAL*8 ARRAY SIZE (NUMBER OF NODES) +C 5 ALFA(J) Boundary slope - node j REAL*4 ARRAY SIZE (NUMBER OF NODES) +C 6 AO(J) Bed elevation - node j REAL*4 ARRAY SIZE (NUMBER OF NODES) +C 7 NOP(J,K) Nodal connections, counterclockwise - element j INTEGER*8 ARRAY SIZE (NUMBER OF ELEMENTS,8) +C 8 IMAT(J) Type number - element j INTEGER*2 ARRAY SIZE (NUMBER OF ELEMENTS) +C 9 TH(J) Principal direction for eddy viscosity - element j REAL*4 ARRAY SIZE (NUMBER OF ELEMENTS) +C 10 NFIXHS(J) Ordering sequence for equation formation and solution - counter j INTEGER*4 ARRAY SIZE (NUMBER OF ELEMENTS) +C 11 WIDTH(J) Nodal bed width for 1-D elements REAL*4 ARRAY SIZE (NUMBER OF NODES) +C 12 SS1(J) Nodal left side slope for 1-D elements REAL*4 ARRAY SIZE (NUMBER OF NODES) +C 13 SS2(J) Nodal right side slope for 1-D elements REAL*4 ARRAY SIZE (NUMBER OF NODES) +C 14 WIDS(J) Nodal storage width for 1-D elements REAL*4 ARRAY SIZE (NUMBER OF NODES) + +The remainder of the file contains more information associated with 1-D elements + + +C 11 WIDTH(J) Nodal bed width ( for 1-D nodes) - node j +C 12 SS1(J) Nodal left side slope ( for 1-D nodes) - node j +C 13 SS2(J) Nodal right side slope ( for 1-D nodes) - node j +C 14 WIDS(J) Off channel storage width - node j (see appendix to documentation) diff --git a/RMAGEN/TRANSFER/RMAGENV83G.exe b/RMAGEN/TRANSFER/RMAGENV83G.exe new file mode 100644 index 0000000..04933f9 Binary files /dev/null and b/RMAGEN/TRANSFER/RMAGENV83G.exe differ diff --git a/junctions/junctions.html b/junctions/junctions.html new file mode 100644 index 0000000..d0ec250 --- /dev/null +++ b/junctions/junctions.html @@ -0,0 +1,29 @@ + + + + + + + +Created by Camtasia Studio 8 + + + + + + + + + + diff --git a/junctions/junctions.mp4 b/junctions/junctions.mp4 new file mode 100644 index 0000000..9639b66 Binary files /dev/null and b/junctions/junctions.mp4 differ diff --git a/junctions/junctions_First_Frame.png b/junctions/junctions_First_Frame.png new file mode 100644 index 0000000..1c20443 Binary files /dev/null and b/junctions/junctions_First_Frame.png differ diff --git a/junctions/junctions_Thumbnails.png b/junctions/junctions_Thumbnails.png new file mode 100644 index 0000000..e69de29 diff --git a/junctions/junctions_config.xml b/junctions/junctions_config.xml new file mode 100644 index 0000000..2230027 --- /dev/null +++ b/junctions/junctions_config.xml @@ -0,0 +1,36 @@ + + + + + + + + English + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/junctions/junctions_controller.swf b/junctions/junctions_controller.swf new file mode 100644 index 0000000..985cc81 Binary files /dev/null and b/junctions/junctions_controller.swf differ diff --git a/junctions/junctions_embed.css b/junctions/junctions_embed.css new file mode 100644 index 0000000..288441b --- /dev/null +++ b/junctions/junctions_embed.css @@ -0,0 +1,28 @@ +@charset "utf-8"; + +#tsc_player { + z-index: 9999; +} + +.tscplayer_inline { + position:static; + margin: 30px; + width: 852px; + height: 480px; + z-index:auto; +} + +.tscplayer_fullframe { + position:absolute; + top: 0px; + left: 0px; + margin: 0px; + padding: 0px; + z-index: 9999; +} + +@media screen and (max-width: 852px) { + .tscplayer_inline { + width: 100%; + } +} diff --git a/junctions/junctions_player.html b/junctions/junctions_player.html new file mode 100644 index 0000000..20df131 --- /dev/null +++ b/junctions/junctions_player.html @@ -0,0 +1,75 @@ + + + + + + + + + + + + + + + + +
+ +
+ + + + + \ No newline at end of file diff --git a/junctions/scripts/config_xml.js b/junctions/scripts/config_xml.js new file mode 100644 index 0000000..b139401 --- /dev/null +++ b/junctions/scripts/config_xml.js @@ -0,0 +1,38 @@ +var TSC = TSC || {}; + +TSC.embedded_config_xml = '\ + \ + \ + \ + \ + \ + \ + English\ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ + \ +'; diff --git a/junctions/scripts/techsmith-smart-player.min.js b/junctions/scripts/techsmith-smart-player.min.js new file mode 100644 index 0000000..913f07c --- /dev/null +++ b/junctions/scripts/techsmith-smart-player.min.js @@ -0,0 +1,58 @@ +/*! TechSmith Smart Player v3.19.2 */ +/*! jQuery v1.10.2 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license + */ +(function(e,t){var n,r,i=typeof t,o=e.location,a=e.document,s=a.documentElement,l=e.jQuery,u=e.$,c={},p=[],f="1.10.2",d=p.concat,h=p.push,g=p.slice,m=p.indexOf,y=c.toString,v=c.hasOwnProperty,b=f.trim,x=function(e,t){return new x.fn.init(e,t,r)},w=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,T=/\S+/g,C=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,N=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,k=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,E=/^[\],:{}\s]*$/,S=/(?:^|:|,)(?:\s*\[)+/g,A=/\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,j=/"[^"\\\r\n]*"|true|false|null|-?(?:\d+\.|)\d+(?:[eE][+-]?\d+|)/g,D=/^-ms-/,L=/-([\da-z])/gi,H=function(e,t){return t.toUpperCase()},q=function(e){(a.addEventListener||"load"===e.type||"complete"===a.readyState)&&(_(),x.ready())},_=function(){a.addEventListener?(a.removeEventListener("DOMContentLoaded",q,!1),e.removeEventListener("load",q,!1)):(a.detachEvent("onreadystatechange",q),e.detachEvent("onload",q))};x.fn=x.prototype={jquery:f,constructor:x,init:function(e,n,r){var i,o;if(!e)return this;if("string"==typeof e){if(i="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:N.exec(e),!i||!i[1]&&n)return!n||n.jquery?(n||r).find(e):this.constructor(n).find(e);if(i[1]){if(n=n instanceof x?n[0]:n,x.merge(this,x.parseHTML(i[1],n&&n.nodeType?n.ownerDocument||n:a,!0)),k.test(i[1])&&x.isPlainObject(n))for(i in n)x.isFunction(this[i])?this[i](n[i]):this.attr(i,n[i]);return this}if(o=a.getElementById(i[2]),o&&o.parentNode){if(o.id!==i[2])return r.find(e);this.length=1,this[0]=o}return this.context=a,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?r.ready(e):(e.selector!==t&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return g.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(g.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,n,r,i,o,a,s=arguments[0]||{},l=1,u=arguments.length,c=!1;for("boolean"==typeof s&&(c=s,s=arguments[1]||{},l=2),"object"==typeof s||x.isFunction(s)||(s={}),u===l&&(s=this,--l);u>l;l++)if(null!=(o=arguments[l]))for(i in o)e=s[i],r=o[i],s!==r&&(c&&r&&(x.isPlainObject(r)||(n=x.isArray(r)))?(n?(n=!1,a=e&&x.isArray(e)?e:[]):a=e&&x.isPlainObject(e)?e:{},s[i]=x.extend(c,a,r)):r!==t&&(s[i]=r));return s},x.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=l),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){if(e===!0?!--x.readyWait:!x.isReady){if(!a.body)return setTimeout(x.ready);x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(a,[x]),x.fn.trigger&&x(a).trigger("ready").off("ready"))}},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray||function(e){return"array"===x.type(e)},isWindow:function(e){return null!=e&&e==e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?c[y.call(e)]||"object":typeof e},isPlainObject:function(e){var n;if(!e||"object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!v.call(e,"constructor")&&!v.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(r){return!1}if(x.support.ownLast)for(n in e)return v.call(e,n);for(n in e);return n===t||v.call(e,n)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||a;var r=k.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:function(n){return e.JSON&&e.JSON.parse?e.JSON.parse(n):null===n?n:"string"==typeof n&&(n=x.trim(n),n&&E.test(n.replace(A,"@").replace(j,"]").replace(S,"")))?Function("return "+n)():(x.error("Invalid JSON: "+n),t)},parseXML:function(n){var r,i;if(!n||"string"!=typeof n)return null;try{e.DOMParser?(i=new DOMParser,r=i.parseFromString(n,"text/xml")):(r=new ActiveXObject("Microsoft.XMLDOM"),r.async="false",r.loadXML(n))}catch(o){r=t}return r&&r.documentElement&&!r.getElementsByTagName("parsererror").length||x.error("Invalid XML: "+n),r},noop:function(){},globalEval:function(t){t&&x.trim(t)&&(e.execScript||function(t){e.eval.call(e,t)})(t)},camelCase:function(e){return e.replace(D,"ms-").replace(L,H)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,a=M(e);if(n){if(a){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(a){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:b&&!b.call("\ufeff\u00a0")?function(e){return null==e?"":b.call(e)}:function(e){return null==e?"":(e+"").replace(C,"")},makeArray:function(e,t){var n=t||[];return null!=e&&(M(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){var r;if(t){if(m)return m.call(t,e,n);for(r=t.length,n=n?0>n?Math.max(0,r+n):n:0;r>n;n++)if(n in t&&t[n]===e)return n}return-1},merge:function(e,n){var r=n.length,i=e.length,o=0;if("number"==typeof r)for(;r>o;o++)e[i++]=n[o];else while(n[o]!==t)e[i++]=n[o++];return e.length=i,e},grep:function(e,t,n){var r,i=[],o=0,a=e.length;for(n=!!n;a>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,a=M(e),s=[];if(a)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(s[s.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(s[s.length]=r);return d.apply([],s)},guid:1,proxy:function(e,n){var r,i,o;return"string"==typeof n&&(o=e[n],n=e,e=o),x.isFunction(e)?(r=g.call(arguments,2),i=function(){return e.apply(n||this,r.concat(g.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):t},access:function(e,n,r,i,o,a,s){var l=0,u=e.length,c=null==r;if("object"===x.type(r)){o=!0;for(l in r)x.access(e,n,l,r[l],!0,a,s)}else if(i!==t&&(o=!0,x.isFunction(i)||(s=!0),c&&(s?(n.call(e,i),n=null):(c=n,n=function(e,t,n){return c.call(x(e),n)})),n))for(;u>l;l++)n(e[l],r,s?i:i.call(e[l],l,n(e[l],r)));return o?e:c?n.call(e):u?n(e[0],r):a},now:function(){return(new Date).getTime()},swap:function(e,t,n,r){var i,o,a={};for(o in t)a[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=a[o];return i}}),x.ready.promise=function(t){if(!n)if(n=x.Deferred(),"complete"===a.readyState)setTimeout(x.ready);else if(a.addEventListener)a.addEventListener("DOMContentLoaded",q,!1),e.addEventListener("load",q,!1);else{a.attachEvent("onreadystatechange",q),e.attachEvent("onload",q);var r=!1;try{r=null==e.frameElement&&a.documentElement}catch(i){}r&&r.doScroll&&function o(){if(!x.isReady){try{r.doScroll("left")}catch(e){return setTimeout(o,50)}_(),x.ready()}}()}return n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){c["[object "+t+"]"]=t.toLowerCase()});function M(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}r=x(a),function(e,t){var n,r,i,o,a,s,l,u,c,p,f,d,h,g,m,y,v,b="sizzle"+-new Date,w=e.document,T=0,C=0,N=st(),k=st(),E=st(),S=!1,A=function(e,t){return e===t?(S=!0,0):0},j=typeof t,D=1<<31,L={}.hasOwnProperty,H=[],q=H.pop,_=H.push,M=H.push,O=H.slice,F=H.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},B="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",P="[\\x20\\t\\r\\n\\f]",R="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",W=R.replace("w","w#"),$="\\["+P+"*("+R+")"+P+"*(?:([*^$|!~]?=)"+P+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+W+")|)|)"+P+"*\\]",I=":("+R+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+$.replace(3,8)+")*)|.*)\\)|)",z=RegExp("^"+P+"+|((?:^|[^\\\\])(?:\\\\.)*)"+P+"+$","g"),X=RegExp("^"+P+"*,"+P+"*"),U=RegExp("^"+P+"*([>+~]|"+P+")"+P+"*"),V=RegExp(P+"*[+~]"),Y=RegExp("="+P+"*([^\\]'\"]*)"+P+"*\\]","g"),J=RegExp(I),G=RegExp("^"+W+"$"),Q={ID:RegExp("^#("+R+")"),CLASS:RegExp("^\\.("+R+")"),TAG:RegExp("^("+R.replace("w","w*")+")"),ATTR:RegExp("^"+$),PSEUDO:RegExp("^"+I),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+P+"*(even|odd|(([+-]|)(\\d*)n|)"+P+"*(?:([+-]|)"+P+"*(\\d+)|))"+P+"*\\)|)","i"),bool:RegExp("^(?:"+B+")$","i"),needsContext:RegExp("^"+P+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+P+"*((?:-\\d)?\\d*)"+P+"*\\)|)(?=[^-]|$)","i")},K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,et=/^(?:input|select|textarea|button)$/i,tt=/^h\d$/i,nt=/'|\\/g,rt=RegExp("\\\\([\\da-f]{1,6}"+P+"?|("+P+")|.)","ig"),it=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:0>r?String.fromCharCode(r+65536):String.fromCharCode(55296|r>>10,56320|1023&r)};try{M.apply(H=O.call(w.childNodes),w.childNodes),H[w.childNodes.length].nodeType}catch(ot){M={apply:H.length?function(e,t){_.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function at(e,t,n,i){var o,a,s,l,u,c,d,m,y,x;if((t?t.ownerDocument||t:w)!==f&&p(t),t=t||f,n=n||[],!e||"string"!=typeof e)return n;if(1!==(l=t.nodeType)&&9!==l)return[];if(h&&!i){if(o=Z.exec(e))if(s=o[1]){if(9===l){if(a=t.getElementById(s),!a||!a.parentNode)return n;if(a.id===s)return n.push(a),n}else if(t.ownerDocument&&(a=t.ownerDocument.getElementById(s))&&v(t,a)&&a.id===s)return n.push(a),n}else{if(o[2])return M.apply(n,t.getElementsByTagName(e)),n;if((s=o[3])&&r.getElementsByClassName&&t.getElementsByClassName)return M.apply(n,t.getElementsByClassName(s)),n}if(r.qsa&&(!g||!g.test(e))){if(m=d=b,y=t,x=9===l&&e,1===l&&"object"!==t.nodeName.toLowerCase()){c=mt(e),(d=t.getAttribute("id"))?m=d.replace(nt,"\\$&"):t.setAttribute("id",m),m="[id='"+m+"'] ",u=c.length;while(u--)c[u]=m+yt(c[u]);y=V.test(e)&&t.parentNode||t,x=c.join(",")}if(x)try{return M.apply(n,y.querySelectorAll(x)),n}catch(T){}finally{d||t.removeAttribute("id")}}}return kt(e.replace(z,"$1"),t,n,i)}function st(){var e=[];function t(n,r){return e.push(n+=" ")>o.cacheLength&&delete t[e.shift()],t[n]=r}return t}function lt(e){return e[b]=!0,e}function ut(e){var t=f.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function ct(e,t){var n=e.split("|"),r=e.length;while(r--)o.attrHandle[n[r]]=t}function pt(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function ft(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function dt(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function ht(e){return lt(function(t){return t=+t,lt(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}s=at.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},r=at.support={},p=at.setDocument=function(e){var n=e?e.ownerDocument||e:w,i=n.defaultView;return n!==f&&9===n.nodeType&&n.documentElement?(f=n,d=n.documentElement,h=!s(n),i&&i.attachEvent&&i!==i.top&&i.attachEvent("onbeforeunload",function(){p()}),r.attributes=ut(function(e){return e.className="i",!e.getAttribute("className")}),r.getElementsByTagName=ut(function(e){return e.appendChild(n.createComment("")),!e.getElementsByTagName("*").length}),r.getElementsByClassName=ut(function(e){return e.innerHTML="
",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),r.getById=ut(function(e){return d.appendChild(e).id=b,!n.getElementsByName||!n.getElementsByName(b).length}),r.getById?(o.find.ID=function(e,t){if(typeof t.getElementById!==j&&h){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},o.filter.ID=function(e){var t=e.replace(rt,it);return function(e){return e.getAttribute("id")===t}}):(delete o.find.ID,o.filter.ID=function(e){var t=e.replace(rt,it);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),o.find.TAG=r.getElementsByTagName?function(e,n){return typeof n.getElementsByTagName!==j?n.getElementsByTagName(e):t}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},o.find.CLASS=r.getElementsByClassName&&function(e,n){return typeof n.getElementsByClassName!==j&&h?n.getElementsByClassName(e):t},m=[],g=[],(r.qsa=K.test(n.querySelectorAll))&&(ut(function(e){e.innerHTML="",e.querySelectorAll("[selected]").length||g.push("\\["+P+"*(?:value|"+B+")"),e.querySelectorAll(":checked").length||g.push(":checked")}),ut(function(e){var t=n.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&g.push("[*^$]="+P+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||g.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),g.push(",.*:")})),(r.matchesSelector=K.test(y=d.webkitMatchesSelector||d.mozMatchesSelector||d.oMatchesSelector||d.msMatchesSelector))&&ut(function(e){r.disconnectedMatch=y.call(e,"div"),y.call(e,"[s!='']:x"),m.push("!=",I)}),g=g.length&&RegExp(g.join("|")),m=m.length&&RegExp(m.join("|")),v=K.test(d.contains)||d.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},A=d.compareDocumentPosition?function(e,t){if(e===t)return S=!0,0;var i=t.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(t);return i?1&i||!r.sortDetached&&t.compareDocumentPosition(e)===i?e===n||v(w,e)?-1:t===n||v(w,t)?1:c?F.call(c,e)-F.call(c,t):0:4&i?-1:1:e.compareDocumentPosition?-1:1}:function(e,t){var r,i=0,o=e.parentNode,a=t.parentNode,s=[e],l=[t];if(e===t)return S=!0,0;if(!o||!a)return e===n?-1:t===n?1:o?-1:a?1:c?F.call(c,e)-F.call(c,t):0;if(o===a)return pt(e,t);r=e;while(r=r.parentNode)s.unshift(r);r=t;while(r=r.parentNode)l.unshift(r);while(s[i]===l[i])i++;return i?pt(s[i],l[i]):s[i]===w?-1:l[i]===w?1:0},n):f},at.matches=function(e,t){return at(e,null,null,t)},at.matchesSelector=function(e,t){if((e.ownerDocument||e)!==f&&p(e),t=t.replace(Y,"='$1']"),!(!r.matchesSelector||!h||m&&m.test(t)||g&&g.test(t)))try{var n=y.call(e,t);if(n||r.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(i){}return at(t,f,null,[e]).length>0},at.contains=function(e,t){return(e.ownerDocument||e)!==f&&p(e),v(e,t)},at.attr=function(e,n){(e.ownerDocument||e)!==f&&p(e);var i=o.attrHandle[n.toLowerCase()],a=i&&L.call(o.attrHandle,n.toLowerCase())?i(e,n,!h):t;return a===t?r.attributes||!h?e.getAttribute(n):(a=e.getAttributeNode(n))&&a.specified?a.value:null:a},at.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},at.uniqueSort=function(e){var t,n=[],i=0,o=0;if(S=!r.detectDuplicates,c=!r.sortStable&&e.slice(0),e.sort(A),S){while(t=e[o++])t===e[o]&&(i=n.push(o));while(i--)e.splice(n[i],1)}return e},a=at.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=a(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=a(t);return n},o=at.selectors={cacheLength:50,createPseudo:lt,match:Q,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(rt,it),e[3]=(e[4]||e[5]||"").replace(rt,it),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||at.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&at.error(e[0]),e},PSEUDO:function(e){var n,r=!e[5]&&e[2];return Q.CHILD.test(e[0])?null:(e[3]&&e[4]!==t?e[2]=e[4]:r&&J.test(r)&&(n=mt(r,!0))&&(n=r.indexOf(")",r.length-n)-r.length)&&(e[0]=e[0].slice(0,n),e[2]=r.slice(0,n)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(rt,it).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=N[e+" "];return t||(t=RegExp("(^|"+P+")"+e+"("+P+"|$)"))&&N(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=at.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,l){var u,c,p,f,d,h,g=o!==a?"nextSibling":"previousSibling",m=t.parentNode,y=s&&t.nodeName.toLowerCase(),v=!l&&!s;if(m){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?m.firstChild:m.lastChild],a&&v){c=m[b]||(m[b]={}),u=c[e]||[],d=u[0]===T&&u[1],f=u[0]===T&&u[2],p=d&&m.childNodes[d];while(p=++d&&p&&p[g]||(f=d=0)||h.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[T,d,f];break}}else if(v&&(u=(t[b]||(t[b]={}))[e])&&u[0]===T)f=u[1];else while(p=++d&&p&&p[g]||(f=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(v&&((p[b]||(p[b]={}))[e]=[T,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=o.pseudos[e]||o.setFilters[e.toLowerCase()]||at.error("unsupported pseudo: "+e);return r[b]?r(t):r.length>1?(n=[e,e,"",t],o.setFilters.hasOwnProperty(e.toLowerCase())?lt(function(e,n){var i,o=r(e,t),a=o.length;while(a--)i=F.call(e,o[a]),e[i]=!(n[i]=o[a])}):function(e){return r(e,0,n)}):r}},pseudos:{not:lt(function(e){var t=[],n=[],r=l(e.replace(z,"$1"));return r[b]?lt(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:lt(function(e){return function(t){return at(e,t).length>0}}),contains:lt(function(e){return function(t){return(t.textContent||t.innerText||a(t)).indexOf(e)>-1}}),lang:lt(function(e){return G.test(e||"")||at.error("unsupported lang: "+e),e=e.replace(rt,it).toLowerCase(),function(t){var n;do if(n=h?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===d},focus:function(e){return e===f.activeElement&&(!f.hasFocus||f.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!o.pseudos.empty(e)},header:function(e){return tt.test(e.nodeName)},input:function(e){return et.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:ht(function(){return[0]}),last:ht(function(e,t){return[t-1]}),eq:ht(function(e,t,n){return[0>n?n+t:n]}),even:ht(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:ht(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:ht(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:ht(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}},o.pseudos.nth=o.pseudos.eq;for(n in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})o.pseudos[n]=ft(n);for(n in{submit:!0,reset:!0})o.pseudos[n]=dt(n);function gt(){}gt.prototype=o.filters=o.pseudos,o.setFilters=new gt;function mt(e,t){var n,r,i,a,s,l,u,c=k[e+" "];if(c)return t?0:c.slice(0);s=e,l=[],u=o.preFilter;while(s){(!n||(r=X.exec(s)))&&(r&&(s=s.slice(r[0].length)||s),l.push(i=[])),n=!1,(r=U.exec(s))&&(n=r.shift(),i.push({value:n,type:r[0].replace(z," ")}),s=s.slice(n.length));for(a in o.filter)!(r=Q[a].exec(s))||u[a]&&!(r=u[a](r))||(n=r.shift(),i.push({value:n,type:a,matches:r}),s=s.slice(n.length));if(!n)break}return t?s.length:s?at.error(e):k(e,l).slice(0)}function yt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function vt(e,t,n){var r=t.dir,o=n&&"parentNode"===r,a=C++;return t.first?function(t,n,i){while(t=t[r])if(1===t.nodeType||o)return e(t,n,i)}:function(t,n,s){var l,u,c,p=T+" "+a;if(s){while(t=t[r])if((1===t.nodeType||o)&&e(t,n,s))return!0}else while(t=t[r])if(1===t.nodeType||o)if(c=t[b]||(t[b]={}),(u=c[r])&&u[0]===p){if((l=u[1])===!0||l===i)return l===!0}else if(u=c[r]=[p],u[1]=e(t,n,s)||i,u[1]===!0)return!0}}function bt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,a=[],s=0,l=e.length,u=null!=t;for(;l>s;s++)(o=e[s])&&(!n||n(o,r,i))&&(a.push(o),u&&t.push(s));return a}function wt(e,t,n,r,i,o){return r&&!r[b]&&(r=wt(r)),i&&!i[b]&&(i=wt(i,o)),lt(function(o,a,s,l){var u,c,p,f=[],d=[],h=a.length,g=o||Nt(t||"*",s.nodeType?[s]:s,[]),m=!e||!o&&t?g:xt(g,f,e,s,l),y=n?i||(o?e:h||r)?[]:a:m;if(n&&n(m,y,s,l),r){u=xt(y,d),r(u,[],s,l),c=u.length;while(c--)(p=u[c])&&(y[d[c]]=!(m[d[c]]=p))}if(o){if(i||e){if(i){u=[],c=y.length;while(c--)(p=y[c])&&u.push(m[c]=p);i(null,y=[],u,l)}c=y.length;while(c--)(p=y[c])&&(u=i?F.call(o,p):f[c])>-1&&(o[u]=!(a[u]=p))}}else y=xt(y===a?y.splice(h,y.length):y),i?i(null,a,y,l):M.apply(a,y)})}function Tt(e){var t,n,r,i=e.length,a=o.relative[e[0].type],s=a||o.relative[" "],l=a?1:0,c=vt(function(e){return e===t},s,!0),p=vt(function(e){return F.call(t,e)>-1},s,!0),f=[function(e,n,r){return!a&&(r||n!==u)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;i>l;l++)if(n=o.relative[e[l].type])f=[vt(bt(f),n)];else{if(n=o.filter[e[l].type].apply(null,e[l].matches),n[b]){for(r=++l;i>r;r++)if(o.relative[e[r].type])break;return wt(l>1&&bt(f),l>1&&yt(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(z,"$1"),n,r>l&&Tt(e.slice(l,r)),i>r&&Tt(e=e.slice(r)),i>r&&yt(e))}f.push(n)}return bt(f)}function Ct(e,t){var n=0,r=t.length>0,a=e.length>0,s=function(s,l,c,p,d){var h,g,m,y=[],v=0,b="0",x=s&&[],w=null!=d,C=u,N=s||a&&o.find.TAG("*",d&&l.parentNode||l),k=T+=null==C?1:Math.random()||.1;for(w&&(u=l!==f&&l,i=n);null!=(h=N[b]);b++){if(a&&h){g=0;while(m=e[g++])if(m(h,l,c)){p.push(h);break}w&&(T=k,i=++n)}r&&((h=!m&&h)&&v--,s&&x.push(h))}if(v+=b,r&&b!==v){g=0;while(m=t[g++])m(x,y,l,c);if(s){if(v>0)while(b--)x[b]||y[b]||(y[b]=q.call(p));y=xt(y)}M.apply(p,y),w&&!s&&y.length>0&&v+t.length>1&&at.uniqueSort(p)}return w&&(T=k,u=C),x};return r?lt(s):s}l=at.compile=function(e,t){var n,r=[],i=[],o=E[e+" "];if(!o){t||(t=mt(e)),n=t.length;while(n--)o=Tt(t[n]),o[b]?r.push(o):i.push(o);o=E(e,Ct(i,r))}return o};function Nt(e,t,n){var r=0,i=t.length;for(;i>r;r++)at(e,t[r],n);return n}function kt(e,t,n,i){var a,s,u,c,p,f=mt(e);if(!i&&1===f.length){if(s=f[0]=f[0].slice(0),s.length>2&&"ID"===(u=s[0]).type&&r.getById&&9===t.nodeType&&h&&o.relative[s[1].type]){if(t=(o.find.ID(u.matches[0].replace(rt,it),t)||[])[0],!t)return n;e=e.slice(s.shift().value.length)}a=Q.needsContext.test(e)?0:s.length;while(a--){if(u=s[a],o.relative[c=u.type])break;if((p=o.find[c])&&(i=p(u.matches[0].replace(rt,it),V.test(s[0].type)&&t.parentNode||t))){if(s.splice(a,1),e=i.length&&yt(s),!e)return M.apply(n,i),n;break}}}return l(e,f)(i,t,!h,n,V.test(e)),n}r.sortStable=b.split("").sort(A).join("")===b,r.detectDuplicates=S,p(),r.sortDetached=ut(function(e){return 1&e.compareDocumentPosition(f.createElement("div"))}),ut(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||ct("type|href|height|width",function(e,n,r){return r?t:e.getAttribute(n,"type"===n.toLowerCase()?1:2)}),r.attributes&&ut(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||ct("value",function(e,n,r){return r||"input"!==e.nodeName.toLowerCase()?t:e.defaultValue}),ut(function(e){return null==e.getAttribute("disabled")})||ct(B,function(e,n,r){var i;return r?t:(i=e.getAttributeNode(n))&&i.specified?i.value:e[n]===!0?n.toLowerCase():null}),x.find=at,x.expr=at.selectors,x.expr[":"]=x.expr.pseudos,x.unique=at.uniqueSort,x.text=at.getText,x.isXMLDoc=at.isXML,x.contains=at.contains}(e);var O={};function F(e){var t=O[e]={};return x.each(e.match(T)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?O[e]||F(e):x.extend({},e);var n,r,i,o,a,s,l=[],u=!e.once&&[],c=function(t){for(r=e.memory&&t,i=!0,a=s||0,s=0,o=l.length,n=!0;l&&o>a;a++)if(l[a].apply(t[0],t[1])===!1&&e.stopOnFalse){r=!1;break}n=!1,l&&(u?u.length&&c(u.shift()):r?l=[]:p.disable())},p={add:function(){if(l){var t=l.length;(function i(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&p.has(n)||l.push(n):n&&n.length&&"string"!==r&&i(n)})})(arguments),n?o=l.length:r&&(s=t,c(r))}return this},remove:function(){return l&&x.each(arguments,function(e,t){var r;while((r=x.inArray(t,l,r))>-1)l.splice(r,1),n&&(o>=r&&o--,a>=r&&a--)}),this},has:function(e){return e?x.inArray(e,l)>-1:!(!l||!l.length)},empty:function(){return l=[],o=0,this},disable:function(){return l=u=r=t,this},disabled:function(){return!l},lock:function(){return u=t,r||p.disable(),this},locked:function(){return!u},fireWith:function(e,t){return!l||i&&!u||(t=t||[],t=[e,t.slice?t.slice():t],n?u.push(t):c(t)),this},fire:function(){return p.fireWith(this,arguments),this},fired:function(){return!!i}};return p},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var a=o[0],s=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=s&&s.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[a+"With"](this===r?n.promise():this,s?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var a=o[2],s=o[3];r[o[1]]=a.add,s&&a.add(function(){n=s},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=a.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=g.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),a=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?g.call(arguments):r,n===s?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},s,l,u;if(r>1)for(s=Array(r),l=Array(r),u=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(a(t,u,n)).fail(o.reject).progress(a(t,l,s)):--i;return i||o.resolveWith(u,n),o.promise()}}),x.support=function(t){var n,r,o,s,l,u,c,p,f,d=a.createElement("div");if(d.setAttribute("className","t"),d.innerHTML="
a",n=d.getElementsByTagName("*")||[],r=d.getElementsByTagName("a")[0],!r||!r.style||!n.length)return t;s=a.createElement("select"),u=s.appendChild(a.createElement("option")),o=d.getElementsByTagName("input")[0],r.style.cssText="top:1px;float:left;opacity:.5",t.getSetAttribute="t"!==d.className,t.leadingWhitespace=3===d.firstChild.nodeType,t.tbody=!d.getElementsByTagName("tbody").length,t.htmlSerialize=!!d.getElementsByTagName("link").length,t.style=/top/.test(r.getAttribute("style")),t.hrefNormalized="/a"===r.getAttribute("href"),t.opacity=/^0.5/.test(r.style.opacity),t.cssFloat=!!r.style.cssFloat,t.checkOn=!!o.value,t.optSelected=u.selected,t.enctype=!!a.createElement("form").enctype,t.html5Clone="<:nav>"!==a.createElement("nav").cloneNode(!0).outerHTML,t.inlineBlockNeedsLayout=!1,t.shrinkWrapBlocks=!1,t.pixelPosition=!1,t.deleteExpando=!0,t.noCloneEvent=!0,t.reliableMarginRight=!0,t.boxSizingReliable=!0,o.checked=!0,t.noCloneChecked=o.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!u.disabled;try{delete d.test}catch(h){t.deleteExpando=!1}o=a.createElement("input"),o.setAttribute("value",""),t.input=""===o.getAttribute("value"),o.value="t",o.setAttribute("type","radio"),t.radioValue="t"===o.value,o.setAttribute("checked","t"),o.setAttribute("name","t"),l=a.createDocumentFragment(),l.appendChild(o),t.appendChecked=o.checked,t.checkClone=l.cloneNode(!0).cloneNode(!0).lastChild.checked,d.attachEvent&&(d.attachEvent("onclick",function(){t.noCloneEvent=!1}),d.cloneNode(!0).click());for(f in{submit:!0,change:!0,focusin:!0})d.setAttribute(c="on"+f,"t"),t[f+"Bubbles"]=c in e||d.attributes[c].expando===!1;d.style.backgroundClip="content-box",d.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===d.style.backgroundClip;for(f in x(t))break;return t.ownLast="0"!==f,x(function(){var n,r,o,s="padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;",l=a.getElementsByTagName("body")[0];l&&(n=a.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",l.appendChild(n).appendChild(d),d.innerHTML="
t
",o=d.getElementsByTagName("td"),o[0].style.cssText="padding:0;margin:0;border:0;display:none",p=0===o[0].offsetHeight,o[0].style.display="",o[1].style.display="none",t.reliableHiddenOffsets=p&&0===o[0].offsetHeight,d.innerHTML="",d.style.cssText="box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;",x.swap(l,null!=l.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===d.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(d,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(d,null)||{width:"4px"}).width,r=d.appendChild(a.createElement("div")),r.style.cssText=d.style.cssText=s,r.style.marginRight=r.style.width="0",d.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),typeof d.style.zoom!==i&&(d.innerHTML="",d.style.cssText=s+"width:1px;padding:1px;display:inline;zoom:1",t.inlineBlockNeedsLayout=3===d.offsetWidth,d.style.display="block",d.innerHTML="
",d.firstChild.style.width="5px",t.shrinkWrapBlocks=3!==d.offsetWidth,t.inlineBlockNeedsLayout&&(l.style.zoom=1)),l.removeChild(n),n=d=o=r=null)}),n=s=l=u=r=o=null,t +}({});var B=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,P=/([A-Z])/g;function R(e,n,r,i){if(x.acceptData(e)){var o,a,s=x.expando,l=e.nodeType,u=l?x.cache:e,c=l?e[s]:e[s]&&s;if(c&&u[c]&&(i||u[c].data)||r!==t||"string"!=typeof n)return c||(c=l?e[s]=p.pop()||x.guid++:s),u[c]||(u[c]=l?{}:{toJSON:x.noop}),("object"==typeof n||"function"==typeof n)&&(i?u[c]=x.extend(u[c],n):u[c].data=x.extend(u[c].data,n)),a=u[c],i||(a.data||(a.data={}),a=a.data),r!==t&&(a[x.camelCase(n)]=r),"string"==typeof n?(o=a[n],null==o&&(o=a[x.camelCase(n)])):o=a,o}}function W(e,t,n){if(x.acceptData(e)){var r,i,o=e.nodeType,a=o?x.cache:e,s=o?e[x.expando]:x.expando;if(a[s]){if(t&&(r=n?a[s]:a[s].data)){x.isArray(t)?t=t.concat(x.map(t,x.camelCase)):t in r?t=[t]:(t=x.camelCase(t),t=t in r?[t]:t.split(" ")),i=t.length;while(i--)delete r[t[i]];if(n?!I(r):!x.isEmptyObject(r))return}(n||(delete a[s].data,I(a[s])))&&(o?x.cleanData([e],!0):x.support.deleteExpando||a!=a.window?delete a[s]:a[s]=null)}}}x.extend({cache:{},noData:{applet:!0,embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"},hasData:function(e){return e=e.nodeType?x.cache[e[x.expando]]:e[x.expando],!!e&&!I(e)},data:function(e,t,n){return R(e,t,n)},removeData:function(e,t){return W(e,t)},_data:function(e,t,n){return R(e,t,n,!0)},_removeData:function(e,t){return W(e,t,!0)},acceptData:function(e){if(e.nodeType&&1!==e.nodeType&&9!==e.nodeType)return!1;var t=e.nodeName&&x.noData[e.nodeName.toLowerCase()];return!t||t!==!0&&e.getAttribute("classid")===t}}),x.fn.extend({data:function(e,n){var r,i,o=null,a=0,s=this[0];if(e===t){if(this.length&&(o=x.data(s),1===s.nodeType&&!x._data(s,"parsedAttrs"))){for(r=s.attributes;r.length>a;a++)i=r[a].name,0===i.indexOf("data-")&&(i=x.camelCase(i.slice(5)),$(s,i,o[i]));x._data(s,"parsedAttrs",!0)}return o}return"object"==typeof e?this.each(function(){x.data(this,e)}):arguments.length>1?this.each(function(){x.data(this,e,n)}):s?$(s,e,x.data(s,e)):null},removeData:function(e){return this.each(function(){x.removeData(this,e)})}});function $(e,n,r){if(r===t&&1===e.nodeType){var i="data-"+n.replace(P,"-$1").toLowerCase();if(r=e.getAttribute(i),"string"==typeof r){try{r="true"===r?!0:"false"===r?!1:"null"===r?null:+r+""===r?+r:B.test(r)?x.parseJSON(r):r}catch(o){}x.data(e,n,r)}else r=t}return r}function I(e){var t;for(t in e)if(("data"!==t||!x.isEmptyObject(e[t]))&&"toJSON"!==t)return!1;return!0}x.extend({queue:function(e,n,r){var i;return e?(n=(n||"fx")+"queue",i=x._data(e,n),r&&(!i||x.isArray(r)?i=x._data(e,n,x.makeArray(r)):i.push(r)),i||[]):t},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),a=function(){x.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return x._data(e,n)||x._data(e,n,{empty:x.Callbacks("once memory").add(function(){x._removeData(e,t+"queue"),x._removeData(e,n)})})}}),x.fn.extend({queue:function(e,n){var r=2;return"string"!=typeof e&&(n=e,e="fx",r--),r>arguments.length?x.queue(this[0],e):n===t?this:this.each(function(){var t=x.queue(this,e,n);x._queueHooks(this,e),"fx"===e&&"inprogress"!==t[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,n){var r,i=1,o=x.Deferred(),a=this,s=this.length,l=function(){--i||o.resolveWith(a,[a])};"string"!=typeof e&&(n=e,e=t),e=e||"fx";while(s--)r=x._data(a[s],e+"queueHooks"),r&&r.empty&&(i++,r.empty.add(l));return l(),o.promise(n)}});var z,X,U=/[\t\r\n\f]/g,V=/\r/g,Y=/^(?:input|select|textarea|button|object)$/i,J=/^(?:a|area)$/i,G=/^(?:checked|selected)$/i,Q=x.support.getSetAttribute,K=x.support.input;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return e=x.propFix[e]||e,this.each(function(){try{this[e]=t,delete this[e]}catch(n){}})},addClass:function(e){var t,n,r,i,o,a=0,s=this.length,l="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(l)for(t=(e||"").match(T)||[];s>a;a++)if(n=this[a],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(U," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,a=0,s=this.length,l=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(l)for(t=(e||"").match(T)||[];s>a;a++)if(n=this[a],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(U," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var t,r=0,o=x(this),a=e.match(T)||[];while(t=a[r++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else(n===i||"boolean"===n)&&(this.className&&x._data(this,"__className__",this.className),this.className=this.className||e===!1?"":x._data(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(U," ").indexOf(t)>=0)return!0;return!1},val:function(e){var n,r,i,o=this[0];{if(arguments.length)return i=x.isFunction(e),this.each(function(n){var o;1===this.nodeType&&(o=i?e.call(this,n,x(this).val()):e,null==o?o="":"number"==typeof o?o+="":x.isArray(o)&&(o=x.map(o,function(e){return null==e?"":e+""})),r=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],r&&"set"in r&&r.set(this,o,"value")!==t||(this.value=o))});if(o)return r=x.valHooks[o.type]||x.valHooks[o.nodeName.toLowerCase()],r&&"get"in r&&(n=r.get(o,"value"))!==t?n:(n=o.value,"string"==typeof n?n.replace(V,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=x.find.attr(e,"value");return null!=t?t:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,a=o?null:[],s=o?i+1:r.length,l=0>i?s:o?i:0;for(;s>l;l++)if(n=r[l],!(!n.selected&&l!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;a.push(t)}return a},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),a=i.length;while(a--)r=i[a],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,n,r){var o,a,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===i?x.prop(e,n,r):(1===s&&x.isXMLDoc(e)||(n=n.toLowerCase(),o=x.attrHooks[n]||(x.expr.match.bool.test(n)?X:z)),r===t?o&&"get"in o&&null!==(a=o.get(e,n))?a:(a=x.find.attr(e,n),null==a?t:a):null!==r?o&&"set"in o&&(a=o.set(e,r,n))!==t?a:(e.setAttribute(n,r+""),r):(x.removeAttr(e,n),t))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(T);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.bool.test(n)?K&&Q||!G.test(n)?e[r]=!1:e[x.camelCase("default-"+n)]=e[r]=!1:x.attr(e,n,""),e.removeAttribute(Q?n:r)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,n,r){var i,o,a,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return a=1!==s||!x.isXMLDoc(e),a&&(n=x.propFix[n]||n,o=x.propHooks[n]),r!==t?o&&"set"in o&&(i=o.set(e,r,n))!==t?i:e[n]=r:o&&"get"in o&&null!==(i=o.get(e,n))?i:e[n]},propHooks:{tabIndex:{get:function(e){var t=x.find.attr(e,"tabindex");return t?parseInt(t,10):Y.test(e.nodeName)||J.test(e.nodeName)&&e.href?0:-1}}}}),X={set:function(e,t,n){return t===!1?x.removeAttr(e,n):K&&Q||!G.test(n)?e.setAttribute(!Q&&x.propFix[n]||n,n):e[x.camelCase("default-"+n)]=e[n]=!0,n}},x.each(x.expr.match.bool.source.match(/\w+/g),function(e,n){var r=x.expr.attrHandle[n]||x.find.attr;x.expr.attrHandle[n]=K&&Q||!G.test(n)?function(e,n,i){var o=x.expr.attrHandle[n],a=i?t:(x.expr.attrHandle[n]=t)!=r(e,n,i)?n.toLowerCase():null;return x.expr.attrHandle[n]=o,a}:function(e,n,r){return r?t:e[x.camelCase("default-"+n)]?n.toLowerCase():null}}),K&&Q||(x.attrHooks.value={set:function(e,n,r){return x.nodeName(e,"input")?(e.defaultValue=n,t):z&&z.set(e,n,r)}}),Q||(z={set:function(e,n,r){var i=e.getAttributeNode(r);return i||e.setAttributeNode(i=e.ownerDocument.createAttribute(r)),i.value=n+="","value"===r||n===e.getAttribute(r)?n:t}},x.expr.attrHandle.id=x.expr.attrHandle.name=x.expr.attrHandle.coords=function(e,n,r){var i;return r?t:(i=e.getAttributeNode(n))&&""!==i.value?i.value:null},x.valHooks.button={get:function(e,n){var r=e.getAttributeNode(n);return r&&r.specified?r.value:t},set:z.set},x.attrHooks.contenteditable={set:function(e,t,n){z.set(e,""===t?!1:t,n)}},x.each(["width","height"],function(e,n){x.attrHooks[n]={set:function(e,r){return""===r?(e.setAttribute(n,"auto"),r):t}}})),x.support.hrefNormalized||x.each(["href","src"],function(e,t){x.propHooks[t]={get:function(e){return e.getAttribute(t,4)}}}),x.support.style||(x.attrHooks.style={get:function(e){return e.style.cssText||t},set:function(e,t){return e.style.cssText=t+""}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex),null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.support.enctype||(x.propFix.enctype="encoding"),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,n){return x.isArray(n)?e.checked=x.inArray(x(e).val(),n)>=0:t}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var Z=/^(?:input|select|textarea)$/i,et=/^key/,tt=/^(?:mouse|contextmenu)|click/,nt=/^(?:focusinfocus|focusoutblur)$/,rt=/^([^.]*)(?:\.(.+)|)$/;function it(){return!0}function ot(){return!1}function at(){try{return a.activeElement}catch(e){}}x.event={global:{},add:function(e,n,r,o,a){var s,l,u,c,p,f,d,h,g,m,y,v=x._data(e);if(v){r.handler&&(c=r,r=c.handler,a=c.selector),r.guid||(r.guid=x.guid++),(l=v.events)||(l=v.events={}),(f=v.handle)||(f=v.handle=function(e){return typeof x===i||e&&x.event.triggered===e.type?t:x.event.dispatch.apply(f.elem,arguments)},f.elem=e),n=(n||"").match(T)||[""],u=n.length;while(u--)s=rt.exec(n[u])||[],g=y=s[1],m=(s[2]||"").split(".").sort(),g&&(p=x.event.special[g]||{},g=(a?p.delegateType:p.bindType)||g,p=x.event.special[g]||{},d=x.extend({type:g,origType:y,data:o,handler:r,guid:r.guid,selector:a,needsContext:a&&x.expr.match.needsContext.test(a),namespace:m.join(".")},c),(h=l[g])||(h=l[g]=[],h.delegateCount=0,p.setup&&p.setup.call(e,o,m,f)!==!1||(e.addEventListener?e.addEventListener(g,f,!1):e.attachEvent&&e.attachEvent("on"+g,f))),p.add&&(p.add.call(e,d),d.handler.guid||(d.handler.guid=r.guid)),a?h.splice(h.delegateCount++,0,d):h.push(d),x.event.global[g]=!0);e=null}},remove:function(e,t,n,r,i){var o,a,s,l,u,c,p,f,d,h,g,m=x.hasData(e)&&x._data(e);if(m&&(c=m.events)){t=(t||"").match(T)||[""],u=t.length;while(u--)if(s=rt.exec(t[u])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){p=x.event.special[d]||{},d=(r?p.delegateType:p.bindType)||d,f=c[d]||[],s=s[2]&&RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),l=o=f.length;while(o--)a=f[o],!i&&g!==a.origType||n&&n.guid!==a.guid||s&&!s.test(a.namespace)||r&&r!==a.selector&&("**"!==r||!a.selector)||(f.splice(o,1),a.selector&&f.delegateCount--,p.remove&&p.remove.call(e,a));l&&!f.length&&(p.teardown&&p.teardown.call(e,h,m.handle)!==!1||x.removeEvent(e,d,m.handle),delete c[d])}else for(d in c)x.event.remove(e,d+t[u],n,r,!0);x.isEmptyObject(c)&&(delete m.handle,x._removeData(e,"events"))}},trigger:function(n,r,i,o){var s,l,u,c,p,f,d,h=[i||a],g=v.call(n,"type")?n.type:n,m=v.call(n,"namespace")?n.namespace.split("."):[];if(u=f=i=i||a,3!==i.nodeType&&8!==i.nodeType&&!nt.test(g+x.event.triggered)&&(g.indexOf(".")>=0&&(m=g.split("."),g=m.shift(),m.sort()),l=0>g.indexOf(":")&&"on"+g,n=n[x.expando]?n:new x.Event(g,"object"==typeof n&&n),n.isTrigger=o?2:3,n.namespace=m.join("."),n.namespace_re=n.namespace?RegExp("(^|\\.)"+m.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,n.result=t,n.target||(n.target=i),r=null==r?[n]:x.makeArray(r,[n]),p=x.event.special[g]||{},o||!p.trigger||p.trigger.apply(i,r)!==!1)){if(!o&&!p.noBubble&&!x.isWindow(i)){for(c=p.delegateType||g,nt.test(c+g)||(u=u.parentNode);u;u=u.parentNode)h.push(u),f=u;f===(i.ownerDocument||a)&&h.push(f.defaultView||f.parentWindow||e)}d=0;while((u=h[d++])&&!n.isPropagationStopped())n.type=d>1?c:p.bindType||g,s=(x._data(u,"events")||{})[n.type]&&x._data(u,"handle"),s&&s.apply(u,r),s=l&&u[l],s&&x.acceptData(u)&&s.apply&&s.apply(u,r)===!1&&n.preventDefault();if(n.type=g,!o&&!n.isDefaultPrevented()&&(!p._default||p._default.apply(h.pop(),r)===!1)&&x.acceptData(i)&&l&&i[g]&&!x.isWindow(i)){f=i[l],f&&(i[l]=null),x.event.triggered=g;try{i[g]()}catch(y){}x.event.triggered=t,f&&(i[l]=f)}return n.result}},dispatch:function(e){e=x.event.fix(e);var n,r,i,o,a,s=[],l=g.call(arguments),u=(x._data(this,"events")||{})[e.type]||[],c=x.event.special[e.type]||{};if(l[0]=e,e.delegateTarget=this,!c.preDispatch||c.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),n=0;while((o=s[n++])&&!e.isPropagationStopped()){e.currentTarget=o.elem,a=0;while((i=o.handlers[a++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(i.namespace))&&(e.handleObj=i,e.data=i.data,r=((x.event.special[i.origType]||{}).handle||i.handler).apply(o.elem,l),r!==t&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,e),e.result}},handlers:function(e,n){var r,i,o,a,s=[],l=n.delegateCount,u=e.target;if(l&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!=this;u=u.parentNode||this)if(1===u.nodeType&&(u.disabled!==!0||"click"!==e.type)){for(o=[],a=0;l>a;a++)i=n[a],r=i.selector+" ",o[r]===t&&(o[r]=i.needsContext?x(r,this).index(u)>=0:x.find(r,this,null,[u]).length),o[r]&&o.push(i);o.length&&s.push({elem:u,handlers:o})}return n.length>l&&s.push({elem:this,handlers:n.slice(l)}),s},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,o=e,s=this.fixHooks[i];s||(this.fixHooks[i]=s=tt.test(i)?this.mouseHooks:et.test(i)?this.keyHooks:{}),r=s.props?this.props.concat(s.props):this.props,e=new x.Event(o),t=r.length;while(t--)n=r[t],e[n]=o[n];return e.target||(e.target=o.srcElement||a),3===e.target.nodeType&&(e.target=e.target.parentNode),e.metaKey=!!e.metaKey,s.filter?s.filter(e,o):e},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,n){var r,i,o,s=n.button,l=n.fromElement;return null==e.pageX&&null!=n.clientX&&(i=e.target.ownerDocument||a,o=i.documentElement,r=i.body,e.pageX=n.clientX+(o&&o.scrollLeft||r&&r.scrollLeft||0)-(o&&o.clientLeft||r&&r.clientLeft||0),e.pageY=n.clientY+(o&&o.scrollTop||r&&r.scrollTop||0)-(o&&o.clientTop||r&&r.clientTop||0)),!e.relatedTarget&&l&&(e.relatedTarget=l===e.target?n.toElement:l),e.which||s===t||(e.which=1&s?1:2&s?3:4&s?2:0),e}},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==at()&&this.focus)try{return this.focus(),!1}catch(e){}},delegateType:"focusin"},blur:{trigger:function(){return this===at()&&this.blur?(this.blur(),!1):t},delegateType:"focusout"},click:{trigger:function(){return x.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):t},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==t&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=a.removeEventListener?function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)}:function(e,t,n){var r="on"+t;e.detachEvent&&(typeof e[r]===i&&(e[r]=null),e.detachEvent(r,n))},x.Event=function(e,n){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.returnValue===!1||e.getPreventDefault&&e.getPreventDefault()?it:ot):this.type=e,n&&x.extend(this,n),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,t):new x.Event(e,n)},x.Event.prototype={isDefaultPrevented:ot,isPropagationStopped:ot,isImmediatePropagationStopped:ot,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=it,e&&(e.preventDefault?e.preventDefault():e.returnValue=!1)},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=it,e&&(e.stopPropagation&&e.stopPropagation(),e.cancelBubble=!0)},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=it,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.submitBubbles||(x.event.special.submit={setup:function(){return x.nodeName(this,"form")?!1:(x.event.add(this,"click._submit keypress._submit",function(e){var n=e.target,r=x.nodeName(n,"input")||x.nodeName(n,"button")?n.form:t;r&&!x._data(r,"submitBubbles")&&(x.event.add(r,"submit._submit",function(e){e._submit_bubble=!0}),x._data(r,"submitBubbles",!0))}),t)},postDispatch:function(e){e._submit_bubble&&(delete e._submit_bubble,this.parentNode&&!e.isTrigger&&x.event.simulate("submit",this.parentNode,e,!0))},teardown:function(){return x.nodeName(this,"form")?!1:(x.event.remove(this,"._submit"),t)}}),x.support.changeBubbles||(x.event.special.change={setup:function(){return Z.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(x.event.add(this,"propertychange._change",function(e){"checked"===e.originalEvent.propertyName&&(this._just_changed=!0)}),x.event.add(this,"click._change",function(e){this._just_changed&&!e.isTrigger&&(this._just_changed=!1),x.event.simulate("change",this,e,!0)})),!1):(x.event.add(this,"beforeactivate._change",function(e){var t=e.target;Z.test(t.nodeName)&&!x._data(t,"changeBubbles")&&(x.event.add(t,"change._change",function(e){!this.parentNode||e.isSimulated||e.isTrigger||x.event.simulate("change",this.parentNode,e,!0)}),x._data(t,"changeBubbles",!0))}),t)},handle:function(e){var n=e.target;return this!==n||e.isSimulated||e.isTrigger||"radio"!==n.type&&"checkbox"!==n.type?e.handleObj.handler.apply(this,arguments):t},teardown:function(){return x.event.remove(this,"._change"),!Z.test(this.nodeName)}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&a.addEventListener(e,r,!0)},teardown:function(){0===--n&&a.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,n,r,i,o){var a,s;if("object"==typeof e){"string"!=typeof n&&(r=r||n,n=t);for(a in e)this.on(a,n,r,e[a],o);return this}if(null==r&&null==i?(i=n,r=n=t):null==i&&("string"==typeof n?(i=r,r=t):(i=r,r=n,n=t)),i===!1)i=ot;else if(!i)return this;return 1===o&&(s=i,i=function(e){return x().off(e),s.apply(this,arguments)},i.guid=s.guid||(s.guid=x.guid++)),this.each(function(){x.event.add(this,e,i,r,n)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,n,r){var i,o;if(e&&e.preventDefault&&e.handleObj)return i=e.handleObj,x(e.delegateTarget).off(i.namespace?i.origType+"."+i.namespace:i.origType,i.selector,i.handler),this;if("object"==typeof e){for(o in e)this.off(o,n,e[o]);return this}return(n===!1||"function"==typeof n)&&(r=n,n=t),r===!1&&(r=ot),this.each(function(){x.event.remove(this,e,r,n)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,n){var r=this[0];return r?x.event.trigger(e,n,r,!0):t}});var st=/^.[^:#\[\.,]*$/,lt=/^(?:parents|prev(?:Until|All))/,ut=x.expr.match.needsContext,ct={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n=[],r=this,i=r.length;if("string"!=typeof e)return this.pushStack(x(e).filter(function(){for(t=0;i>t;t++)if(x.contains(r[t],this))return!0}));for(t=0;i>t;t++)x.find(e,r[t],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=this.selector?this.selector+" "+e:e,n},has:function(e){var t,n=x(e,this),r=n.length;return this.filter(function(){for(t=0;r>t;t++)if(x.contains(this,n[t]))return!0})},not:function(e){return this.pushStack(ft(this,e||[],!0))},filter:function(e){return this.pushStack(ft(this,e||[],!1))},is:function(e){return!!ft(this,"string"==typeof e&&ut.test(e)?x(e):e||[],!1).length},closest:function(e,t){var n,r=0,i=this.length,o=[],a=ut.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(a?a.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?x.inArray(this[0],x(e)):x.inArray(e.jquery?e[0]:e,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function pt(e,t){do e=e[t];while(e&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return pt(e,"nextSibling")},prev:function(e){return pt(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return x.nodeName(e,"iframe")?e.contentDocument||e.contentWindow.document:x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(ct[e]||(i=x.unique(i)),lt.test(e)&&(i=i.reverse())),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,n,r){var i=[],o=e[n];while(o&&9!==o.nodeType&&(r===t||1!==o.nodeType||!x(o).is(r)))1===o.nodeType&&i.push(o),o=o[n];return i},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function ft(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(st.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return x.inArray(e,t)>=0!==n})}function dt(e){var t=ht.split("|"),n=e.createDocumentFragment();if(n.createElement)while(t.length)n.createElement(t.pop());return n}var ht="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",gt=/ jQuery\d+="(?:null|\d+)"/g,mt=RegExp("<(?:"+ht+")[\\s/>]","i"),yt=/^\s+/,vt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bt=/<([\w:]+)/,xt=/\s*$/g,At={option:[1,""],legend:[1,"
","
"],area:[1,"",""],param:[1,"",""],thead:[1,"","
"],tr:[2,"","
"],col:[2,"","
"],td:[3,"","
"],_default:x.support.htmlSerialize?[0,"",""]:[1,"X
","
"]},jt=dt(a),Dt=jt.appendChild(a.createElement("div"));At.optgroup=At.option,At.tbody=At.tfoot=At.colgroup=At.caption=At.thead,At.th=At.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===t?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||a).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Lt(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Lt(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(Ft(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&_t(Ft(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++){1===e.nodeType&&x.cleanData(Ft(e,!1));while(e.firstChild)e.removeChild(e.firstChild);e.options&&x.nodeName(e,"select")&&(e.options.length=0)}return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var n=this[0]||{},r=0,i=this.length;if(e===t)return 1===n.nodeType?n.innerHTML.replace(gt,""):t;if(!("string"!=typeof e||Tt.test(e)||!x.support.htmlSerialize&&mt.test(e)||!x.support.leadingWhitespace&&yt.test(e)||At[(bt.exec(e)||["",""])[1].toLowerCase()])){e=e.replace(vt,"<$1>");try{for(;i>r;r++)n=this[r]||{},1===n.nodeType&&(x.cleanData(Ft(n,!1)),n.innerHTML=e);n=0}catch(o){}}n&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(r&&r.parentNode!==i&&(r=this.nextSibling),x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=d.apply([],e);var r,i,o,a,s,l,u=0,c=this.length,p=this,f=c-1,h=e[0],g=x.isFunction(h);if(g||!(1>=c||"string"!=typeof h||x.support.checkClone)&&Nt.test(h))return this.each(function(r){var i=p.eq(r);g&&(e[0]=h.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(l=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),r=l.firstChild,1===l.childNodes.length&&(l=r),r)){for(a=x.map(Ft(l,"script"),Ht),o=a.length;c>u;u++)i=l,u!==f&&(i=x.clone(i,!0,!0),o&&x.merge(a,Ft(i,"script"))),t.call(this[u],i,u);if(o)for(s=a[a.length-1].ownerDocument,x.map(a,qt),u=0;o>u;u++)i=a[u],kt.test(i.type||"")&&!x._data(i,"globalEval")&&x.contains(s,i)&&(i.src?x._evalUrl(i.src):x.globalEval((i.text||i.textContent||i.innerHTML||"").replace(St,"")));l=r=null}return this}});function Lt(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function Ht(e){return e.type=(null!==x.find.attr(e,"type"))+"/"+e.type,e}function qt(e){var t=Et.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function _t(e,t){var n,r=0;for(;null!=(n=e[r]);r++)x._data(n,"globalEval",!t||x._data(t[r],"globalEval"))}function Mt(e,t){if(1===t.nodeType&&x.hasData(e)){var n,r,i,o=x._data(e),a=x._data(t,o),s=o.events;if(s){delete a.handle,a.events={};for(n in s)for(r=0,i=s[n].length;i>r;r++)x.event.add(t,n,s[n][r])}a.data&&(a.data=x.extend({},a.data))}}function Ot(e,t){var n,r,i;if(1===t.nodeType){if(n=t.nodeName.toLowerCase(),!x.support.noCloneEvent&&t[x.expando]){i=x._data(t);for(r in i.events)x.removeEvent(t,r,i.handle);t.removeAttribute(x.expando)}"script"===n&&t.text!==e.text?(Ht(t).text=e.text,qt(t)):"object"===n?(t.parentNode&&(t.outerHTML=e.outerHTML),x.support.html5Clone&&e.innerHTML&&!x.trim(t.innerHTML)&&(t.innerHTML=e.innerHTML)):"input"===n&&Ct.test(e.type)?(t.defaultChecked=t.checked=e.checked,t.value!==e.value&&(t.value=e.value)):"option"===n?t.defaultSelected=t.selected=e.defaultSelected:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}}x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=0,i=[],o=x(e),a=o.length-1;for(;a>=r;r++)n=r===a?this:this.clone(!0),x(o[r])[t](n),h.apply(i,n.get());return this.pushStack(i)}});function Ft(e,n){var r,o,a=0,s=typeof e.getElementsByTagName!==i?e.getElementsByTagName(n||"*"):typeof e.querySelectorAll!==i?e.querySelectorAll(n||"*"):t;if(!s)for(s=[],r=e.childNodes||e;null!=(o=r[a]);a++)!n||x.nodeName(o,n)?s.push(o):x.merge(s,Ft(o,n));return n===t||n&&x.nodeName(e,n)?x.merge([e],s):s}function Bt(e){Ct.test(e.type)&&(e.defaultChecked=e.checked)}x.extend({clone:function(e,t,n){var r,i,o,a,s,l=x.contains(e.ownerDocument,e);if(x.support.html5Clone||x.isXMLDoc(e)||!mt.test("<"+e.nodeName+">")?o=e.cloneNode(!0):(Dt.innerHTML=e.outerHTML,Dt.removeChild(o=Dt.firstChild)),!(x.support.noCloneEvent&&x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(r=Ft(o),s=Ft(e),a=0;null!=(i=s[a]);++a)r[a]&&Ot(i,r[a]);if(t)if(n)for(s=s||Ft(e),r=r||Ft(o),a=0;null!=(i=s[a]);a++)Mt(i,r[a]);else Mt(e,o);return r=Ft(o,"script"),r.length>0&&_t(r,!l&&Ft(e,"script")),r=s=i=null,o},buildFragment:function(e,t,n,r){var i,o,a,s,l,u,c,p=e.length,f=dt(t),d=[],h=0;for(;p>h;h++)if(o=e[h],o||0===o)if("object"===x.type(o))x.merge(d,o.nodeType?[o]:o);else if(wt.test(o)){s=s||f.appendChild(t.createElement("div")),l=(bt.exec(o)||["",""])[1].toLowerCase(),c=At[l]||At._default,s.innerHTML=c[1]+o.replace(vt,"<$1>")+c[2],i=c[0];while(i--)s=s.lastChild;if(!x.support.leadingWhitespace&&yt.test(o)&&d.push(t.createTextNode(yt.exec(o)[0])),!x.support.tbody){o="table"!==l||xt.test(o)?""!==c[1]||xt.test(o)?0:s:s.firstChild,i=o&&o.childNodes.length;while(i--)x.nodeName(u=o.childNodes[i],"tbody")&&!u.childNodes.length&&o.removeChild(u)}x.merge(d,s.childNodes),s.textContent="";while(s.firstChild)s.removeChild(s.firstChild);s=f.lastChild}else d.push(t.createTextNode(o));s&&f.removeChild(s),x.support.appendChecked||x.grep(Ft(d,"input"),Bt),h=0;while(o=d[h++])if((!r||-1===x.inArray(o,r))&&(a=x.contains(o.ownerDocument,o),s=Ft(f.appendChild(o),"script"),a&&_t(s),n)){i=0;while(o=s[i++])kt.test(o.type||"")&&n.push(o)}return s=null,f},cleanData:function(e,t){var n,r,o,a,s=0,l=x.expando,u=x.cache,c=x.support.deleteExpando,f=x.event.special;for(;null!=(n=e[s]);s++)if((t||x.acceptData(n))&&(o=n[l],a=o&&u[o])){if(a.events)for(r in a.events)f[r]?x.event.remove(n,r):x.removeEvent(n,r,a.handle); + u[o]&&(delete u[o],c?delete n[l]:typeof n.removeAttribute!==i?n.removeAttribute(l):n[l]=null,p.push(o))}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})}}),x.fn.extend({wrapAll:function(e){if(x.isFunction(e))return this.each(function(t){x(this).wrapAll(e.call(this,t))});if(this[0]){var t=x(e,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstChild&&1===e.firstChild.nodeType)e=e.firstChild;return e}).append(this)}return this},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var Pt,Rt,Wt,$t=/alpha\([^)]*\)/i,It=/opacity\s*=\s*([^)]*)/,zt=/^(top|right|bottom|left)$/,Xt=/^(none|table(?!-c[ea]).+)/,Ut=/^margin/,Vt=RegExp("^("+w+")(.*)$","i"),Yt=RegExp("^("+w+")(?!px)[a-z%]+$","i"),Jt=RegExp("^([+-])=("+w+")","i"),Gt={BODY:"block"},Qt={position:"absolute",visibility:"hidden",display:"block"},Kt={letterSpacing:0,fontWeight:400},Zt=["Top","Right","Bottom","Left"],en=["Webkit","O","Moz","ms"];function tn(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=en.length;while(i--)if(t=en[i]+n,t in e)return t;return r}function nn(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function rn(e,t){var n,r,i,o=[],a=0,s=e.length;for(;s>a;a++)r=e[a],r.style&&(o[a]=x._data(r,"olddisplay"),n=r.style.display,t?(o[a]||"none"!==n||(r.style.display=""),""===r.style.display&&nn(r)&&(o[a]=x._data(r,"olddisplay",ln(r.nodeName)))):o[a]||(i=nn(r),(n&&"none"!==n||!i)&&x._data(r,"olddisplay",i?n:x.css(r,"display"))));for(a=0;s>a;a++)r=e[a],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[a]||"":"none"));return e}x.fn.extend({css:function(e,n){return x.access(this,function(e,n,r){var i,o,a={},s=0;if(x.isArray(n)){for(o=Rt(e),i=n.length;i>s;s++)a[n[s]]=x.css(e,n[s],!1,o);return a}return r!==t?x.style(e,n,r):x.css(e,n)},e,n,arguments.length>1)},show:function(){return rn(this,!0)},hide:function(){return rn(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){nn(this)?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Wt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":x.support.cssFloat?"cssFloat":"styleFloat"},style:function(e,n,r,i){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var o,a,s,l=x.camelCase(n),u=e.style;if(n=x.cssProps[l]||(x.cssProps[l]=tn(u,l)),s=x.cssHooks[n]||x.cssHooks[l],r===t)return s&&"get"in s&&(o=s.get(e,!1,i))!==t?o:u[n];if(a=typeof r,"string"===a&&(o=Jt.exec(r))&&(r=(o[1]+1)*o[2]+parseFloat(x.css(e,n)),a="number"),!(null==r||"number"===a&&isNaN(r)||("number"!==a||x.cssNumber[l]||(r+="px"),x.support.clearCloneStyle||""!==r||0!==n.indexOf("background")||(u[n]="inherit"),s&&"set"in s&&(r=s.set(e,r,i))===t)))try{u[n]=r}catch(c){}}},css:function(e,n,r,i){var o,a,s,l=x.camelCase(n);return n=x.cssProps[l]||(x.cssProps[l]=tn(e.style,l)),s=x.cssHooks[n]||x.cssHooks[l],s&&"get"in s&&(a=s.get(e,!0,r)),a===t&&(a=Wt(e,n,i)),"normal"===a&&n in Kt&&(a=Kt[n]),""===r||r?(o=parseFloat(a),r===!0||x.isNumeric(o)?o||0:a):a}}),e.getComputedStyle?(Rt=function(t){return e.getComputedStyle(t,null)},Wt=function(e,n,r){var i,o,a,s=r||Rt(e),l=s?s.getPropertyValue(n)||s[n]:t,u=e.style;return s&&(""!==l||x.contains(e.ownerDocument,e)||(l=x.style(e,n)),Yt.test(l)&&Ut.test(n)&&(i=u.width,o=u.minWidth,a=u.maxWidth,u.minWidth=u.maxWidth=u.width=l,l=s.width,u.width=i,u.minWidth=o,u.maxWidth=a)),l}):a.documentElement.currentStyle&&(Rt=function(e){return e.currentStyle},Wt=function(e,n,r){var i,o,a,s=r||Rt(e),l=s?s[n]:t,u=e.style;return null==l&&u&&u[n]&&(l=u[n]),Yt.test(l)&&!zt.test(n)&&(i=u.left,o=e.runtimeStyle,a=o&&o.left,a&&(o.left=e.currentStyle.left),u.left="fontSize"===n?"1em":l,l=u.pixelLeft+"px",u.left=i,a&&(o.left=a)),""===l?"auto":l});function on(e,t,n){var r=Vt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function an(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,a=0;for(;4>o;o+=2)"margin"===n&&(a+=x.css(e,n+Zt[o],!0,i)),r?("content"===n&&(a-=x.css(e,"padding"+Zt[o],!0,i)),"margin"!==n&&(a-=x.css(e,"border"+Zt[o]+"Width",!0,i))):(a+=x.css(e,"padding"+Zt[o],!0,i),"padding"!==n&&(a+=x.css(e,"border"+Zt[o]+"Width",!0,i)));return a}function sn(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=Rt(e),a=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=Wt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Yt.test(i))return i;r=a&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+an(e,t,n||(a?"border":"content"),r,o)+"px"}function ln(e){var t=a,n=Gt[e];return n||(n=un(e,t),"none"!==n&&n||(Pt=(Pt||x("'}),this.TSC.templates.question_count_template=Handlebars.template(function(e,t,n,i,a){this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var r,o,s="",u="function",c=this.escapeExpression;return s+="",(o=n.currentQuestionNumber)?r=o.call(t,{hash:{},data:a}):(o=t&&t.currentQuestionNumber,r=typeof o===u?o.call(t,{hash:{},data:a}):o),s+=c(r)+"",(o=n.prepositionText)?r=o.call(t,{hash:{},data:a}):(o=t&&t.prepositionText,r=typeof o===u?o.call(t,{hash:{},data:a}):o),s+=c(r)+" ",(o=n.totalQuestions)?r=o.call(t,{hash:{},data:a}):(o=t&&t.totalQuestions,r=typeof o===u?o.call(t,{hash:{},data:a}):o),s+=c(r)+"\r\n"}),this.TSC.templates.question_set_confirmation_template=Handlebars.template(function(e,t,n,i,a){this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var r,o,s="",u="function",c=this.escapeExpression;return s+='
\r\n
',(o=n.confirmationText)?r=o.call(t,{hash:{},data:a}):(o=t&&t.confirmationText,r=typeof o===u?o.call(t,{hash:{},data:a}):o),s+=c(r)+'
\r\n
',(o=n.reviewText)?r=o.call(t,{hash:{},data:a}):(o=t&&t.reviewText,r=typeof o===u?o.call(t,{hash:{},data:a}):o),(r||0===r)&&(s+=r),s+='
\r\n
\r\n
\r\n
'}),this.TSC.templates.question_set_review_confirmation_template=Handlebars.template(function(e,t,n,i,a){this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var r,o,s="",u="function";return s+='
\r\n
',(o=n.reviewAnswerText)?r=o.call(t,{hash:{},data:a}):(o=t&&t.reviewAnswerText,r=typeof o===u?o.call(t,{hash:{},data:a}):o),(r||0===r)&&(s+=r),s+='
\r\n
',(o=n.continueText)?r=o.call(t,{hash:{},data:a}):(o=t&&t.continueText,r=typeof o===u?o.call(t,{hash:{},data:a}):o),(r||0===r)&&(s+=r),s+='
\r\n
\r\n
\r\n
'}),this.TSC.templates.question_set_template=Handlebars.template(function(e,t,n,i,a){this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var r,o,s="",u="function";return s+='
\r\n

',(o=n.questionSetTitle)?r=o.call(t,{hash:{},data:a}):(o=t&&t.questionSetTitle,r=typeof o===u?o.call(t,{hash:{},data:a}):o),(r||0===r)&&(s+=r),s+='

\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
'}),this.TSC.templates.question_text_template=Handlebars.template(function(e,t,n,i,a){this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var r,o,s="",u="function",c=this.escapeExpression;return s+='

',(o=n.questionNumber)?r=o.call(t,{hash:{},data:a}):(o=t&&t.questionNumber,r=typeof o===u?o.call(t,{hash:{},data:a}):o),s+=c(r)+") ",(o=n.questionText)?r=o.call(t,{hash:{},data:a}):(o=t&&t.questionText,r=typeof o===u?o.call(t,{hash:{},data:a}):o),(r||0===r)&&(s+=r),s+="

"}),this.TSC.templates.quiz_setup_template=Handlebars.template(function(e,t,n,i,a){function r(){return"autofocus"}this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var o,s,u="",c="function",l=this.escapeExpression,d=this;return u+='
\r\n

',(s=n.setupMessage)?o=s.call(t,{hash:{},data:a}):(s=t&&t.setupMessage,o=typeof s===c?s.call(t,{hash:{},data:a}):s),(o||0===o)&&(u+=o),u+='

\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n

',(s=n.skipControlText)?o=s.call(t,{hash:{},data:a}):(s=t&&t.skipControlText,o=typeof s===c?s.call(t,{hash:{},data:a}):s),u+=l(o)+"

\r\n
"}),this.TSC.templates.settings_view_template=Handlebars.template(function(e,t,n,i,a){function r(e,t){var i,a,r="";return r+="\r\n \r\n "}function o(){return"selected"}this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var s,u,c="",l=this,d="function",f=this.escapeExpression;return c+='
\r\n
\r\n \r\n \r\n
\r\n
"}),this.TSC.templates.short_answer_template=Handlebars.template(function(e,t,n,i,a){function r(){return"autofocus"}this.compilerInfo=[4,">= 1.0.0"],n=this.merge(n,e.helpers),a=a||{};var o,s,u="",c=this,l="function";return u+='\r\n"}),function(){"use strict";window.TSC=window.TSC||{},window.TSC.smartPlayerPreRollEventConstants=function(){return{PRE_ROLL_STARTED:"preRollStarted",PRE_ROLL_FINISHED:"preRollFinished",PRE_ROLL_FINISHED_ACTIONS:{REMOVE_NOW:"removeNow"}}}()}(),function(e,t){"use strict";e.TSC=e.TSC||{},e.TSC.preRollView=function(){var e;if(!t||!t.pre_roll_container_template)throw Error("TSC.preRollView: Template not found");return e=t.pre_roll_container_template,{render:function(t){var n={preRollSizeClass:"preRoll-fullPage",preRollSrc:t};return e(n)}}}()}(window,TSC.templates),function(e,t,n,i,a){e.TSC=e.TSC||{},e.TSC.preRollController=function(){function r(e){if(e=e.originalEvent,e.data&&"function"==typeof e.data.indexOf&&-1!==e.data.indexOf("smartPlayerEventName")){var t=n.parse(e.data);switch(t.smartPlayerEventName){case i.PRE_ROLL_STARTED:u&&u();break;case i.PRE_ROLL_FINISHED:switch(t.data.action){case i.PRE_ROLL_FINISHED_ACTIONS.REMOVE_NOW:s()}}}}function o(){c.removeClass("preRollHidden")}function s(){c&&(l.unbind("message",r),c.unbind("load",o),c.remove(),c=void 0,u=void 0)}var u,c,l;return l=t(e),{createView:function(e,n){c=t(a.render(e)).appendTo("body"),c.bind("load",o),u=n,l.bind("message",r)},viewExists:function(){return void 0!=c},destroyView:s}}()}(window,jQuery,JSON,TSC.smartPlayerPreRollEventConstants,TSC.preRollView),function(e,t){e.TSC=e.TSC||{},e.TSC.externalMessageController=function(){function n(e){if(e.data&&"function"==typeof e.data.indexOf&&-1!==e.data.indexOf("smartPlayerEventName")){var n=t.parse(e.data);i[n.smartPlayerEventName]&&i[n.smartPlayerEventName].call(this,n.data)}}var i={};return e.addEventListener?e.addEventListener("message",n,!1):e.attachEvent("onmessage",n),{addCallback:function(e,t){i[e]=t},removeCallback:function(e){i[e]&&(i[e]=void 0)},removeAllCallbacks:function(){i={}}}}()}(this,JSON),function(e){e.TSC=e.TSC||{},e.TSC.windowWrapper=function(){return{getLocationHref:function(){return e.location.href}}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.languageCodes=function(){"use strict";var e="en-US",t="de-DE",n="ja-JP";return{ENGLISH:e,GERMAN:t,JAPANESE:n,ENU:e,DEU:t,JPN:n,isValid:function(i){return i!==e&&i!==t&&i!==n?!1:!0}}}()}(this),function(e,t){e.TSC=e.TSC||{},e.TSC.localizationStrings=function(){"use strict";var e,n="default",i=n,a="",r={};return r.xmpError={},r.xmpError[t.ENGLISH]="There seems to be a problem accessing certain features of this video. Please contact the video Author.",r.xmpError[t.GERMAN]="Einige Merkmale dieses Videos sind offenbar nicht zugänglich. Bitte setzen Sie sich mit dem Autor des Videos in Verbindung.",r.xmpError[t.JAPANESE]="このビデオの特定機能にアクセスする時に問題が発生したようです。ビデオの作成者に連絡してください。",r.xmpSecurity={},r.xmpSecurity[t.ENGLISH]="Certain features in your video are currently disabled due to Local Network Security. These features work correctly when the video is played from a Website or Server.",r.xmpSecurity[t.GERMAN]="Einige Merkmale Ihrem Video sind zurzeit aufgrund der Sicherheitseinstellungen im lokalen Netzwerk deaktiviert. Diese Merkmale funktionieren wie vorgesehen, wenn das Video über eine Website oder einen Server wiedergegeben wird.",r.xmpSecurity[t.JAPANESE]="ローカル ネットワークのセキュリティのために、ビデオの特定機能が現在無効になっています。これらの機能は、Web サイトまたはサーバーからビデオを再生すると正しく動作します。",r.videoNotSupported={},r.videoNotSupported[t.ENGLISH]="Your browser cannot play this video.",r.videoNotSupported[t.GERMAN]="Ihr Browser kann dieses Video nicht wiedergeben.",r.videoNotSupported[t.JAPANESE]="お使いのブラウザではこのビデオを再生できません。",r.videoNotSupportedUseFlash={},r.videoNotSupportedUseFlash[t.ENGLISH]="This browser does not support the video format needed for playback. Please install the Flash Player or use a different browser.",r.videoNotSupportedUseFlash[t.GERMAN]="Dieser Browser unterstützt das zur Wiedergabe erforderliche Videoformat nicht. Bitte installieren Sie den Flash Player oder verwenden Sie einen anderen Browser.",r.videoNotSupportedUseFlash[t.JAPANESE]="このブラウザは、再生に必要なビデオ形式をサポートしていません。最新版のFlash Player をインストールするか、別のブラウザを使用してください。",r.noWebMSupport={},r.noWebMSupport[t.ENGLISH]="This browser does not support WebM video.",r.noWebMSupport[t.GERMAN]="Dieser Browser bietet keine WebM-Video-Unterstützung.",r.noWebMSupport[t.JAPANESE]="このブラウザは WebM ビデオをサポートしていません。",r.playlistLocalError={},r.playlistLocalError[t.ENGLISH]="Videos in a Playlist cannot be viewed from a local drive. The videos will play correctly from a Playlist hosted on a Website or Server.",r.playlistLocalError[t.GERMAN]="Videos in einer Wiedergabeliste können nicht von einem lokalen Laufwerk aus abgespielt werden. Die Videos werden über eine auf einer Website oder einem Server gehostete Wiedergabeliste korrekt abgespielt.",r.playlistLocalError[t.JAPANESE]="プレイリストのビデオはローカル ドライブから再生できません。Web サイトまたはサーバーでホストされているプレイリストからは、ビデオが正しく再生されます。",r.search={},r.search[t.ENGLISH]="Search…",r.search[t.GERMAN]="Suchen…",r.search[t.JAPANESE]="検索…",r.playerRateText={},r.playerRateText[t.ENGLISH]="Playback Speed",r.playerRateText[t.GERMAN]="Wiedergabe-Geschwindigkeit",r.playerRateText[t.JAPANESE]="再生速度",r.playerRateOptionsText={},r.playerRateOptionsText[t.ENGLISH]={.25:"0.25",.5:"0.5",.75:"0.75",1:"normal",1.25:"1.25",1.5:"1.5",1.75:"1.75",2:"2.0"},r.playerRateOptionsText[t.GERMAN]={.25:"0.25",.5:"0.5",.75:"0.75",1:"normal",1.25:"1.25",1.5:"1.5",1.75:"1.75",2:"2.0"},r.playerRateOptionsText[t.JAPANESE]={.25:"0.25",.5:"0.5",.75:"0.75",1:"標準",1.25:"1.25",1.5:"1.5",1.75:"1.75",2:"2.0"},r.videoFailedToLoad={},r.videoFailedToLoad[t.ENGLISH]="This video failed to load completely.",r.videoFailedToLoad[t.GERMAN]="Dieses Video wurde nicht vollständig geladen.",r.videoFailedToLoad[t.JAPANESE]="このビデオを正しく読み込めませんでした。",r.videoFailedToLoadUseFlash={},r.videoFailedToLoadUseFlash[t.ENGLISH]="This video failed to load completely. You may need to try another browser or use the Flash plugin.",r.videoFailedToLoadUseFlash[t.GERMAN]="Dieses Video wurde nicht vollständig geladen. Vielleicht müssen Sie einen anderen Browser ausprobieren oder das Flash-Plug-In verwenden.",r.videoFailedToLoadUseFlash[t.JAPANESE]="このビデオを正しく読み込めませんでした。別のブラウザを試すか、Flash プラグインを使用する必要があります。",r.searchDisabledFullScreen={},r.searchDisabledFullScreen[t.ENGLISH]="Search is disabled in fullscreen mode.",r.searchDisabledFullScreen[t.GERMAN]="Die Suche ist im Vollbildmodus deaktiviert.",r.searchDisabledFullScreen[t.JAPANESE]="フル画面モードでは検索機能は無効です。",r.videoLoading={},r.videoLoading[t.ENGLISH]="Please wait... the video is loading.",r.videoLoading[t.GERMAN]="Bitte warten... Das Video wird geladen.",r.videoLoading[t.JAPANESE]="お待ちください... ビデオを読み込んでいます。",r.clickToClose={},r.clickToClose[t.ENGLISH]="Click to Close",r.clickToClose[t.GERMAN]="Hier klicken, um zu schließen",r.clickToClose[t.JAPANESE]="クリックして終了",r.playWithSmartPlayer={},r.playWithSmartPlayer[t.ENGLISH]="Play with TechSmith Smart Player",r.playWithSmartPlayer[t.GERMAN]="Mit TechSmith Smart Player abspielen",r.playWithSmartPlayer[t.JAPANESE]="クリックして終了",r.playVideoOnly={},r.playVideoOnly[t.ENGLISH]="Play Video Only",r.playVideoOnly[t.GERMAN]="Nur Video wiedergeben",r.playVideoOnly[t.JAPANESE]="ビデオの再生のみ",r.openWithSmartPlayer={},r.openWithSmartPlayer[t.ENGLISH]="Open video in TechSmith Smart Player",r.openWithSmartPlayer[t.GERMAN]="Öffnen Sie das Video im TechSmith Smart Player.",r.openWithSmartPlayer[t.JAPANESE]="TechSmith Smart Player でビデオを開く",r.FullscreenKeyboardDisabled={},r.FullscreenKeyboardDisabled[t.ENGLISH]="Warning!, keyboard support is disabled in fullscreen.",r.FullscreenKeyboardDisabled[t.GERMAN]="Warnung! Tastaturunterstützung ist im Vollbildmodus deaktiviert.",r.FullscreenKeyboardDisabled[t.JAPANESE]="警告! フル画面ではキーボード サポートは無効です。",r.txtRequiredMessage={},r.txtRequiredMessage[t.ENGLISH]="A first name, last name, and email address are required to take this quiz.",r.txtRequiredMessage[t.GERMAN]="Sie müssen Vor- und Nachnamen und eine E-Mail-Adresse angeben, um an diesem Quiz teilzunehmen.",r.txtRequiredMessage[t.JAPANESE]="このクイズに解答するには、氏名と電子メール アドレスを入力する必要があります。",r.txtSkip={},r.txtSkip[t.ENGLISH]="Watch Video Only - No Quiz",r.txtSkip[t.GERMAN]="Nur Video ansehen - Kein Quiz",r.txtSkip[t.JAPANESE]="ビデオを見るだけでクイズに解答しない",r.txtBegin={},r.txtBegin[t.ENGLISH]="Watch Video and Take Quiz",r.txtBegin[t.GERMAN]="Video ansehen und am Quiz teilnehmen",r.txtBegin[t.JAPANESE]="ビデオを見てクイズに解答する",r.txtFirstName={},r.txtFirstName[t.ENGLISH]="First",r.txtFirstName[t.GERMAN]="Vorname",r.txtFirstName[t.JAPANESE]="姓",r.txtLastName={},r.txtLastName[t.ENGLISH]="Last",r.txtLastName[t.GERMAN]="Nachname",r.txtLastName[t.JAPANESE]="名",r.txtEmail={},r.txtEmail[t.ENGLISH]="Email",r.txtEmail[t.GERMAN]="E-Mail",r.txtEmail[t.JAPANESE]="電子メール",r.txtReview={},r.txtReview[t.ENGLISH]="Replay Last Section",r.txtReview[t.GERMAN]="Letzten Abschnitt erneut wiedergeben",r.txtReview[t.JAPANESE]="最後に選択した範囲をもう一度再生",r.txtAnswerQuestion={},r.txtAnswerQuestion[t.ENGLISH]="Take Quiz Now",r.txtAnswerQuestion[t.GERMAN]="Jetzt am Quiz teilnehmen",r.txtAnswerQuestion[t.JAPANESE]="今すぐクイズに解答する",r.txtPrev={},r.txtPrev[t.ENGLISH]="Previous",r.txtPrev[t.GERMAN]="Zurück",r.txtPrev[t.JAPANESE]="前へ",r.txtNext={},r.txtNext[t.ENGLISH]="Next",r.txtNext[t.GERMAN]="Weiter",r.txtNext[t.JAPANESE]="次へ",r.txtSubmit={},r.txtSubmit[t.ENGLISH]="Submit Answers",r.txtSubmit[t.GERMAN]="Antworten abschicken",r.txtSubmit[t.JAPANESE]="解答・回答の送信",r.txtSubmittingAnswers={},r.txtSubmittingAnswers[t.ENGLISH]="Please wait... submitting answers.",r.txtSubmittingAnswers[t.GERMAN]="Bitte warten... Antwort wird gesendet.",r.txtSubmittingAnswers[t.JAPANESE]="少々お待ちください... 回答を送信中です。",r.txtContinue={},r.txtContinue[t.ENGLISH]="Continue",r.txtContinue[t.GERMAN]="Fortsetzen",r.txtContinue[t.JAPANESE]="続行",r.txtReviewAnswer={},r.txtReviewAnswer[t.ENGLISH]="View Answers",r.txtReviewAnswer[t.GERMAN]="Antworten anzeigen",r.txtReviewAnswer[t.JAPANESE]="解答・回答を表示",r.txtAnswerSent={},r.txtAnswerSent[t.ENGLISH]="Your answers have been sent.",r.txtAnswerSent[t.GERMAN]="Ihre Antworten wurden gesendet.",r.txtAnswerSent[t.JAPANESE]="解答・回答が送信されました。",r.txtDisabledLocalQuizReporting={},r.txtDisabledLocalQuizReporting[t.ENGLISH]="Keyboard input is disabled in full screen mode. Press the ESC key to exit full screen mode.",r.txtDisabledLocalQuizReporting[t.GERMAN]="Bestimmte Merkmale in Ihrem Video sind aufgrund der Sicherheitseinstellungen im lokalen Netzwerk zurzeit deaktiviert. Sie funktionieren jedoch ordnungsgemäß, wenn das Video von einer Website oder einem Server aus wiedergegeben wird.",r.txtDisabledLocalQuizReporting[t.JAPANESE]="ローカル ネットワークのセキュリティの理由により、ビデオの特定機能が現在無効化されています。Web サイトまたはサーバーからビデオを再生する場合、これらの機能は正しく動作します。",r.txtErrorMessage={},r.txtErrorMessage[t.ENGLISH]="We're sorry, a network error has prevented the quiz from loading. The video is available to view. To try and reload the quiz, refresh the browser page or check your network connection.",r.txtErrorMessage[t.GERMAN]="Das Quiz konnte aufgrund eines Netzwerkfehlers nicht geladen werden. Das Video steht zur Ansicht bereit. Sie können versuchen das Quiz erneut zu laden, indem Sie die Browserseite aktualisieren bzw. Ihre Netzwerkverbindung überprüfen.",r.txtErrorMessage[t.JAPANESE]="申し訳ありませんが、ネットワーク エラーによりクイズを読み込めませんでした。ビデオは表示できます。クイズを再度読み込むには、ブラウザのページを更新するか、ネットワーク接続を確認してください。",r.txtQuizErrorMessage={},r.txtQuizErrorMessage[t.ENGLISH]="We're attempting to save your response. Please make sure you have an active internet connection.",r.txtQuizErrorMessage[t.GERMAN]="Wir versuchen, Ihre Antworten zu speichern. Bitte achten Sie darauf, dass Sie eine aktive Internet Verbindung haben.",r.txtQuizErrorMessage[t.JAPANESE]="返答の保存を試みています。インターネットに正しく接続しているか確認してください。",r.txtLoaderMessageInstance={},r.txtLoaderMessageInstance[t.ENGLISH]="Please wait... the quiz is loading.",r.txtLoaderMessageInstance[t.GERMAN]="Bitte warten... Das Quiz wird geladen.",r.txtLoaderMessageInstance[t.JAPANESE]="お待ちください... クイズを読み込んでいます。",r.txtLoaderMessageDefinition={},r.txtLoaderMessageDefinition[t.ENGLISH]="Please wait... the quiz is loading.",r.txtLoaderMessageDefinition[t.GERMAN]="Bitte warten... Das Quiz wird geladen.",r.txtLoaderMessageDefinition[t.JAPANESE]="お待ちください... クイズを読み込んでいます。",r.txtQuestionCount={},r.txtQuestionCount[t.ENGLISH]="{{currentQuestion}} of {{totalQuestions}}",r.txtQuestionCount[t.GERMAN]="{{currentQuestion}} von {{totalQuestions}}",r.txtQuestionCount[t.JAPANESE]="{{currentQuestion}} 問 ({{totalQuestions}} 問中)",r.txtCorrectAnswer={},r.txtCorrectAnswer[t.ENGLISH]="{{numberCorrect}} correct answer.",r.txtCorrectAnswer[t.GERMAN]="{{numberCorrect}} richtige Antwort.",r.txtCorrectAnswer[t.JAPANESE]="{{numberCorrect}} 個の正解があります。",r.txtCorrectAnswers={},r.txtCorrectAnswers[t.ENGLISH]="{{numberCorrect}} correct answers.",r.txtCorrectAnswers[t.GERMAN]="{{numberCorrect}} richtige Antworten.",r.txtCorrectAnswers[t.JAPANESE]="{{numberCorrect}} 個の正解があります。",r.txtUngradedQuestion={},r.txtUngradedQuestion[t.ENGLISH]="{{numberUngraded}} question could not be scored.",r.txtUngradedQuestion[t.GERMAN]="{{numberUngraded}} Frage konnte nicht bewertet werden.",r.txtUngradedQuestion[t.JAPANESE]="{{numberUngraded}} 個の問題のスコアを付けることができませんでした。",r.txtUngradedQuestions={},r.txtUngradedQuestions[t.ENGLISH]="{{numberUngraded}} questions could not be scored.",r.txtUngradedQuestions[t.GERMAN]="{{numberUngraded}} Fragen konnte nicht bewertet werden.",r.txtUngradedQuestions[t.JAPANESE]="{{numberUngraded}} 個の問題のスコアを付けることができませんでした。",r.txtQuizFullscreenMode={},r.txtQuizFullscreenMode[t.ENGLISH]="Keyboard input is disabled in full screen mode. Press the ESC key to exit full screen mode.",r.txtQuizFullscreenMode[t.GERMAN]="Die Tastatureingabe ist im Vollbildmodus deaktiviert. Drücken Sie >Esc<, um den Vollbildmodus zu beenden.",r.txtQuizFullscreenMode[t.JAPANESE]="全画面表示ではキーボード入力は無効です。ESC キーを押すと全画面モードを終了します。",r.accessBtnClearSearch={},r.accessBtnClearSearch[t.ENGLISH]="Clear Search",r.accessBtnClearSearch[t.GERMAN]="Suche löschen",r.accessBtnClearSearch[t.JAPANESE]="検索をクリア",r.accessBtnRewind={},r.accessBtnRewind[t.ENGLISH]="Rewind",r.accessBtnRewind[t.GERMAN]="Zurückspulen",r.accessBtnRewind[t.JAPANESE]="巻き戻し",r.accessBtnPlay={},r.accessBtnPlay[t.ENGLISH]="Play",r.accessBtnPlay[t.GERMAN]="Wiedergabe",r.accessBtnPlay[t.JAPANESE]="再生",r.accessBtnPrevious={},r.accessBtnPrevious[t.ENGLISH]="Previous",r.accessBtnPrevious[t.GERMAN]="Zurück",r.accessBtnPrevious[t.JAPANESE]="前へ",r.accessBtnNext={},r.accessBtnNext[t.ENGLISH]="Next",r.accessBtnNext[t.GERMAN]="Weiter",r.accessBtnNext[t.JAPANESE]="次へ",r.accessBtnVolume={},r.accessBtnVolume[t.ENGLISH]="Volume",r.accessBtnVolume[t.GERMAN]="Volumen",r.accessBtnVolume[t.JAPANESE]="音量",r.accessBtnClosedCaption={},r.accessBtnClosedCaption[t.ENGLISH]="Closed Caption",r.accessBtnClosedCaption[t.GERMAN]="Geschlossene Beschriftung",r.accessBtnClosedCaption[t.JAPANESE]="クローズド キャプション",r.accessBtnTableOfContents={},r.accessBtnTableOfContents[t.ENGLISH]="Table of Contents",r.accessBtnTableOfContents[t.GERMAN]="Inhaltsverzeichnis",r.accessBtnTableOfContents[t.JAPANESE]="目次",r.accessBtnSettings={},r.accessBtnSettings[t.ENGLISH]="Player Settings",r.accessBtnSettings[t.GERMAN]="Einstellungen",r.accessBtnSettings[t.JAPANESE]="プレーヤー設定",r.accessBtnFullScreen={},r.accessBtnFullScreen[t.ENGLISH]="Full Screen",r.accessBtnFullScreen[t.GERMAN]="Vollbild",r.accessBtnFullScreen[t.JAPANESE]="全画面",{setLanguage:function(e){t.isValid(e)&&(i=e) +},getLanguage:function(){return i},getQuestionCountPreposition:function(){if(!a){e=i===n?t.ENGLISH:i;for(var o=r.txtQuestionCount[e].split(" "),s=0;o.length>s;s++)if(-1===o[s].indexOf("{{")){a=o[s];break}}return a},getString:function(a){if(void 0!==r[a])return e=i===n?t.ENGLISH:i,r[a][e];throw Error("getString(): '"+a+"' string does not exist in the player.")},setString:function(a,o){if(void 0===r[a])throw Error("setString(): '"+a+"' string does not exist in the player.");e=i===n?t.ENGLISH:i,r[a][e]=o}}}()}(this,TSC.languageCodes),function(e,t,n){e.TSC=e.TSC||{},e.TSC.iOSTextInputFix=function(){"use strict";function i(e){e.keyCode===u?c--:c++;var t=a.value,n=t.length-c;if(0>n){var i=a.cloneNode(!0);s.appendChild(i),l++,setTimeout(function(){i.focus(),s.removeChild(i),r&&r(l)},100),c=a.value.length}}var a,r,o=t(e),s=e.document.getElementsByTagName("body")[0],u=8,c=0,l=0,d=function(){a=void 0,o.unbind("keyup",i)};return{setOnBugCallback:function(e){r=e},watch:function(e){d(),a=e,c=a.value===n.getString("search")?0:a.value.length,o.bind("keyup",i)},clear:d}}()}(this,jQuery,TSC.localizationStrings),function(e){e.TSC=e.TSC||{},e.TSC.playerType=function(){return{HTML5_VIDEO:"html5",FLASH_VIDEO:"flash",YOUTUBE:"youtube",IMAGE:"image",NOT_SUPPORTED:"not_supported"}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.mediaMimeType=function(){"use strict";return{WEBM:"video/webm",MP4:"video/mp4",OGG:"video/ogg",JPG:"image/jpeg",PNG:"image/png",GIF:"image/gif",UNKNOWN:""}}()}(this),function(e,t,n){e.TSC=e.TSC||{},e.TSC.deviceInfo=function(){"use strict";function i(){switch(e.location.protocol){case"http:":case"https:":return!1;case"file:":return!0}}function a(){for(var e in navigator.plugins)if(navigator.plugins[e].filename&&-1!==navigator.plugins[e].filename.toLowerCase().indexOf("pepflashplayer"))return!0;return!1}function r(){if(/iP(hone|od|ad)/.test(navigator.platform)){var e=navigator.appVersion.match(/OS (\d+)_(\d+)_?(\d+)?/);return[parseInt(e[1],10),parseInt(e[2],10),parseInt(e[3]||0,10)]}}function o(){var t=document.createElement("video")||!1;if(s=t&&t.canPlayType!==void 0,u=s&&("maybe"===t.canPlayType(n.MP4)||"probably"===t.canPlayType(n.MP4)),c=s&&("maybe"===t.canPlayType(n.OGG)||"probably"===t.canPlayType(n.OGG)),l=s&&("maybe"===t.canPlayType(n.WEBM)||"probably"===t.canPlayType(n.WEBM)),m=null!==navigator.userAgent.match(/iPad/i),v=null!==navigator.userAgent.match(/iPhone/i),A=null!==navigator.userAgent.match(/iPod/i),S=-1!==navigator.userAgent.toLowerCase().indexOf("android"),h=-1!==navigator.userAgent.toLowerCase().indexOf("chrome"),p="Microsoft Internet Explorer"==navigator.appName,h&&i()&&(y=a()),p){var o=navigator.userAgent,I=RegExp("MSIE ([0-9]{1,}[.0-9]{0,})");null!=I.exec(o)&&(d=parseFloat(RegExp.$1))}(m||v||A)&&(f=r()),g=-1!==navigator.userAgent.toLowerCase().indexOf("firefox"),b=null!==navigator.userAgent.match(/Nuevo/i),C=null!==navigator.userAgent.match(/Safari/i),E=640>screen.availWidth&&480>screen.availHeight||480>screen.availWidth&&640>screen.availHeight,T=e.devicePixelRatio&&e.devicePixelRatio>1,(v||A)&&b&&T&&(m=!0,v=A=!1)}var s,u,c,l,d,f,p=!1,g=!1,h=!1,m=!1,v=!1,A=!1,S=!1,b=!1,C=!1,T=!1,E=!1,y=!1;return{isSmallScreen:function(){return E},isRetinaDisplay:function(){return T},isNuevoApp:function(){return b},isIPad:function(){return m},isIPhoneOrIPod:function(){return v||A},isIE:function(){return p},getIEVersion:function(){return d},getIOSMajorVersion:function(){return f?f[0]:null},isFirefox:function(){return g},isChrome:function(){return h},isSafari:function(){return C},isAndroid:function(){return S},canPlayHTML5Video:function(){return s},canPlayMP4:function(){return u},canPlayOgg:function(){return c},canPlayWebM:function(){return l},isTouchInterface:function(){return t.touch||this.isTouchIEInterface()},isTouchIEInterface:function(){return navigator.msMaxTouchPoints},getFullScreenChangeEventNames:function(){return"webkitfullscreenchange MSFullscreenChange mozfullscreenchange fullscreenchange"},requiresManualPreload:function(){return m||S},supportsFullScreen:function(){return document.fullscreenEnabled||document.webkitFullscreenEnabled||document.msFullscreenEnabled||document.mozFullScreenEnabled},supportsFullScreenKeyboardInput:function(){var e=!1;return h&&void 0!==Element.ALLOW_KEYBOARD_INPUT&&(e=!0),e},mediaLocation:function(){var e=document.location.href,t=e.lastIndexOf("/"),n=e.substring(0,t+1);return p&&(n=encodeURI(n)),n=n.split("%25").join("%")},isLocal:function(){return i()},isLocalPepperFlash:function(){return y},lookAtDevice:function(){o()}}}()}(this,Modernizr,TSC.mediaMimeType),function(e,t,n){e.TSC=e.TSC||{},e.TSC.playerConfiguration=function(){"use strict";function e(e){var t=e.replace(/’/g,"'");return t}function i(e){return/[^\u0000-\u00ff]/.test(e)}var a,r,o,s,u,c,l,d,f,p,g="13.0.0",h=[],m="'playerProductInstall.swf",v="tsc_player.swf",A="100%",S="100%",b="stop",C=!0,T=!0,E=!1,y=-1,I=!1,w=!1,N="left",x="#000",R=!1,P=!1,M=!0,L=!1,k=!0,_=!0,O=!1,D=!1,B=!1,Q=!0,V=!0,q=!1,G=!1,F=!1,U=!1,H=".",z=!1,W="",J=!0,Y=!1,j=!1,K=void 0;return{isIEOnServerWithUnicode:function(){return 1==t.isIE()&&1==TSC.playerConfiguration.runOnServer()&&P},runOnServer:function(){var e=!1,t=document.location.href;return 0==t.indexOf("http")&&(e=!0),e},getUnicodeSafeString:function(e){return void 0===e?e:P?1==t.isIE()?TSC.playerConfiguration.runOnServer()?i(e)?encodeURI(e):e:decodeURI(e):encodeURI(e):e},getMediaSrc:function(){return h.length>0?h[0]:""},clearMediaSrc:function(){h=[]},setMediaSrc:function(t){h[0]=e(t)},addMediaSrc:function(t){h.push(e(t))},getMediaSources:function(){return h},getMediaFileName:function(){var e,t=h.length>0?h[0]:void 0;if(t){var n=t.split("/");e=n[n.length-1],e=e.split("?")[0],(void 0===e||""===e)&&(e="Unnamed Media")}else e="No Media";return e},getXMPSrc:function(){return TSC.playerConfiguration.getUnicodeSafeString(a)},setXMPSrc:function(t){a=e(t)},setSwfBase:function(t){H=e(t)},getSwfBase:function(){return H},getConfigurationSrc:function(){return TSC.playerConfiguration.getUnicodeSafeString(r)},setConfigurationSrc:function(e){r=e},getPosterImageSrc:function(){return TSC.playerConfiguration.getUnicodeSafeString(o)},setPosterImageSrc:function(e){o=e},getUnableToDisplayContentString:function(){return n.getString("videoNotSupported")},getFlashUpdateBootstrapSwf:function(){return m},setFlashUpdateBootstrapSwf:function(e){m=e},getFlashPlayerSwf:function(){return v},setFlashPlayerSwf:function(t){v=e(t)},getPlayerWidth:function(){return A},setPlayerWidth:function(e){A=e},getPlayerHeight:function(){return S},setPlayerHeight:function(e){S=e},getEndActionType:function(){return b},setEndActionType:function(e){b=e},getEndActionParam:function(){return C},setEndActionParam:function(e){C=e},getIsSearchable:function(){return T},setIsSearchable:function(e){T=e},getAutoPlayMedia:function(){return E},setAutoPlayMedia:function(e){E=e},getAllowRewind:function(){return y},setAllowRewind:function(e){y=e},getCaptionsEnabled:function(){return I},setCaptionsEnabled:function(e){I=e},getSidebarEnabled:function(){return w},setSidebarEnabled:function(e){w=e},getSidebarLocation:function(){return N},setSidebarLocation:function(e){N=e},getBackgroundColor:function(){return x},setBackgroundColor:function(e){x=e},getMinFlashPlayerVersion:function(){return g},setDebugHotspot:function(e){R=e},getDebugHotspot:function(){return R},setAutoHideControls:function(e){M=e},getAutoHideControls:function(){return M},setProcessUnicodeNames:function(e){P=e},getProcessUnicodeNames:function(){return P},setReportScormComplete:function(e){L=e},getReportScormComplete:function(){return L},setEnforceLinearAssessment:function(e){k=e},getEnforceLinearAssessment:function(){return k},setDisableFullframeMode:function(e){_=e},getDisableFullframeMode:function(){return _},getDisableControls:function(){return O},setDisableControls:function(e){O=e},getMobileWebViewCanAutoPlay:function(){return D},setMobileWebViewCanAutoPlay:function(e){D=e},setGoogleAnalyticsID:function(e){s=e},getGoogleAnalyticsID:function(){return s},setGAPageViewTracking:function(e){Q=e},getGAPageViewTracking:function(){return Q},setGAEventTracking:function(e){V=e},getGAEventTracking:function(){return V},useCustomEventTracking:function(e,t){q=e,u=t},getTrackEvents:function(){return q||void 0!==s},getCustomEventTracking:function(){return q},getCustomEventCallback:function(){return u},setAltEventCategoryAsFilename:function(e){G=e},getAltEventCategoryAsFilename:function(){return G},setAltLoadTimeAsSeconds:function(e){F=e},getAltLoadTimeAsSeconds:function(){return F},setAdvancedSeeking:function(e){B=e},getAdvancedSeeking:function(){return B},setTechSmithAccessToken:function(e){l=e,z=!0},getTechSmithAccessToken:function(){return l},getIsUserIdentified:function(){return z},setJumpToTime:function(e){c=e},getJumpToTime:function(){return c},setDebugUIMode:function(e){U=e},getDebugUIMode:function(){return U},setFathomId:function(e){d=e},getFathomId:function(){return d},setAdditionalAppQueryParamsFromJson:function(e){var t="";for(var n in e)t+="&"+n+"="+e[n];W=t},getAdditionalAppQueryString:function(){return W},setScormStartPt:function(e){p=e},getScormStartPt:function(){return p},setEmbedIFrameId:function(e){f=e},getEmbedIFrameId:function(){return f},setUseSlimAppSplashScreen:function(e){J=e},getUseSlimAppSplashScreen:function(){return J},saveConfigurationFromQueryString:function(e){if(e instanceof Array){var t,n,i=e.length;for(t=0;i>t;t++)if(n=e[t].split("="),2===n.length)switch(n[0].toLowerCase()){case"embediframeid":f=n[1];break;case"t":c=n[1];break;case"forceflash":"true"==n[1].toLowerCase()?Y=!0:"false"==n[1].toLowerCase()&&(Y=!1)}}},setForceFlashPlayer:function(e){Y=e},getForceFlashPlayer:function(){return Y},setPrioritizeFullScreen:function(){},getShowYouTubeAnnotations:function(){return j},setShowYouTubeAnnotations:function(e){j=e},getPreRollSrc:function(){return K},setPreRollSrc:function(e){K=e}}}()}(this,TSC.deviceInfo,TSC.localizationStrings),function(e){e.TSC=e.TSC||{},e.TSC.textSanitizer=function(){"use strict";return{htmlEncode:function(e,t){return e?t?e.replace(/&/g,"&").replace(/(<|&lt;)/g,"<").replace(/(>|&gt;)/g,">").replace(/&amp;/g,"&"):e.replace(/&/g,"&").replace(/("|&quot;)/g,""").replace(/(<|&lt;)/g,"<").replace(/(>|&gt;)/g,">").replace(/&amp;/g,"&"):e}}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.questionType=function(){"use strict";return{FILL_IN:"FITB",CHOICE:"MC",SHORT:"SHORT"}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.reportType=function(){"use strict";var e="NONE",t="API",n="SCORM",i="APIANDSCORM";return{NONE:e,API:t,SCORM:n,APIANDSCORM:i,isValid:function(a){return a===e||a===t||a===n||a===i}}}()}(this),function(e,t,n){e.TSC=e.TSC||{},e.TSC.quizModel=function(){"use strict";function e(){v=[];for(var e=C.length,t=0,n=0,i=0;e>i;i++)C[i].complete===!1&&(t=C[i].mediaTimeCode-T,t=0>t?0:t,n=C[i].mediaTimeCode+E,v.push({quesitonSetId:i,rangeStart:t,rangeEnd:n,time:C[i].mediaTimeCode}))}function i(){var e={};e.quizId=p,e.lang=I,e.projectName=d,e.productionName=c,e.originId=l,e.mediaDuration=y,e.reportRecipients=[g],e.questionSets=[];for(var t,n,i,a=C.length,r=0;a>r;r++){e.questionSets.push({name:C[r].questionSetTitle,mediaTimePosition:C[r].mediaTimeCode,order:Number(r)+1,questions:[]}),t=C[r].questions.length;for(var o=0;t>o;o++){i=[],n=C[r].questions[o].choices.length;for(var s=0;n>s;s++)i.push(C[r].questions[o].choices[s]);e.questionSets[r].questions.push({type:C[r].questions[o].type,id:C[r].questions[o].id,questionText:C[r].questions[o].text,choices:i,correctAnswer:C[r].questions[o].correctAnswer})}}return JSON.stringify(e)}function a(e){var t={};t.quizId=p,t.order=e+1,t.questions=[];for(var i,a=C[e].questions.length,r=0;a>r;r++)i=C[e].questions[r].type===n.CHOICE&&"0"===C[e].questions[r].correctAnswer?{type:C[e].questions[r].type,id:C[e].questions[r].id,duration:C[e].questions[r].duration,response:C[e].questions[r].response,segmentWatched:C[e].percentOfVideoSegmentWatched}:{type:C[e].questions[r].type,id:C[e].questions[r].id,duration:C[e].questions[r].duration,response:C[e].questions[r].response,correct:C[e].questions[r].isResponseCorrect,segmentWatched:C[e].percentOfVideoSegmentWatched},t.questions.push(i);return JSON.stringify(t)}function r(e,t){return C[e]&&C[e].questions[t]?!0:!1}function o(e){for(var t=0,n=C[e],i=n.questions.length,a=0;i>a;a++){var r=n.questions[a];r.isQuestionGraded&&t++}return t}function s(e){for(var t=0,n=C[e],i=n.questions.length,a=0;i>a;a++){var r=n.questions[a];r.isQuestionGraded&&r.isResponseCorrect&&t++}return t}function u(e,t,i){if(e===n.CHOICE){if(t&&t>0)return!0}else{if(e!==n.FILL_IN)return!1;if(i.length>0)return!0}}var c,l,d,f,p,g,h,m,v,A=t.NONE,S=!0,b=!1,C=[],T=250,E=100,y=0,I="",w=2e3,N=!0,x=!1;return{clearAllQuestions:function(){C=[]},getQuizDefinition:function(){return i()},getUseQuizApi:function(){return A===t.API||A===t.APIANDSCORM},getUseScorm:function(){return A===t.SCORM||A===t.APIANDSCORM},getDisplayFeedback:function(e){return C[e].displayFeedback},setQuizTitle:function(e){f=e},getQuizTitle:function(){return f},setProductionMetadata:function(e,t,n){c=t,l=n,d=e},setQuizID:function(e){p=e},getQuizID:function(){return p},setAuthoredEmail:function(e){g=e},getAuthoredEmail:function(){return g},setClientId:function(e){h=e},getClientId:function(){return h},setQuizHash:function(e){m=e},getQuizHash:function(){return m},setMediaDuration:function(e){y=e},setReportMethod:function(e){t.isValid(e)&&(A=e)},getReportMethod:function(){return A},setRequireUserId:function(e){S=e},getRequireUserId:function(){return S},setHideReplay:function(e){b=e},getHideReplay:function(){return b},setAllowSkipQuiz:function(e){N="0"===e||e===!1?!1:!0},getAllowSkipQuiz:function(){return N},setLocale:function(e){I=e},getLocale:function(){return I},setQuestionSetComplete:function(t){t>=0&&C.length>t&&(C[t].complete=!0,e())},getQuestionSetMarkerTimes:function(){return v||e(),v},numberQuestionSets:function(){return C.length},numberQuestionsInSet:function(e){return void 0===C[e]?-1:C[e].questions.length},addQuestionSet:function(e,t,n){return C.push({questions:[],questionSetTitle:e,mediaTimeCode:t,displayFeedback:n,complete:!1,percentOfVideoSegmentWatched:0}),C.length-1},addQuestion:function(e,t,i,a,r,o){if(void 0!==C[e]){var s=u(t,o,r);(t===n.FILL_IN||t===n.SHORT)&&(x=!0),C[e].questions.push({type:t,id:i,text:a,choices:r,correctAnswer:o,isQuestionGraded:s,response:"",isResponseCorrect:!1,duration:0})}},getQuestionSetTitle:function(e){return e>=0&&C.length>e?C[e].questionSetTitle:""},getQuestionSetMarkerTime:function(e){return e>=0&&C.length>e?C[e].mediaTimeCode:-1},getQuestionType:function(e,t){return r(e,t)?C[e].questions[t].type:void 0},getQuestionApiId:function(e,t){return r(e,t)?C[e].questions[t].id:void 0},getQuestionText:function(e,t){return r(e,t)?C[e].questions[t].text:void 0},getQuestionChoices:function(e,t){return r(e,t)?C[e].questions[t].choices:void 0},getQuestionAnswer:function(e,t){return r(e,t)?C[e].questions[t].correctAnswer:void 0},setQuestionAnswer:function(e,t,n){C[e].questions[t].correctAnswer=n},setQuestionResponse:function(e,t,n){C[e].questions[t].response=n},getQuestionResponse:function(e,t){return r(e,t)?C[e].questions[t].response:void 0},getIsResponseCorrect:function(e,t){return r(e,t)?C[e].questions[t].isResponseCorrect:void 0},setIsResponseCorrect:function(e,t,n){C[e].questions[t].isResponseCorrect=n},getMinMarkerTimeDiff:function(){return w},getIsQuestionGraded:function(e,t){return r(e,t)?C[e].questions[t].isQuestionGraded:void 0},setIsQuestionGraded:function(e,t,n){C[e].questions[t].isQuestionGraded=n},getPreviousMarkerTimeForMarker:function(e){var t,n=0;if(e>0)if(e>=C.length)n=C[C.length-1].mediaTimeCode;else for(var i=e-1;i>=0;i--)if(t=C[Number(i)+1].mediaTimeCode-C[i].mediaTimeCode,t>=w){n=C[i].mediaTimeCode;break}return n},updatePercentageWatchedForQuestionSet:function(e,t){C[e].percentOfVideoSegmentWatched=t},addDurationToQuestion:function(e,t,n){C[e].questions[t].duration+=n},getApiDataForQuestionSet:function(e){return a(e)},getNumberOfCorrectInQuestionSet:function(e){return s(e)},getTotalNumberOfGradableInQuestionSet:function(e){return o(e)},getTotalNumberOfGradedQuestionSets:function(){for(var e=0,t=C.length,n=0;t>n;n++)o(n)>0&&e++;return e},getTotalNumberOfUngradableInQuestionSet:function(e){if(0>e||e>=C.length)return void 0;for(var t,n=0,i=C[e],a=i.questions.length,r=0;a>r;r++)t=i.questions[r],t.isQuestionGraded||n++;return n},getScormScore:function(){for(var e=0,t=0,n=C.length,i=0;n>i;i++)e+=o(i),t+=s(i);var a=100*(t/e);return a},getLastQuestionComplete:function(e){void 0===e&&(e=-1);for(var t=0,n=C.length,i=!0,a=0;n>a;a++)t=o(a),t>0&&C[a].complete===!1&&a!==e&&(i=!1);return i},quizContainsTextInputQuestions:function(){return x}}}()}(this,TSC.reportType,TSC.questionType),function(e,t,n,i,a,r){e.TSC=e.TSC||{},e.TSC.quizService=function(){"use strict";function e(){M=200,A&&A.call()}function o(e){M=200;var t;I?(L="mock_id",D=!0,t=15e3):(L=e.Id,D=e.DefinitionRequired,t=e.SampleRate),m&&m.call(this,L,D,t)}function s(e,t,n,i,r){t=JSON.stringify(t),a.isIE()&&9==a.getIEVersion()?u(e,t,n,i,r):c(e,t,n,i,r)}function u(e,t,n,i,a){var o=function(){if(n>0)setTimeout(function(){u(e,t,--n,i,a)},V);else if(a)try{c.responseText?a.call(JSON.parse(c.responseText)):a()}catch(r){throw"Quiz-service: JSON Parse failed on errorCallback inside sendXdrMessage() with text: "+c.responseText}},s=function(){r.logException("quiz-service: sendXdrMessage() failed after the server responded with an error."),o()},c=new XDomainRequest;c.timeout=B,c.open("post",e),c.onprogress=function(){},c.ontimeout=o,c.onerror=s,c.onload=function(){if(i)try{i(JSON.parse(c.responseText),n)}catch(e){throw"Quiz-service: JSON Parse failed on successCallback inside sendXdrMessage() with text: "+c.responseText}},setTimeout(function(){c.send(t)},0)}function c(e,n,i,a,o){var s=function(){i>0?setTimeout(function(){c(e,n,--i,a,o)},V):o&&o(response)},u=function(){r.logException("quiz-service: sendAjaxMessage() failed with server response: "+response.statusText+" : "+response.status),s()};t.ajax({url:e,type:"POST",data:n,contentType:"application/json",crossDomain:!0,timeout:B,error:function(e){"timeout"==e.statusText?s():u()},success:function(e){a&&a(e,i)}})}function l(e,t,n,i,a){if(I)return setTimeout(o,1e3),void 0;var u=P[O].url+N,c={QuizId:e};a.getIsUserIdentified()?c.AccessToken=a.getTechSmithAccessToken():(c.FirstName=t?t:"",c.LastName=n?n:"",c.Email=i?i:"");var l=function(e){r.logMessage("quiz-service: startQuizInstance() failed after "+Q+" retries."),S(e)},d=function(e,t){t&&Q>t&&r.logMessage("quiz-service: startQuizInstance() succeded after "+(Q-t)+" retries."),o(e)};s(u,c,Q,d,l)}function d(t,n,i){if(t){if(I)return setTimeout(e,1e3),void 0;var a=P[O].url+w+"?Quiz-Checksum="+n+"&Quiz-ClientId="+i+"&noop=1",o={DefinitionText:t},u=function(e){r.logMessage("quiz-service: sendQuizDefinitionToApi() failed after "+Q+" retries."),S(e)},c=function(t,n){n&&Q>n&&r.logMessage("quiz-service: sendQuizDefinitionToApi() succeded after "+(Q-n)+" retries."),e(t)};s(a,o,Q,c,u)}}function f(e,t){k=e,_=t;var n=1;if(I){var i={0:{isCorrect:!0},1:{isCorrect:!0},2:{isCorrect:!0,correctAnswer:2}};return setTimeout(function(){t(i)},1e3),void 0}var a=function(){n++,b(),setTimeout(function(){s(u,c,0,o,a)},V)},o=function(e){1!=n&&r.logMessage("quiz-service: sendQuestionSet() succeded after "+n+" retries."),C(),t(e.results)},u=P[O].url+x,c={ResponseText:e};s(u,c,0,o,a)}function p(e,t){if(!I&&L&&t){var n=P[O].url+R,i={InstanceId:L,Interval:e,ViewedSegments:t};s(n,i,0,null,null)}}function g(e){var t='';t+='';for(var a=e.questions.length,r=0;a>r;r++)t+='',t+=""+e.questions[r].duration+"",t+=""+n.htmlEncode(e.questions[r].response)+"",e.questions[r].type!==i.SHORT&&void 0!==e.questions[r].correct&&(t+=""+(e.questions[r].correct?"True":"False")+""),t+=""+e.questions[r].segmentWatched+"",t+="";return t+=""}function h(e){var t,a,r,o,s,u,c='';for(c+='',c+=""+n.htmlEncode(e.projectName)+"",c+=""+e.productionName+"",c+=""+e.originId+"",c+=""+e.mediaDuration+"",c+="",t=0;e.reportRecipients.length>t;t++)c+=""+e.reportRecipients[t]+"";for(c+="",c+="",o=e.questionSets.length,t=0;o>t;t++){for(c+='',s=e.questionSets[t].questions.length,a=0;s>a;a++){if(c+='',c+=""+n.htmlEncode(e.questionSets[t].questions[a].questionText,!0)+"",e.questionSets[t].questions[a].type===i.CHOICE){for(c+="",u=e.questionSets[t].questions[a].choices.length,r=0;u>r;r++)c+=""+n.htmlEncode(e.questionSets[t].questions[a].choices[r],!0)+"";c+="",c+=""+e.questionSets[t].questions[a].correctAnswer+""}else if(e.questionSets[t].questions[a].type===TSC.questionType.FILL_IN){for(c+="",u=e.questionSets[t].questions[a].choices.length,r=0;u>r;r++)c+=""+n.htmlEncode(e.questionSets[t].questions[a].choices[r],!0)+"";c+=""}c+=""}c+=""}return c+="",c+=""}var m,v,A,S,b,C,T,E,y=1,I=!1,w="v/1/quiz/definition",N="v/1/quiz/instance?noop=1",x="v/1/quiz/response?noop=1",R="v/1/quiz/progress?noop=1",P=[];P.push({label:"Local",url:"https://quiz.techsmith.localhost:11443/"}),P.push({label:"Dev",url:"https://quiz.cloud.tsc-dev.co/"}),P.push({label:"Stage",url:"https://quiz.cloud.tsc-stage.co/"}),P.push({label:"Live",url:"https://quiz.cloud.techsmith.com/"}),P.push({label:"TE",url:"https://quizzingtest2.cloud.tsc-dev.co/"});var M,L,k,_,O=3,D=!1,B=3500,Q=2,V=0;return t.support.cors=!0,{setEnvironment:function(e){O=e},getEnvironment:function(){return O},getLastAttemptStatus:function(){return M},startQuizInstance:function(e,t,n,i,a){T(),l(e,t,n,i,a)},submitQuizDefinition:function(e,n,i){"string"==typeof e&&(e=t.parseJSON(e));var a=h(e);return d(a,n,i),a},submitQuestionSet:function(e,n){var i="";return L&&("string"==typeof e&&(e=t.parseJSON(e)),i=g(e),f(i,n)),i},sendProgress:function(e,t){p(e,t)},addEventListener:function(e,t){"START_INSTANCE_COMPLETE"===e?m=t:"SEND_DEFINITION_COMPLETE"===e?A=t:"NEED_DEFINITION"===e?v=t:"ERROR"===e?S=t:"SHOW_SUBMISSION_RETRY_MESSAGE"===e?b=t:"HIDE_SUBMISSION_RETRY_MESSAGE"===e?C=t:"SHOW_LOADING_MESSAGE"===e?T=t:"HIDE_LOADING_MESSAGE"===e&&(E=t)},removeEventListener:function(e){"START_INSTANCE_COMPLETE"===e?m=void 0:"SEND_DEFINITION_COMPLETE"===e?A=void 0:"NEED_DEFINITION"===e?v=void 0:"ERROR"===e?S=void 0:"SHOW_SUBMISSION_RETRY_MESSAGE"===e?S=void 0:"HIDE_SUBMISSION_RETRY_MESSAGE"===e?S=void 0:"SHOW_LOADING_MESSAGE"===e?T=void 0:"HIDE_LOADING_MESSAGE"===e&&(E=void 0)}}}()}(this,jQuery,TSC.textSanitizer,TSC.questionType,TSC.deviceInfo,TSC.log),function(e,t,n,i,a){e.TSC=e.TSC||{},e.TSC.fathomParser=function(){"use strict";function e(e){var n,r,o,s,u,c,l,d,f=-1,p=!1,g=[];a.clearAllQuestions(),t(e).find("*").filterNode("rdf:Description").each(function(){var e=t(this).attr("tscIQ:questionSetName");if(e){e=i.htmlEncode(e),p&&(a.addQuestion(f,n,o,s,g,c),p=!1,s=void 0,o=void 0,g=[],c=void 0);var h="1"===t(this).attr("tscIQ:feedback"),m=Number(t(this).attr("xmpDM:startTime"));f=a.addQuestionSet(e,m,h)}else r=t(this).attr("tscIQ:type"),r?(p&&(a.addQuestion(f,n,o,s,g,c),p=!1,p=!1,s=void 0,o=void 0,g=[],c=void 0),o=t(this).attr("tscIQ:id"),n=r,l=t(this).children(),s=i.htmlEncode(t(l[0]).text(),!0),c=i.htmlEncode(t(l[1]).text(),!0),p=!0):(u=t(this).attr("tscIQ:orderId"),u&&(l=t(this).children(),d=t(l[0]).text(),d&&g.push(i.htmlEncode(d,!0))))}),p&&a.addQuestion(f,n,o,s,g,c)}var r,o;return{parseFathom:function(i){var s,u,c=t(i).find("*").eq(2),l=c.attr("dc:title"),d=c.attr("tscDM:originId"),f=c.attr("tscDM:project"),p=t(i).find("*").length;for(r=!1,s=4;p>s;s++)if("xmpDM:Tracks"===t(i).find("*").eq(s)[0].nodeName){u=t(i).find("*").eq(s).children();break}for(var g,h=t(u).find("*").length,m=0;h>m;m++){var v=t(u).find("*").eq(m);if(g=v.attr("xmpDM:trackType"),void 0!==g)switch(g.toLowerCase()){case"quiz":if(a){r=!0;var A=t(v).attr("tscIQ:quizGuid"),S=t(v).attr("tscIQ:reportMethod"),b="1"===t(v).attr("tscIQ:requireUserId"),C="1"===t(v).attr("tscIQ:hideReplay"),T=t(v).attr("tscIQ:authoredEmail"),E=t(v).attr("tscIQ:clientId"),y=t(v).attr("tscIQ:quizHash"),I=t(v).attr("tscIQ:locale");I||(I=n.ENGLISH),a.setLocale(I),a.setProductionMetadata(f,l,d),a.setQuizTitle(l),a.setQuizID(A),a.setReportMethod(S),a.setRequireUserId(b),a.setHideReplay(C),a.setAuthoredEmail(T),a.setClientId(E),a.setQuizHash(y)}o=t(v),m+=o.find("*").length}}r&&e(o)}}}()}(this,jQuery,TSC.languageCodes,TSC.textSanitizer,TSC.quizModel),function(e,t,n,i,a){e.TSC=e.TSC||{},e.TSC.fathomService=function(){"use strict";function e(){g&&g.call()}function r(){h&&h.call()}function o(t){n.parseFathom(t),e()}function s(){if(c)setTimeout(e,1e3);else{var t=d[f].url+l+p+"?noop=1";u(t,v)}}function u(e,n){var s=function(){n>0?setTimeout(function(){u(e,--n)},A):(a.logMessage("fathom-service: getFathom() failed after "+v+" retries."),r())},c=function(e){e&&e.statusText?a.logException("fathom-service: sendRequest() Ajax message failed with server response: "+e.statusText+" : "+e.status):a.logException("fathom-service: sendRequest() XDR message failed after the server responded with an error."),s()},l=function(){v>n&&a.logMessage("fathom-service: getFathom() succeeded after "+(v-n)+" retries.")};if(i.isIE()&&9==i.getIEVersion()){var d=new XDomainRequest;d.timeout=m,d.onprogress=function(){},d.ontimeout=s,d.onerror=c,d.onload=function(){l();var e=new ActiveXObject("Microsoft.XMLDOM");e.loadXML(d.responseText),o(e)},d.open("GET",e),setTimeout(function(){d.send()},0)}else t.ajax({type:"GET",url:e,crossDomain:!0,timeout:m,success:function(e){l(),o(e)},error:function(e){"timeout"==e.statusText?s():c(e)}})}var c,l,d,f,p,g,h,m,v,A;return c=!1,l="/Assessment/Xmp/",d=[],d.push({label:"Local",url:"https://results.localhost:444"}),d.push({label:"Dev",url:"https://results.cloud.tsc-dev.co"}),d.push({label:"Stage",url:"https://results.tsc-stage.co"}),d.push({label:"Live",url:"https://results.techsmith.com"}),d.push({label:"TE",url:"https://fathomtest2.cloud.tsc-dev.co"}),f=3,m=3500,v=2,A=0,{setEnvironment:function(e){isNaN(e)||0>e||e>d.length-1||(f=e)},getEnvironment:function(){return f},getFathom:function(e){p=e,s()},addEventListener:function(e,t){"GET_COMPLETE"===e?g=t:"ERROR"===e&&(h=t)},removeEventListener:function(e){"GET_COMPLETE"===e?g=void 0:"ERROR"===e&&(h=void 0)}}}()}(this,jQuery,TSC.fathomParser,TSC.deviceInfo,TSC.log),function(e,t){e.TSC=e.TSC||{},e.TSC.progressTracker=function(){var n,i,a=!1,r=!1,o=15e3,s=500,u=1e3,c=function(e){var t=e.length;if(1>t)return[];var n,i=[{start:1e3*e.start(0),end:1e3*e.end(0)}],a=0;for(n=1;t>n;n++)i[a].end>=1e3*e.start(n)-s?i[a].end=1e3*e.end(n):(i.push({start:1e3*e.start(n),end:1e3*e.end(n)}),a++);return i},l=function(e){var n,a,r,s,l,d,f,p,h,m=[],v=1e3*e.duration;for(h=c(e.played),n=0;h.length>n;n++)if(r=h[n].start,s=h[n].end,l=u>v-1e3*e.currentTime,!(!l&&o>s-r||(d=Math.floor(r/o),0!=r%o&&(d+=1),f=Math.floor(s/o),l||(f-=1),d>f)))for(a=d;f>=a;a++)m.push(a);t.sendProgress(o,m),p=m.length===Math.ceil(v/o),p&&(g(),e.removeEventListener("play",i,!1))},d=function(e){var t=function(){p(e),g()};e.addEventListener("ended",t,!1),a=!0},f=function(e){i=function(){-1==n&&h(e)},e.addEventListener("play",i,!1),r=!0},p=function(e){e&&(a||d(e),r||f(e),l(e))},g=function(){-1!==n&&(e.clearInterval(n),n=-1)},h=function(t){var i=function(){p(t),t.paused&&(e.clearInterval(n),n=-1)};n=e.setInterval(i,o)},m=function(e,t){a=!1,r=!1,o=t,g(),h(e)};return{start:m}}()}(window,TSC.quizService),function(e,t){e.TSC=e.TSC||{},e.TSC.BubbleView=function(n){"use strict";var i=10,a=48,r=22,o=8,s=45,u=n,c="#tsc_overlay",l=".chat-bubble-arrow-border",d=".chat-bubble-arrow",f='
';return{showView:function(){t(u).css("opacity",0),t(u).animate({opacity:1},300)},updateViewPosition:function(){t(u).css("bottom",a+"px")},removeView:function(e,n){t(u).animate({opacity:0},200,function(){void 0!==e&&e.call(),t(u).remove()}),n&&t(c).remove()},getOverlayMarkup:function(){return f},setBottomOffset:function(e){a=e},pointAt:function(n){var a,c,f=e.innerWidth,p=t(u).outerWidth(!0),g=.5*p,h=t(l).css("border-top-width").replace(/px/,""),m=r;0>n-(g+i)?(a=i,c=n-i-h):n+g+i>f?(a=f-(p+i),c=n-a-h):(a=n-g,c=g-h),t(u).css("left",a),t(l).css("left",c),t(d).css("left",c),s>n&&(m=o),t(u).css("border-bottom-left-radius",m+"px"),t(u).css("-webkit-border-bottom-left-radius",m+"px")}}}}(this,jQuery),function(e,t,n,i){e.TSC=e.TSC||{},e.TSC.quizSetupView=function(){"use strict";var e;if(!n||!n.quiz_setup_template)throw Error("quizSetupView: Quiz Setup Template not found.");e=n.quiz_setup_template;var a="#tsc_quiz_setup_container",r="#tsc_begin_button",o="#skip_control",s="#first_name",u="#last_name",c="#email_address",l=function(){var e=t(s).val().replace(/ /g,""),n=t(u).val().replace(/ /g,""),i=t(c).val().replace(/ /g,"");""!==e&&""!==n&&""!==i&&d(i)?t(r).removeAttr("disabled"):t(r).attr("disabled","disabled")},d=function(e){var t=/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;return t.test(e)};return{getViewMarkup:function(t,n,a,r,o,s){var u={setupMessage:t,firstNamePlaceholder:n,lastNamePlaceholder:a,emailPlaceholder:r,beginButtonText:o,skipControlText:s};return i.isNuevoApp()||(u.useAutofocus=!0),e(u)},getBeginControlRef:function(){return r},getSkipControlRef:function(){return o},getFirstName:function(){return t(s).val()},getLastName:function(){return t(u).val()},getEmail:function(){return t(c).val()},showView:function(){t("input").bind("keyup",l),t("input").bind("change",l),t(a).css("opacity",0),t(a).animate({opacity:1},300),i&&(i.isIE()&&t(a+" label").css("display","block"),i.isNuevoApp()||t(s).focus())},removeView:function(e){t("input").unbind("keyup",l),t("input").unbind("change",l),t(a).animate({opacity:0},200,function(){void 0!==e&&e.call(),t(a).remove()})}}}()}(this,jQuery,TSC.templates,TSC.deviceInfo),function(e,t,n){e.TSC=e.TSC||{},e.TSC.questionSetConfirmationView=function(){"use strict";var e,i=new n("#tsc_confirmation_container"),a="#tsc_review_control",r="#tsc_confirm_control";if(!t||!t.question_set_confirmation_template)throw Error("questionSetConfirmationView: Question Set Confirmation Template not found.");return e=t.question_set_confirmation_template,{getViewMarkup:function(t,n){var a={reviewText:t,confirmationText:n};return e(a)+i.getOverlayMarkup()},getReviewControlRef:function(){return a},getConfirmControlRef:function(){return r},showView:i.showView,removeView:i.removeView,updateViewPosition:i.updateViewPosition,setBottomOffset:i.setBottomOffset,pointAt:i.pointAt}}()}(this,TSC.templates,TSC.BubbleView),function(e,t,n,i,a,r,o){e.TSC=e.TSC||{},e.TSC.questionSetView=function(){"use strict";var s,u,c,l,d,f,p="#tsc_quiz_container";if(!n||!n.question_set_template)throw Error("questionSetView: Question Set Template not found.");if(s=n.question_set_template,!n||!n.question_count_template)throw Error("questionSetView: Question Count Template not found.");if(u=n.question_count_template,!n||!n.question_text_template)throw Error("questionSetView: Question Text Template not found."); +if(c=n.question_text_template,!n||!n.choice_answer_template)throw Error("questionSetView: Multiple Choice Answer Template not found.");if(l=n.choice_answer_template,!n||!n.fill_answer_template)throw Error("questionSetView: Fill In The Blank Answer Template not found.");if(d=n.fill_answer_template,!n||!n.short_answer_template)throw Error("questionSetView: Short Answer Template not found.");f=n.short_answer_template;var g="#tsc_previous_button",h="#tsc_next_button",m="#tsc_submit_button",v="#tsc_continue_button",A="#tsc_quiz_controls",S="#tsc_quiz_question_count",b="#tsc_question",C="#tsc_answers",T="#tsc_question_set_result_info",E=new i(p),y="",I=" T2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AU kSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89+bN/rXX Pues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz/SMBAPh+PDwrIsAHvgAB eNMLCADATZvAMByH/w/qQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAt AGAnf+bTAICd+Jl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3 AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dX Lh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA/g88wAAKCRFRHgg/P9eM4Ors7ONo62Dl8t6r8G/yJiYuP+ 5c+rcEAAAOF0ftH+LC+zGoA7BoBt/qIl7gRoXgugdfeLZrIPQLUAoOnaV/Nw+H48PEWhkLnZ2eXk 5NhKxEJbYcpXff5nwl/AV/1s+X48/Pf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H/LcL//wd 0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s+wM+3zUAsGo+AXuRLahdYwP2SycQWHTA 4vcAAPK7b8HUKAgDgGiD4c93/+8//UegJQCAZkmScQAAXkQkLlTKsz/HCAAARKCBKrBBG/TBGCzA BhzBBdzBC/xgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD/ph CJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5 h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8+ Q8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8+xdwQSgUXACTYEd0IgYR5BSFhM WE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR+cQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQ AkmxpFTSEtJG0m5SI+ksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG+Qh8lsKnWJAcaT4U+Io UspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdp r+h0uhHdlR5Ol9BX0svpR+iX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK+YTKYZ04sZx1QwNzHrmOeZ D5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI+pXlN9rkZVM1PjqQnUlqtVqp1Q61Mb U2epO6iHqmeob1Q/pH5Z/YkGWcNMw09DpFGgsV/jvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY /R27iz2qqaE5QzNKM1ezUvOUZj8H45hx+Jx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllir SKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4/OBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79u p+6Ynr5egJ5Mb6feeb3n+hx9L/1U/W36p/VHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6Vh lWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1 mz0x1zLnm+eb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lO k06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw+6TvZN9un2N/T0HDYfZDqsdWh1+c7Ry FDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc+Lpsbxt3I veRKdPVxXeF60vWdm7Obwu2o26/uNu5p7ofcn8w0nymeWTNz0MPIQ+BR5dE/C5+VMGvfrH5PQ0+B Z7XnIy9jL5FXrdewt6V3qvdh7xc+9j5yn+M+4zw33jLeWV/MN8C3yLfLT8Nvnl+F30N/I/9k/3r/ 0QCngCUBZwOJgUGBWwL7+Hp8Ib+OPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5p DoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo+qi5q PNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt/87fOH4p3iC+N7F5gvyF1weaHOwvSFpxapLhIs OpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi/RNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5 hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z+pn5mZ2y6xlhbL+xW6Lty8elQfJa7OQ rAVZLQq2QqboVFoo1yoHsmdlV2a/zYnKOZarnivN7cyzytuQN5zvn//tEsIS4ZK2pYZLVy0dWOa9 rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1+1d T1gvWd+1YfqGnRs+FYmKrhTbF5cVf9go3HjlG4dvyr+Z3JS0qavEuWTPZtJm6ebeLZ5bDpaql+aX Dm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO/PLi8ZafJzs07P1SkVPRU+lQ27tLdtWHX+G7R7ht7 vPY07NXbW7z3/T7JvttVAVVN1WbVZftJ+7P3P66Jqun4lvttXa1ObXHtxwPSA/0HIw6217nU1R3S PVRSj9Yr60cOxx++/p3vdy0NNg1VjZzG4iNwRHnk6fcJ3/ceDTradox7rOEH0x92HWcdL2pCmvKa RptTmvtbYlu6T8w+0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO 32oPb++6EHTh0kX/i+c7vDvOXPK4dPKy2+UTV7hXmq86X23qdOo8/pPTT8e7nLuarrlca7nuer21 e2b36RueN87d9L158Rb/1tWeOT3dvfN6b/fF9/XfFt1+cif9zsu72Xcn7q28T7xf9EDtQdlD3YfV P1v+3Njv3H9qwHeg89HcR/cGhYPP/pH1jw9DBY+Zj8uGDYbrnjg+OTniP3L96fynQ89kzyaeF/6i /suuFxYvfvjV69fO0ZjRoZfyl5O/bXyl/erA6xmv28bCxh6+yXgzMV70VvvtwXfcdx3vo98PT+R8 IH8o/2j5sfVT0Kf7kxmTk/8EA5jz/GMzLdsAAAAgY0hSTQAAeiUAAICDAAD5/wAAgOkAAHUwAADq YAAAOpgAABdvkl/FRgAAAwdJREFUeNqslU1oG0cUx/8zu9JKK0taYctqrMS2YoIT13EMhbT00hbf QgOFluSWUwyhhx4CgYCaYDmkLvRemkOOwYFcQ26lpKc2GIoPdnGxncauPyTvaiVZWnu9M/Ny8MYf wYcm+MFjmAfv9/5vPhkR4TiN45jt2IHs2ot+EACDG+A8isXGHKTaQiAkTMNCPnkKUgmACACBMQYA kFJCY7rR2vHOpaPWjE+bQUDb76uQIEnxdLTj1mf5L//sjHcViYmUgtD198FJUiwb6yr2pvrvVtWq nognb7CWMccUzf5vIBEhwiPQEEHCSBUL6XPjFbGAqlijaq35c7Ajn3Kuee+kUCjBrXju9ulM/72K XMQmObLRDO42ZOsHgyLgYLtryAAQlCGUKBDoSHUKimdi2eKZjrMlly+hBSdwnOZYvb41wdj+VnBF CgRKZBP50vCJT37LGO2XAyWAPfBuq51mvjjwwfCYq6/odbKpXK6WXLd+nzF2SAGP6eblVDRz82R7 97dmivd83nvpYc7MXwokQCBIJZllZIsDnRfGXb7E67KsVpftomO79zljFE1qMCwOw9JgpDVow6NZ W1CwWN1Z797S3Q+TsVSir21oZL25POvJ5ny/Nfj92dxgydVe8Zq0/fVXG2OVSn0iEmeIt0cw/9jD 2u8e7CkflSkf7Pr0IIQK4GM7bZnWg0wmdbUr2oegpb/811l4Pnjiwjc1banN2SnL5bJ9p+lUf1SM U/kPHwuTHmr/BJDb+13rtXkfggQCJuoy2xjVTaZXoi+/7oj3Fj46ebGwKufQZBuwPfvO2mp1glYU pkouvA15CLR39Q5OBq5ZIKLMp9/1/FIY6ryiNjUo0xdzf/03Pv1o7Z4zI1B+7r/TQxEDwHMXzdzo i+FnY1tf0FdP+n6yhvQIgDiAJIAEADOc62+LYgfGGIA0gDYA2x3nY6d6RlIf/z1Z/dUrCz8EyNAF AB9AI3R1VMscQCSsysOkICyk7x3K3eQ3HoQF6Mg1PBB7E1chnB0A0qFn5+3k4/4CXg8ASMFjCJPN 2KUAAAAASUVORK5CYII=",w=" T2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AU kSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89+bN/rXX Pues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz/SMBAPh+PDwrIsAHvgAB eNMLCADATZvAMByH/w/qQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAt AGAnf+bTAICd+Jl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3 AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dX Lh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA/g88wAAKCRFRHgg/P9eM4Ors7ONo62Dl8t6r8G/yJiYuP+ 5c+rcEAAAOF0ftH+LC+zGoA7BoBt/qIl7gRoXgugdfeLZrIPQLUAoOnaV/Nw+H48PEWhkLnZ2eXk 5NhKxEJbYcpXff5nwl/AV/1s+X48/Pf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H/LcL//wd 0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s+wM+3zUAsGo+AXuRLahdYwP2SycQWHTA 4vcAAPK7b8HUKAgDgGiD4c93/+8//UegJQCAZkmScQAAXkQkLlTKsz/HCAAARKCBKrBBG/TBGCzA BhzBBdzBC/xgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD/ph CJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5 h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8+ Q8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8+xdwQSgUXACTYEd0IgYR5BSFhM WE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR+cQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQ AkmxpFTSEtJG0m5SI+ksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG+Qh8lsKnWJAcaT4U+Io UspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdp r+h0uhHdlR5Ol9BX0svpR+iX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK+YTKYZ04sZx1QwNzHrmOeZ D5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI+pXlN9rkZVM1PjqQnUlqtVqp1Q61Mb U2epO6iHqmeob1Q/pH5Z/YkGWcNMw09DpFGgsV/jvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY /R27iz2qqaE5QzNKM1ezUvOUZj8H45hx+Jx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllir SKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4/OBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79u p+6Ynr5egJ5Mb6feeb3n+hx9L/1U/W36p/VHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6Vh lWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1 mz0x1zLnm+eb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lO k06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw+6TvZN9un2N/T0HDYfZDqsdWh1+c7Ry FDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc+Lpsbxt3I veRKdPVxXeF60vWdm7Obwu2o26/uNu5p7ofcn8w0nymeWTNz0MPIQ+BR5dE/C5+VMGvfrH5PQ0+B Z7XnIy9jL5FXrdewt6V3qvdh7xc+9j5yn+M+4zw33jLeWV/MN8C3yLfLT8Nvnl+F30N/I/9k/3r/ 0QCngCUBZwOJgUGBWwL7+Hp8Ib+OPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5p DoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo+qi5q PNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt/87fOH4p3iC+N7F5gvyF1weaHOwvSFpxapLhIs OpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi/RNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5 hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z+pn5mZ2y6xlhbL+xW6Lty8elQfJa7OQ rAVZLQq2QqboVFoo1yoHsmdlV2a/zYnKOZarnivN7cyzytuQN5zvn//tEsIS4ZK2pYZLVy0dWOa9 rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1+1d T1gvWd+1YfqGnRs+FYmKrhTbF5cVf9go3HjlG4dvyr+Z3JS0qavEuWTPZtJm6ebeLZ5bDpaql+aX Dm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO/PLi8ZafJzs07P1SkVPRU+lQ27tLdtWHX+G7R7ht7 vPY07NXbW7z3/T7JvttVAVVN1WbVZftJ+7P3P66Jqun4lvttXa1ObXHtxwPSA/0HIw6217nU1R3S PVRSj9Yr60cOxx++/p3vdy0NNg1VjZzG4iNwRHnk6fcJ3/ceDTradox7rOEH0x92HWcdL2pCmvKa RptTmvtbYlu6T8w+0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO 32oPb++6EHTh0kX/i+c7vDvOXPK4dPKy2+UTV7hXmq86X23qdOo8/pPTT8e7nLuarrlca7nuer21 e2b36RueN87d9L158Rb/1tWeOT3dvfN6b/fF9/XfFt1+cif9zsu72Xcn7q28T7xf9EDtQdlD3YfV P1v+3Njv3H9qwHeg89HcR/cGhYPP/pH1jw9DBY+Zj8uGDYbrnjg+OTniP3L96fynQ89kzyaeF/6i /suuFxYvfvjV69fO0ZjRoZfyl5O/bXyl/erA6xmv28bCxh6+yXgzMV70VvvtwXfcdx3vo98PT+R8 IH8o/2j5sfVT0Kf7kxmTk/8EA5jz/GMzLdsAAAAgY0hSTQAAeiUAAICDAAD5/wAAgOkAAHUwAADq YAAAOpgAABdvkl/FRgAABHZJREFUeNqslMtvW0UUxr+ZuTP3+voZ47itidO0Thy3cVqIQgKqGmoI AlZIqKgCKugC2IDEBlZdsUBizR9QiapFqoToColWiCKEuiltoginIRi3hNTxo3bit32v7wwLO32t Geks5ptzfjpHOvMRpRT+z0POMgYFQHccRHy+N90eT6CQy53TGHssUQAghPQv/SbMfdHox1dLpSu5 bnclJyUoAO2RDsXwyMhJXzAYqNZqlzXOt0EICCFQUkLW6w/g0nEgTHNy+ODB03FNU1axuHK3VgMn BGxRCCjAnUwkvjo2N/dBJBSasHU9ul0uX9UMw9KEAKUUTqsFMoAxXY8fPn783OTo6Ew8Ejn+T7lc ze/sLHkZkyw1NISepo3Nx2JfDpdKgWY2i6cPHZrucj5W3tr6mTHWUVLCabUAKcGESEylUt/GAoHZ 9s2b4FJyn2H4Yu32dzMeT4fFlULNcbarGxt/hx3nhNfl8trFIqKJxLSl62PlfP4apbTdq9fBdD2Z TKUujvv9z3bTaRDGkMlmb925d+9DeL0bDgA2NxhJdrvr+Xr9dtgwXhkSwm2XShiZnEx2hRgtbm7+ QKUcTaZSFycCgRlrdRUgBNlK5fdMofCOIuQ2c7sBpcCe4xyKEHgcBx0p/9poNtf2Gcarfs5Nq1hE ZGJi2jLNeGR8/Ezc55vvptOghCBbLi9nCoX3lFJrGuegpvk40NXrgSuFmpTrhUZjdY9hvGxy7rFK JYzE41NBTYt20mkQTUO2XF7J5POnFZCmSoFq2kPgPOfAAMiUAgHQlXJ9s1pdCnGecgvht/N5OKUS QAgyhcL1TKl0CsCfhFKQXaDLBSgF7RnGAEIATYMjJQilgFJwhMi0/P6KJIg6PRsAARMcnWAwJx1n UxcCUqn+njoOGltbIJSCUgAUABkEpIQmxOHphYXLY+Oxo5ZlQYLAUQpd28b00aMnD0xNfWP3ekFQ 2m9m9/coBfaGrvdFx4Hs9UA5PzS5sHBhxO2ZaabTcJTCv9s7f1i2bZtM83WLRUTi8aQtxGgln/+J MdYlSvUXn5CHQGVZIIzF4wsvnt9nGrP1lRVIKZGr1m7duX//5N1m8xe/EK8bhLjb+Tz2TkxM9wwj ulMsXmGA7bTbfeDbhoGOlNA4Tx544fkLYSFmqyvLcJRCudFYbm3vvK9BrdWA7P12e82raYsMyt3c ymHv+PgRZbr31wqFX3udTstDCBilFCc8nqFwInExaLrmK8vLAIBao7lUq9ffXVIqfQnAEoCOUuvD nc6qrvGXiFKeRj6PPQdjR5RlufVK5cdLu04zp+v861Do099Coe718LD63uu9cQwYD/dti+y6jAZg GMDnlL52NRDYuh4OqWuhp5pnfb4zUw+8DeAAPB7A/ITzL86b5tIsyCIAH4ADAGJPxH4G+E5R+tEF 08y+RchnAFwAvAAEGXinC4DgAAkC/gLQHGjk0Y0CoAYhCdBZAPw3gEqr/9YF0NpNpgAYAHtQYDwC IU+4vBpotgnYFsB6/VoHgPxvAKXu/Kzwy4WOAAAAAElFTkSuQmCC",N=400,x=function(e,t,n,i){var r,s={},u=1;if(a.isNuevoApp()&&(i=!1),e===o.CHOICE){r=l,s.answers=[],s.placeHolderImg=y;for(var c=t.length,p=0;c>p;p++)n&&p===Number(n)?s.answers.push({answerIndex:p,tabIndex:u,answer:t[p],isChecked:!0}):s.answers.push({answerIndex:p,tabIndex:u,answer:t[p]}),u++}else e===o.FILL_IN?(r=d,s.userResponse=n,i&&(s.useAutofocus="true")):e===o.SHORT&&(r=f,s.userResponse=n,i&&(s.useAutofocus="true"));return r(s)},R=function(e,t){var n={questionNumber:e,questionText:t};return c(n)},P=function(e,t,n){var i={currentQuestionNumber:e,totalQuestions:t,prepositionText:n};return u(i)},M=function(){var n,i,a=t(e).height(),r=N>=a;if(t(p).css("max-height","none"),t(C).css("max-height","none"),r){var o=t(A).offset().top;n=t(C).outerHeight(!0);var s=t(C).offset().top;s+n>o&&(n-=s+n-o,t(C).css("max-height",n+"px"))}else{var u=t(p).css("bottom").replace(/px/,""),c=10,l=t(p).outerHeight(!0),d=l,f=Number(u)+Number(l)+c+6;if(f>a){var g=f-a;n=t(C).outerHeight(!1),i=n-g-8,t(C).css("max-height",i+"px"),d=d-(f-a)-u,t(p).css("max-height",d+"px")}}};return{getViewMarkup:function(e,t,n,i,a,r){var o={questionSetTitle:e,previousButtonName:t,nextButtonName:n,submitButtonName:i,continueButtonName:a},u=s(o);return r&&(u+=E.getOverlayMarkup()),u},configureControls:function(e,n,i,a){e.visible?(t(g).css("display","inline"),e.disabled?t(g).attr("disabled","disabled"):t(g).removeAttr("disabled")):t(g).css("display","none"),n.visible?(t(h).css("display","inline"),n.disabled?t(h).attr("disabled","disabled"):t(h).removeAttr("disabled")):t(h).css("display","none"),i.visible?(t(m).css("display","inline"),i.disabled?t(m).attr("disabled","disabled"):t(m).removeAttr("disabled")):t(m).css("display","none"),a.visible?(t(v).css("display","inline"),a.disabled?t(v).attr("disabled","disabled"):t(v).removeAttr("disabled")):t(v).css("display","none")},showControls:function(){"hidden"===t(A).css("visibility")&&(t(A).css("visibility","visible"),t(A).css("opacity",0),t(A).animate({opacity:1},300))},hideControls:function(){"visible"===t(A).css("visibility")&&t(A).css("visibility","hidden")},showResponse:function(e){t(C).css("opacity",0),t(C).stop().animate({opacity:1},400,function(){"autofocus"in document.createElement("input")||a.isNuevoApp()||(e===o.FILL_IN?t(C+" input")[0].focus():e===o.SHORT&&t(C+" textarea")[0].focus())}),e===o.CHOICE&&a.isTouchInterface()&&t(".tsc_multiple_choice").removeClass("active_quiz_item")},displayQuestion:function(e,n,i,a,r,o,s,u){t(S).html(P(a,o,r)),t(b).html(R(a,n)),t(C).html(x(e,i,s,!u)),M()},disableResponseUI:function(e){e===o.CHOICE?t(C+" input").attr("disabled",!0):e===o.FILL_IN?t(C+" input").attr("disabled",!0):e===o.SHORT&&t(C+" textarea").attr("disabled",!0)},showFeedback:function(e){t(T).html(e),t(T).show()},showResponseFillInFeedback:function(e){e?t(C).prepend(""):t(C).prepend(""),t(C+" img").css("opacity",0),t(C+" img").animate({opacity:1},200)},showResponseChoiceFeedback:function(e,n,i){i&&(t("label img").removeClass("feedback_placeholder"),Number(e)===Number(n)?(t(C+" label:eq("+e+") img").remove(),t(C+" label:eq("+e+")").prepend(""),t(C+" label:eq("+e+") img").css("opacity",0),t(C+" label:eq("+e+") img").animate({opacity:1},200)):(t(C+" label:eq("+e+") img").remove(),t(C+" label:eq("+n+") img").remove(),t(C+" label:eq("+n+")").prepend(""),t(C+" label:eq("+e+")").prepend(""),t(C+" label:eq("+e+") img").css("opacity",0),t(C+" label:eq("+e+") img").animate({opacity:1},200),t(C+" label:eq("+n+") img").css("opacity",0),t(C+" label:eq("+n+") img").animate({opacity:1},200))),t(C+" input").hide(),e&&t(C+" label:eq("+e+")").addClass("picked_quiz_item")},getPreviousControlsRef:function(){return g},getNextControlsRef:function(){return h},getSubmitControlsRef:function(){return m},getContinueControlsRef:function(){return v},getResponseLabelRef:function(){return C+" label"},getResponseInputRef:function(){return C+" input"},getResponseTextAreaRef:function(){return C+" textarea"},getResponseInputValue:function(){return r.htmlEncode(t(C+" input").val())},getResponseTextAreaValue:function(){var e=r.htmlEncode(t(C+" textarea").val().replace(/^[ \t]+|[ \t]+$/,""));if(a.isIE()){var n=t(C+" textarea").attr("maxlength");n&&e.length>n&&(e=e.substring(0,n))}return e},getResponseListSelectedIndex:function(){return t("input[name=tsc_multiple_choice]:checked").val()},showView:function(){t(p).show(),M(),E.showView()},removeView:E.removeView,updateViewPosition:E.updateViewPosition,setBottomOffset:E.setBottomOffset,pointAt:function(e){E.pointAt(e),M()}}}()}(this,jQuery,TSC.templates,TSC.BubbleView,TSC.deviceInfo,TSC.textSanitizer,TSC.questionType),function(e,t,n){e.TSC=e.TSC||{},e.TSC.reviewAnswersConfirmationView=function(){"use strict";var e,i=new n("#tsc_review_confirmation_container");if(!t||!t.question_set_review_confirmation_template)throw Error("reviewAnswersConfirmationView: Review Answer Confirmation View Template not found.");e=t.question_set_review_confirmation_template;var a="#tsc_continue_control",r="#tsc_review_answers_control";return{getViewMarkup:function(t,n){var i={continueText:t,reviewAnswerText:n};return e(i)},getContinueControlRef:function(){return a},getReviewControlRef:function(){return r},showView:i.showView,removeView:i.removeView,updateViewPosition:i.updateViewPosition,setBottomOffset:i.setBottomOffset,pointAt:i.pointAt}}()}(this,TSC.templates,TSC.BubbleView),function(e){e.TSC=e.TSC||{},e.TSC.quizMarker=function(){"use strict";var e="#ffffff",t=3;return{setColor:function(t){e=t},getColor:function(){return e},setSize:function(e){t=e},getSize:function(){return t}}}()}(this),function(e,t){e.TSC=e.TSC||{},e.TSC.xmpGrader=function(){"use strict";var e=function(e,n,i,a){var r=e.getQuestionType(n,i);if(r===t.CHOICE){var o,s=e.getQuestionAnswer(n,i);o=isNaN(parseInt(a))?!1:1<0)}else if(r===t.FILL_IN){var u=a.toLowerCase(),c=e.getQuestionChoices(n,i),l=c?c.length:0;e.setIsQuestionGraded(n,i,l>0);for(var d=0;l>d;d++)if(u===c[d].toLowerCase()){e.setIsResponseCorrect(n,i,!0);break}}};return{gradeQuestionSet:function(t,n){for(var i=t.numberQuestionsInSet(n),a=0;i>a;a++){var r=t.getQuestionResponse(n,a);e(t,n,a,r)}},doesLocalGrading:!0}}()}(this,TSC.questionType),function(e){e.TSC=e.TSC||{},e.TSC.fathomGrader=function(){"use strict";return{processQuestionSetResults:function(e,t,n){for(var i=e.numberQuestionsInSet(t),a=0;i>a;a++){var r=e.getQuestionApiId(t,a),o=n[r];void 0!==o&&(e.setIsResponseCorrect(t,a,o.isCorrect),e.setQuestionAnswer(t,a,o.correctAnswer),e.setIsQuestionGraded(t,a,o.isGraded))}},doesLocalGrading:!1}}()}(this),function(e,t,n,i,a,r,o,s,u,c,l,d,f,p){e.TSC=e.TSC||{},e.TSC.quizController=function(){"use strict";var g,h,m,v,A,S,b,C,T,E,y,I,w,N,x,R,P,M,L=0,k=0,_=0,O=0,D=7,B=0,Q=!1,V=!0,q=!1,G=0,F=0,U=!0,H="",z=3e4,W=function(e){m=e,L=m.numberQuestionSets(),k=m.numberQuestionsInSet(0)},J=function(){S&&S.call(this,{type:"BEGIN"})},Y=function(){b&&b.call(this,{type:"SKIP"})},j=function(){m.getUseScorm()&&userSubmitToLMS&&userSubmitToLMS(m.getScormScore(),m.getLastQuestionComplete(O))},K=function(){m.setQuestionSetComplete(O),O=-1},Z=function(){v&&v.call(this,{type:"COMPLETE"})},X=function(){K(),t(a.getPreviousControlsRef()).unbind("click",rt),t(a.getNextControlsRef()).unbind("click",ot),t(a.getSubmitControlsRef()).unbind("click",ft),t(a.getContinueControlsRef()).unbind("click",X),a.removeView(Z,!0),g=void 0},$=function(e){if(!Q)if(e===c.CHOICE){var t=a.getResponseListSelectedIndex();t&&m.setQuestionResponse(O,_,t)}else if(e===c.FILL_IN){var n=a.getResponseInputValue();n&&""!==n&&m.setQuestionResponse(O,_,n)}else if(e===c.SHORT){var i=a.getResponseTextAreaValue();i&&""!==i&&m.setQuestionResponse(O,_,i)}},et=function(e){T&&(H=e,T.call(this,{type:"STATUS",message:e}))},tt=function(){E&&E.call(this,{type:"SUBMITTED"})},nt=function(){i.isNuevoApp()&&t(e).scrollTop(0)},it=function(){var e=m.getQuestionType(O,_),i=m.getQuestionText(O,_),r=m.getQuestionChoices(O,_),o=m.getQuestionResponse(O,_);a.displayQuestion(e,i,r,Number(_+1),n.getQuestionCountPreposition(),k,o,Q);var s=!(1===k),u=!(1===k),l=_!==k-1||Q?!1:!0,d=Q,f=0===_?!0:!1,p=_===k-1?!0:!1;if(a.configureControls({visible:s,disabled:f},{visible:u,disabled:p},{visible:l},{visible:d}),Q)if(a.showResponse(),a.disableResponseUI(e),e===c.CHOICE){for(var g=a.getResponseListSelectedIndex(),h=m.getQuestionAnswer(O,_),v=-1,A=m.getQuestionChoices(O,_).length,S=0;A>S;S++)if(1<0),t(a.getResponseLabelRef()).removeClass("active_quiz_item")}else e===c.FILL_IN&&m.getIsQuestionGraded(O,_)&&a.showResponseFillInFeedback(m.getIsResponseCorrect(O,_));else a.showResponse(e),G=(new Date).getTime()},at=function(){F=(new Date).getTime(),m.addDurationToQuestion(O,_,F-G)},rt=function(){var e=m.getQuestionType(O,_);$(e),at(),_--,it()},ot=function(){var e=m.getQuestionType(O,_);$(e),at(),_++,it()},st=function(e,t,i){var a="";if(t>0){var r=1===e?"txtCorrectAnswer":"txtCorrectAnswers";a=n.getString(r),a=a.replace(/{{numberCorrect}}/,e)}if(i>0&&t>0){""!==a&&(a+=" ");var r=1===i?"txtUngradedQuestion":"txtUngradedQuestions";a+=n.getString(r),a=a.replace(/{{numberUngraded}}/,i)}return a},ut=function(){Q=!0,k=m.numberQuestionsInSet(O);var e=a.getViewMarkup(m.getQuestionSetTitle(O),n.getString("txtPrev"),n.getString("txtNext"),n.getString("txtSubmit"),n.getString("txtContinue"));h.append(e),g=a,Tt(),x&&g.pointAt(x),t(a.getPreviousControlsRef()).bind("click",rt),t(a.getNextControlsRef()).bind("click",ot),t(a.getSubmitControlsRef()).bind("click",ft),t(a.getContinueControlsRef()).bind("click",X);var i=m.getNumberOfCorrectInQuestionSet(O),r=m.getTotalNumberOfGradableInQuestionSet(O),o=m.getTotalNumberOfUngradableInQuestionSet(O),s=st(i,r,o);""!==s&&a.showFeedback(s),_=0,it(),a.showView(),a.updateViewPosition()},ct=function(){K(),t(s.getContinueControlRef()).unbind("click",ct),t(s.getReviewControlRef()).unbind("click",lt),s.removeView(Z,!0),g=void 0},lt=function(){t(s.getContinueControlRef()).unbind("click",ct),t(s.getReviewControlRef()).unbind("click",lt),s.removeView(ut,!1),g=void 0},dt=function(){var e=s.getViewMarkup(n.getString("txtContinue"),n.getString("txtReviewAnswer"));h.append(e),g=s,Tt(),x&&g.pointAt(x),t(s.getContinueControlRef()).bind("click",ct),t(s.getReviewControlRef()).bind("click",lt),s.showView(),s.updateViewPosition()},ft=function(){t(TSC.questionSetView.getSubmitControlsRef()).attr("disabled","disabled"),t("#tsc_quiz_container").css("z-index",8),at();var e=m.getQuestionType(O,_);$(e),P.doesLocalGrading&&P.gradeQuestionSet(m,O),M=!0,m.getUseQuizApi()&&(et(n.getString("txtSubmittingAnswers")),u.submitQuestionSet(m.getApiDataForQuestionSet(O),pt)),m.getUseScorm()&&j(),(i.isLocal()||!m.getUseQuizApi())&&pt()},pt=function(e){if(M=!1,tt(),!P.doesLocalGrading&&m.getUseQuizApi()){if(void 0===e)return Nt(),X(),void 0;P.processQuestionSetResults(m,O,e)}m.getDisplayFeedback(O)?g.removeView(dt,!1):X()},gt=function(e){Q=!1,_=0,k=m.numberQuestionsInSet(O);var i=a.getViewMarkup(m.getQuestionSetTitle(O),n.getString("txtPrev"),n.getString("txtNext"),n.getString("txtSubmit"),n.getString("txtContinue"),e);h.append(i),g=a,Tt(),x&&g.pointAt(x),t(a.getPreviousControlsRef()).bind("click",rt),t(a.getNextControlsRef()).bind("click",ot),t(a.getSubmitControlsRef()).bind("click",ft),t(a.getContinueControlsRef()).bind("click",X),it(),a.showView(),a.updateViewPosition()},ht=function(){g.removeView(void 0,!0),g=void 0,A&&A.call(this,{type:"REVIEW"})},mt=function(){L>O&>(!1)},vt=function(){g.removeView(mt),g=void 0},At=function(){var e;e=U?n.getString("txtReview"):n.getString("txtContinue");var i=r.getViewMarkup(e,n.getString("txtAnswerQuestion"));h.append(i),g=r,Tt(),m.getHideReplay()===!0&&t(r.getReviewControlRef()).hide(),t(r.getReviewControlRef()).bind("click",ht),t(r.getConfirmControlRef()).bind("click",vt),r.showView(),r.updateViewPosition()},St=function(e){m.getUseQuizApi()?(yt(o.getFirstName(),o.getLastName(),o.getEmail()),g.removeView()):g.removeView(J),g=void 0,e.preventDefault()},bt=function(e){V=!1,i.isIPad()||i.isAndroid()?(g.removeView(),Y()):g.removeView(Y),g=void 0,e.preventDefault()},Ct=function(){var e=n.getString("txtRequiredMessage"),i=n.getString("txtFirstName"),a=n.getString("txtLastName"),r=n.getString("txtEmail"),s=n.getString("txtBegin"),u=n.getString("txtSkip"),c=o.getViewMarkup(e,i,a,r,s,u);h.append(c),g=o,t(o.getBeginControlRef()).bind("click",St),m.getAllowSkipQuiz()?t(o.getSkipControlRef()).bind("click",bt):t(o.getSkipControlRef()).hide(),o.showView()},Tt=function(){g&&g.setBottomOffset&&(g.setBottomOffset(B),g.updateViewPosition())},Et=function(){q=!0,J()},yt=function(e,t,n){u.startQuizInstance(m.getQuizID(),e,t,n,f),(i.isIPad()||i.isAndroid())&&J()},It=function(e,t,i){i&&i>0&&(z=i),t?(et(n.getString("txtLoaderMessageDefinition")),u.submitQuizDefinition(d.getQuizDefinition(),d.getQuizHash(),d.getClientId())):Et()},wt=function(){Et()},Nt=function(){V=!1,M&&pt(),C.call(this,{type:"ERROR"})};return{init:function(e,n){U=e,R=n,m.getUseQuizApi()?(u.addEventListener("START_INSTANCE_COMPLETE",It),u.addEventListener("SEND_DEFINITION_COMPLETE",wt),u.addEventListener("ERROR",Nt),u.addEventListener("SHOW_LOADING_MESSAGE",w),u.addEventListener("HIDE_LOADING_MESSAGE",N),u.addEventListener("SHOW_SUBMISSION_RETRY_MESSAGE",y),u.addEventListener("HIDE_SUBMISSION_RETRY_MESSAGE",I),m.getRequireUserId()&&!f.getIsUserIdentified()?Ct():yt()):(q=!0,J()),i.isNuevoApp()&&(t("body").on("blur","#tsc_quiz_container input",nt),t("body").on("blur","#tsc_quiz_container textarea",nt))},getQuizReady:function(){return q},getAnalyticsSampleRate:function(){return z},getLastStatusMessage:function(){return H},setQuestionData:function(e){W(e)},setViewContainer:function(e){h=t(e)},displayNextQuestionSet:function(){L>O&>(!0)},quizEnabled:function(){return V},viewOpen:function(){return void 0!==g},findQuestionSet:function(e){for(var t=-1,n=-1,i=d.getQuestionSetMarkerTimes(),a=i.length,r=0;a>r;r++)if(U&&e>=i[r].time||e>=i[r].rangeStart&&i[r].rangeEnd>=e){t=i[r].quesitonSetId,n=i[r].time;break}return{id:t,markerTime:n}},findPrevMarkerTimeForMarker:function(e){return m.getPreviousMarkerTimeForMarker(e)},updatePercentWatchedForQuestionSet:function(e,t){m.updatePercentageWatchedForQuestionSet(e,t)},drawMarkers:function(e,t,n,i){if(V){var a=d.getQuestionSetMarkerTimes(),r=a.length,o=Math.round(i/2),s=0,u=0;t.clearRect(0,0,n,i);for(var c=0;r>c;c++)u=a[c].time/e,s=Math.round(n*u),t.fillStyle=l.getColor(),t.beginPath(),t.arc(s,o,l.getSize(),0,2*Math.PI,!0),t.closePath(),t.fill()}},displayConfirm:function(e){g||(O=e,U&&m.getQuestionSetMarkerTime(e)<=m.getMinMarkerTimeDiff()?gt(!0):At())},addEventListener:function(e,t){"COMPLETE"===e?v=t:"REVIEW"===e?A=t:"BEGIN"===e?S=t:"SKIP"===e?b=t:"ERROR"===e?C=t:"STATUS"===e?T=t:"SUBMITTED"===e?E=t:"SHOW_SUBMISSION_RETRY_MESSAGE"===e?y=t:"HIDE_SUBMISSION_RETRY_MESSAGE"===e?I=t:"SHOW_LOADING_MESSAGE"===e?w=t:"HIDE_LOADING_MESSAGE"===e&&(N=t)},removeEventListener:function(e){"COMPLETE"===e?v=void 0:"REVIEW"===e?A=void 0:"BEGIN"===e?S=void 0:"SKIP"===e?b=void 0:"ERROR"===e?C=void 0:"STATUS"===e?T=void 0:"SUBMITTED"===e?E=void 0:"SHOW_LOADING_MESSAGE"===e?w=void 0:"HIDE_LOADING_MESSAGE"===e&&(N=void 0)},pointViewAt:function(e){x=e,g&&g.pointAt&&g.pointAt(x)},setViewControlBarOffset:function(e){B=e+D,Tt()},setQuestionGrader:function(e){P=e},startTrackingProgress:function(){p.start(R(),z)}}}()}(this,jQuery,TSC.localizationStrings,TSC.deviceInfo,TSC.questionSetView,TSC.questionSetConfirmationView,TSC.quizSetupView,TSC.reviewAnswersConfirmationView,TSC.quizService,TSC.questionType,TSC.quizMarker,TSC.quizModel,TSC.playerConfiguration,TSC.progressTracker),function(e){e.TSC=e.TSC||{},e.TSC.videoAnalytics=function(){"use strict";var e,t,n,i,a,r,o,s=3e4,u=0,c=[{duration:3e5,segmentLength:2e3},{duration:18e5,segmentLength:5e3}],l=0,d=!1;return{setVideoLoadStartTime:function(t){e=t},setVideoLoadEndTime:function(e){t=e},getVideoLoadTime:function(){var n=0;return e&&t&&(n=t-e),n},getNumberSegments:function(){return i},setCurrentPlayTime:function(e){r=e},getCurrentPlayTime:function(){return r},getNumberWatchedSegments:function(){return l},isPercentWatchedInitialized:function(){return u>0},clearPercentWatched:function(){u=0},initPercentWatched:function(e){if(!(0>=e)){u=e,n=s;for(var t=0;c.length>t;t++)if(c[t].duration>=e){n=c[t].segmentLength;break}for(a=[],i=Math.ceil(e/n),t=0;i>t;t++)a.push(!1);l=0}},markTimeWatched:function(e){e>u||(r=e/1e3,o=Math.floor(e/n),0>o||o>=i||a[o]||(l++,a[o]=!0))},getPercentageWatched:function(){return i&&i>0?l/i:0},getPercentageWatchedForVideoSegment:function(e,t){var i=0;if(u>0&&t>=e){for(var r=Math.floor(e/n),o=Math.floor(t/n),s=0,c=o-r+1,l=r;o>=l;l++)a[l]&&s++;i=s/c}return i},setEnabled:function(e){d=e},isEnabled:function(){return d}}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.mediaType=function(){"use strict";return{WEBM:"webm",H264:"h264",OGG:"ogg",YOUTUBE:"youtube",JPG:"jpg",PNG:"png",GIF:"gif",UNKNOWN:"unknown",NOT_AVAILABLE:"not available",MULTIPLE_TYPES:"multiple types"}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.rtfParser=function(){"use strict";function e(e){var t="par ";return e.toLowerCase()==t}function t(e,t){void 0===t&&(t=0); +var n="a",i="z",a=n.charCodeAt(),r=i.charCodeAt(),o=-1;if(e)for(o=e.indexOf(d,t);-1!=o;){if(e.length>o+1){var s=e.toLowerCase().charCodeAt(o+1);if(s>=a&&r>=s)break}o=e.indexOf(d,o+1)}return o}function n(n,a){void 0===a&&(a=0);for(var r=t(n,a);-1!=r;){var o=i(n,r);if(o&&!e(o))break;r=t(n,r+1)}return r}function i(e,t){var n;if(-1!=t){var i=e.indexOf(p,t+1);if(-1!=i){var a=i+1-(t+1);n=e.substr(t+1,a)}else n=e.substr(t+1)}return n}function a(e,t){for(var n="",i=[],a=t.pop();a&&a!=e&&t.length;)n+=d+a,i.push(o(a)),t.length&&(a=t.pop());for(n+=d+e;i.length;){var r=i.pop();r&&(n+=d+r,t.push(o(r)))}return n}function r(e){return-1!=e.indexOf(f)}function o(e){var t;return""!=e&&(r(e)?t=e.substr(0,e.indexOf(f)):(-1!=e.indexOf(g)&&(t=e.substr(0,e.indexOf(g))),t+=f),t+=g),t}function s(e,t){var n=e;if(-1!=t&&n&&n.length>t){var i=n.indexOf(p,t);n=-1!=i?n.substr(0,t)+n.substr(i+1):n.substr(0,t)}return n}function u(e){for(var t=" ",n=e;n.length>1&&n.charAt(0)==t;)n=n.substr(1);for(;n.length>1&&n.charAt(n.length-1)==t;)n=n.substr(0,n.length-1);return n==t&&(n=""),n}function c(s){var u=s;if(u)for(var c=[],l=n(u);-1!==l;){var d=i(u,l);if(d&&r(d)){var f=a(d,c),g=u.indexOf(p,l);u=-1!==g?u.substr(0,l)+f+u.substr(g+1):u.substr(0,l)+f,l+=f.length}else d&&!e(d)&&c.push(o(d)),l=Number(l)+1;l=t(u,l)}return u}function l(e){var t=e;if(t)for(var a=1;a>0;){a=0;for(var r=n(t);-1!=r;){var c=n(t,r+1),l=i(t,r);if(l&&-1!=c){var d=o(l),f=i(t,c);if(f&&f==d){var p=r+1+l.length,g=t.substr(p,c-p);u(g).length||(t=s(t,c),t=s(t,r),c-=l.length+1,a++)}}r=c}}return t}var d="\\",f="0",p=" ",g=" ";return{NestAndCleanUpTags:function(e){var t=e;return t&&(t=c(t),t=l(t)),t}}}()}(this),function(e){e.TSC=e.TSC||{},e.TSC.textFormatter=function(){"use strict";return{rtfToText:function(e){var t=!1;return-1!=e.indexOf("{\\rtf1")&&(e=e.split("{\\rtf1 ").join(""),t=!0),e=e.split("\\i ").join(""),e=e.split("\\i0 ").join(""),e=e.split("\\b ").join(""),e=e.split("\\b0 ").join(""),e=e.split("\\ul ").join(""),e=e.split("\\ul0 ").join(""),e=e.split("\\par ").join(""),e=e.split("\\{").join("{"),e=e.split("\\}").join("}"),e=e.split("\\\\").join("\\"),t&&"}"==e.charAt(e.length-1)&&(e=e.substr(0,e.length-1)),e},rtfToHTML:function(e){e=TSC.rtfParser.NestAndCleanUpTags(e),e=e.split("<").join("<"),e=e.split(">").join(">");var t=!1;return-1!=e.indexOf("{\\rtf1")&&(e=e.split("{\\rtf1 ").join(""),t=!0),e=e.split("\\i0 ").join(""),e=e.split("\\b0 ").join(""),e=e.split("\\ul0 ").join(""),e=e.split("\\i ").join(""),e=e.split("\\b ").join(""),e=e.split("\\ul ").join(""),e=e.split("\\par ").join("
"),e=e.split("\\{").join("{"),e=e.split("\\}").join("}"),e=e.split("\\\\").join("\\"),t&&"}"==e.charAt(e.length-1)&&(e=e.substr(0,e.length-1)),e=e.split("<br>").join("
"),e=e.split("<BR>").join("
")}}}()}(this),function(e,t,n,i,a,r){e.TSC=e.TSC||{},e.TSC.mediaList=function(){"use strict";function e(e){return d(e)}function o(){if(C=0,-1!=m[0].toLowerCase().indexOf(S))T=!0,s(i.getUnicodeSafeString(m[0]));else{T=!1;for(var n,a=[],r=[],o=0;m.length>o;o++){n=m[o];var u={mediaSrc:n};a.push(u),r.push(e(u))}b.push(a),t.when.apply(t,r).done(function(){v&&v.call()})}}function s(e){t.ajax({type:"GET",url:e,isLocal:!0,dataType:"text",success:u,error:c})}function u(n){b=n.split(/\r?\n/g);for(var a=b.length-1,r=[],o=a;o>=0;o--)if(""===b[o])b.splice(o,1);else{var s={mediaSrc:i.getUnicodeSafeString(b[o])};b[o]=s,r.push(e(s))}t.when.apply(t,r).done(function(){v&&v.call()})}function c(){"string"==typeof TSC.embedded_playlist?u(TSC.embedded_playlist):A&&A.call()}function l(e){var t=a.UNKNOWN;switch(e){case r.WEBM:t=a.WEBM;break;case r.MP4:t=a.H264;break;case r.OGG:t=a.OGG;break;case r.JPG:t=a.JPG;break;case r.PNG:t=a.PNG;break;case r.GIF:t=a.GIF;break;default:}return t}function d(e){var n=t.Deferred();e.mediaMimeType=r.UNKNOWN,e.mediaType=a.UNKNOWN;var i=g(e.mediaSrc);return i!==a.UNKNOWN?(e.mediaType=i,e.mediaMimeType=f(i),n.resolve()):p(e.mediaSrc).then(function(t){e.mediaMimeType=t,e.mediaType=l(t),n.resolve()},function(){n.resolve()}),n}function f(e){var t=r.UNKNOWN;switch(e){case a.WEBM:t=r.WEBM;break;case a.H264:t=r.MP4;break;case a.OGG:t=r.OGG;break;case a.JPG:t=r.JPG;break;case a.PNG:t=r.PNG;break;case a.GIF:t=r.GIF;break;default:}return t}function p(e){return t.ajax({type:"HEAD",url:e,done:function(){var e=this.getResponseHeader("content-type")||r.UNKNOWN;defer.resolve(e)},fail:function(){defer.resolve(r.UNKNOWN)}})}function g(e){var t=a.UNKNOWN,n=/youtu(?:\.be|be\.com)\//;if(n.test(e))return a.YOUTUBE;var i=e.split(".");if(i.length>0){var r=i.pop().toLowerCase();switch(r){case"webm":t=a.WEBM;break;case"mp4":case"m4v":case"mov":t=a.H264;break;case"ogv":t=a.OGG;break;case"jpg":case"jpeg":t=a.JPG;break;case"png":t=a.PNG;break;case"gif":t=a.GIF;break;default:}}return t}function h(e){return e===a.GIF||e===a.JPG||e===a.PNG}var m,v,A,S=".m3u",b=[],C=0,T=!1;return{init:function(e){m=e,o()},clear:function(){b=[],C=0,m=void 0},getCurrentMedia:function(){var e=void 0;return b.length>0&&(e=b[C]),e},getCurrentMediaIndex:function(){return C},setCurrentMedia:function(e){"next"===e?b.length-1>C&&C++:"previous"===e?C>0&&C--:Number(e)>=0&&Number(e)n;n++)if(T){if(b[n].mediaSrc===e){t=n;break}}else for(var i=0;b[n].length>i;i++)if(b[n][i].mediaSrc===e){t=n;break}return t},getMediaType:function(){var e=a.NOT_AVAILABLE;if(b.length>0)if(e=a.UNKNOWN,T)e=b[C].mediaType;else{var t=b[C].length;e=1===t?b[C][0].mediaType:a.MULTIPLE_TYPES}return e},isMediaTypeAvailable:function(e){var t=!1;if(b.length>0)if(T)t=e===b[C].mediaType;else for(var n=b[C].length,i=0;n>i&&!(t=e===b[C][i].mediaType);i++);return t},isPlaylist:function(){return T},onFirstMedia:function(){return 0===C},onLastMedia:function(){return C+1===b.length},getErrorMessage:function(){return n.getString("playlistLocalError")},addEventListener:function(e,t){"READY"===e?v=t:"ERROR"===e&&(A=t)},removeEventListener:function(e){"READY"===e?v=void 0:"ERROR"===e&&(A=void 0)},hasImage:function(){var e=!1,t=0;if(b.length>0)if(T)e=h(b[C].mediaType);else{t=b[C].length;for(var n=0;t>n;n++)if(h(b[C][n].mediaType)){e=!0;break}}return e}}}()}(this,jQuery,TSC.localizationStrings,TSC.playerConfiguration,TSC.mediaType,TSC.mediaMimeType),function(e,t,n,i,a,r){"use strict";e.TSC=e.TSC||{},e.TSC.mediaPlayerController=function(){function e(){var e=i.hasImage(),o=i.isMediaTypeAvailable(a.WEBM)&&r.canPlayWebM(),s=i.isMediaTypeAvailable(a.H264)&&r.canPlayMP4(),u=i.isMediaTypeAvailable(a.OGG)&&r.canPlayOgg(),c=i.isMediaTypeAvailable(a.YOUTUBE),l=swfobject.hasFlashPlayerVersion(n.getMinFlashPlayerVersion())&&i.isMediaTypeAvailable(a.H264),d=r.isIE()&&9==r.getIEVersion(),f=r.isIE()&&10==r.getIEVersion();return c?t.YOUTUBE:l&&(n.getForceFlashPlayer()||d||f)?t.FLASH_VIDEO:o||s||u?t.HTML5_VIDEO:l?t.FLASH_VIDEO:e?t.IMAGE:t.NOT_SUPPORTED}var o;return{getPlayerType:function(){return o||(o=e())},clearPlayerType:function(){o=void 0}}}()}(this,TSC.playerType,TSC.playerConfiguration,TSC.mediaList,TSC.mediaType,TSC.deviceInfo),function(e,t,n){e.TSC=e.TSC||{},e.TSC.iFrameBridge=function(){return{postMessage:function(i,a,r){var o={};o.smartPlayerEventName=i,n.getEmbedIFrameId()&&(o.iFrameId=n.getEmbedIFrameId()),r&&(o.data=r),e.top.postMessage(t.stringify(o),a)}}}()}(this,JSON,TSC.playerConfiguration),function(e,t,n,i,a){e.TSC=e.TSC||{},e.TSC.queryParamsStripper=function(){function r(e){var t=e.slice(e.indexOf("?")+1).split("&");t&&t.length>0&&n.saveConfigurationFromQueryString(t)}function o(){t.addCallback("PARENT-URL-PARAMS",s),i.postMessage("GET-EMBEDDED-URL-VARS","*")}function s(e){t.removeCallback("PARENT-URL-PARAMS"),r(e)}return{strip:function(){r(a.getLocationHref()),e.top!=e&&o()}}}()}(this,TSC.externalMessageController,TSC.playerConfiguration,TSC.iFrameBridge,TSC.windowWrapper),function(e,t){e.TSC=e.TSC||{},e.TSC.ioOverlayView=function(){"use strict";var e,n="#tsc_io_container";if(!t||!t.io_overlay_view_template)throw Error("ioOverlayView: IO Overlay View Template not found.");e=t.io_overlay_view_template;var i=" AAAAACH/C05FVFNDQVBFMi4wAwEAAAAh/hpDcmVhdGVkIHdpdGggYWpheGxvYWQuaW5mbwAh+QQJ CgAAACwAAAAAIAAgAAAE5xDISWlhperN52JLhSSdRgwVo1ICQZRUsiwHpTJT4iowNS8vyW2icCF6 k8HMMBkCEDskxTBDAZwuAkkqIfxIQyhBQBFvAQSDITM5VDW6XNE4KagNh6Bgwe60smQUB3d4Rz1Z BApnFASDd0hihh12BkE9kjAJVlycXIg7CQIFA6SlnJ87paqbSKiKoqusnbMdmDC2tXQlkUhziYty WTxIfy6BE8WJt5YJvpJivxNaGmLHT0VnOgSYf0dZXS7APdpB309RnHOG5gDqXGLDaC457D1zZ/V/ nmOM82XiHRLYKhKP1oZmADdEAAAh+QQJCgAAACwAAAAAIAAgAAAE6hDISWlZpOrNp1lGNRSdRpDU olIGw5RUYhhHukqFu8DsrEyqnWThGvAmhVlteBvojpTDDBUEIFwMFBRAmBkSgOrBFZogCASwBDEY /CZSg7GSE0gSCjQBMVG023xWBhklAnoEdhQEfyNqMIcKjhRsjEdnezB+A4k8gTwJhFuiW4dokXil oUepBAp5qaKpp6+Ho7aWW54wl7obvEe0kRuoplCGepwSx2jJvqHEmGt6whJpGpfJCHmOoNHKaHx6 1WiSR92E4lbFoq+B6QDtuetcaBPnW6+O7wDHpIiK9SaVK5GgV543tzjgGcghAgAh+QQJCgAAACwA AAAAIAAgAAAE7hDISSkxpOrN5zFHNWRdhSiVoVLHspRUMoyUakyEe8PTPCATW9A14E0UvuAKMNAZ KYUZCiBMuBakSQKG8G2FzUWox2AUtAQFcBKlVQoLgQReZhQlCIJesQXI5B0CBnUMOxMCenoCfTCE WBsJColTMANldx15BGs8B5wlCZ9Po6OJkwmRpnqkqnuSrayqfKmqpLajoiW5HJq7FL1Gr2mMMcKU MIiJgIemy7xZtJsTmsM4xHiKv5KMCXqfyUCJEonXPN2rAOIAmsfB3uPoAK++G+w48edZPK+M6hLJ pQg484enXIdQFSS1u6UhksENEQAAIfkECQoAAAAsAAAAACAAIAAABOcQyEmpGKLqzWcZRVUQnZYg 1aBSh2GUVEIQ2aQOE+G+cD4ntpWkZQj1JIiZIogDFFyHI0UxQwFugMSOFIPJftfVAEoZLBbcLEFh lQiqGp1Vd140AUklUN3eCA51C1EWMzMCezCBBmkxVIVHBWd3HHl9JQOIJSdSnJ0TDKChCwUJjoWM PaGqDKannasMo6WnM562R5YluZRwur0wpgqZE7NKUm+FNRPIhjBJxKZteWuIBMN4zRMIVIhffcgo jwCF117i4nlLnY5ztRLsnOk+aV+oJY7V7m76PdkS4trKcdg0Zc0tTcKkRAAAIfkECQoAAAAsAAAA ACAAIAAABO4QyEkpKqjqzScpRaVkXZWQEximw1BSCUEIlDohrft6cpKCk5xid5MNJTaAIkekKGQk WyKHkvhKsR7ARmitkAYDYRIbUQRQjWBwJRzChi9CRlBcY1UN4g0/VNB0AlcvcAYHRyZPdEQFYV8c cwR5HWxEJ02YmRMLnJ1xCYp0Y5idpQuhopmmC2KgojKasUQDk5BNAwwMOh2RtRq5uQuPZKGIJQIG wAwGf6I0JXMpC8C7kXWDBINFMxS4DKMAWVWAGYsAdNqW5uaRxkSKJOZKaU3tPOBZ4DuK2LATgJhk PJMgTwKCdFjyPHEnKxFCDhEAACH5BAkKAAAALAAAAAAgACAAAATzEMhJaVKp6s2nIkolIJ2WkBSh pkVRWqqQrhLSEu9MZJKK9y1ZrqYK9WiClmvoUaF8gIQSNeF1Er4MNFn4SRSDARWroAIETg1iVwuH jYB1kYc1mwruwXKC9gmsJXliGxc+XiUCby9ydh1sOSdMkpMTBpaXBzsfhoc5l58Gm5yToAaZhaOU qjkDgCWNHAULCwOLaTmzswadEqggQwgHuQsHIoZCHQMMQgQGubVEcxOPFAcMDAYUA85eWARmfSRQ CdcMe0zeP1AAygwLlJtPNAAL19DARdPzBOWSm1brJBi45soRAWQAAkrQIykShQ9wVhHCwCQCACH5 BAkKAAAALAAAAAAgACAAAATrEMhJaVKp6s2nIkqFZF2VIBWhUsJaTokqUCoBq+E71SRQeyqUToLA 7VxF0JDyIQh/MVVPMt1ECZlfcjZJ9mIKoaTl1MRIl5o4CUKXOwmyrCInCKqcWtvadL2SYhyASyND J0uIiRMDjI0Fd30/iI2UA5GSS5UDj2l6NoqgOgN4gksEBgYFf0FDqKgHnyZ9OX8HrgYHdHpcHQUL XAS2qKpENRg7eAMLC7kTBaixUYFkKAzWAAnLC7FLVxLWDBLKCwaKTULgEwbLA4hJtOkSBNqITT3x EgfLpBtzE/jiuL04RGEBgwWhShRgQExHBAAh+QQJCgAAACwAAAAAIAAgAAAE7xDISWlSqerNpyJK hWRdlSAVoVLCWk6JKlAqAavhO9UkUHsqlE6CwO1cRdCQ8iEIfzFVTzLdRAmZX3I2SfZiCqGk5dTE SJeaOAlClzsJsqwiJwiqnFrb2nS9kmIcgEsjQydLiIlHehhpejaIjzh9eomSjZR+ipslWIRLAgMD OR2DOqKogTB9pCUJBagDBXR6XB0EBkIIsaRsGGMMAxoDBgYHTKJiUYEGDAzHC9EACcUGkIgFzgwZ 0QsSBcXHiQvOwgDdEwfFs0sDzt4S6BK4xYjkDOzn0unFeBzOBijIm1Dgmg5YFQwsCMjp1oJ8LyIA ACH5BAkKAAAALAAAAAAgACAAAATwEMhJaVKp6s2nIkqFZF2VIBWhUsJaTokqUCoBq+E71SRQeyqU ToLA7VxF0JDyIQh/MVVPMt1ECZlfcjZJ9mIKoaTl1MRIl5o4CUKXOwmyrCInCKqcWtvadL2SYhyA SyNDJ0uIiUd6GGl6NoiPOH16iZKNlH6KmyWFOggHhEEvAwwMA0N9GBsEC6amhnVcEwavDAazGwID aH1ipaYLBUTCGgQDA8NdHz0FpqgTBwsLqAbWAAnIA4FWKdMLGdYGEgraigbT0OITBcg5QwPT4xLr ROZL6AuQAPUS7bxLpoWidY0JtxLHKhwwMJBTHgPKdEQAACH5BAkKAAAALAAAAAAgACAAAATrEMhJ aVKp6s2nIkqFZF2VIBWhUsJaTokqUCoBq+E71SRQeyqUToLA7VxF0JDyIQh/MVVPMt1ECZlfcjZJ 9mIKoaTl1MRIl5o4CUKXOwmyrCInCKqcWtvadL2SYhyASyNDJ0uIiUd6GAULDJCRiXo1CpGXDJOU jY+Yip9DhToJA4RBLwMLCwVDfRgbBAaqqoZ1XBMHswsHtxtFaH1iqaoGNgAIxRpbFAgfPQSqpbgG BqUD1wBXeCYp1AYZ19JJOYgH1KwA4UBvQwXUBxPqVD9L3sbp2BNk2xvvFPJd+MFCN6HAAIKgNggY 0KtEBAAh+QQJCgAAACwAAAAAIAAgAAAE6BDISWlSqerNpyJKhWRdlSAVoVLCWk6JKlAqAavhO9Uk UHsqlE6CwO1cRdCQ8iEIfzFVTzLdRAmZX3I2SfYIDMaAFdTESJeaEDAIMxYFqrOUaNW4E4ObYcCX aiBVEgULe0NJaxxtYksjh2NLkZISgDgJhHthkpU4mW6blRiYmZOlh4JWkDqILwUGBnE6TYEbCgev r0N1gH4At7gHiRpFaLNrrq8HNgAJA70AWxQIH1+vsYMDAzZQPC9VCNkDWUhGkuE5PxJNwiUK4UfL zOlD4WvzAHaoG9nxPi5d+jYUqfAhhykOFwJWiAAAIfkECQoAAAAsAAAAACAAIAAABPAQyElpUqnq zaciSoVkXVUMFaFSwlpOCcMYlErAavhOMnNLNo8KsZsMZItJEIDIFSkLGQoQTNhIsFehRww2CQLK F0tYGKYSg+ygsZIuNqJksKgbfgIGepNo2cIUB3V1B3IvNiBYNQaDSTtfhhx0CwVPI0UJe0+bm4g5 VgcGoqOcnjmjqDSdnhgEoamcsZuXO1aWQy8KAwOAuTYYGwi7w5h+Kr0SJ8MFihpNbx+4Erq7BYBu zsdiH1jCAzoSfl0rVirNbRXlBBlLX+BP0XJLAPGzTkAuAOqb0WT5AH7OcdCm5B8TgRwSRKIHQtaL Cwg1RAAAOwAAAAAAAAAAAA==",a=!1;return{getViewMarkup:function(t){var n={ioMessage:t,loaderImg:i};return e(n)},setViewMessage:function(e){$(n+" span").html(e)},hideLoadingGraphic:function(){$(n+" img").hide()},showLoadingGraphic:function(){$(n+" img").show()},viewOpen:function(){return a},showView:function(){$(n).css("opacity",0),$(n).animate({opacity:1},300),a=!0},removeView:function(e){a=!1,$(n).animate({opacity:0},200,function(){void 0!==e&&e.call(),$(n).remove()})}}}()}(this,TSC.templates),function(e,t,n,i,a,r,o,s,u,n){e.TSC=e.TSC||{},e.TSC.xmp=e.TSC.xmp||function(){"use strict";function e(){I=!1,w=!1,N=!1,x=!1,R=!1,P=!1,M=!1,H=!1,z="",W=0,J="en-US",Y="#ffffff",j="#000000",K=.9,Z="Arial, Helvetica, sans-serif;",X=18,$={r:255,g:255,b:255},et="overlay",tt=0,nt=2,it=144,at=[],rt=[],ot=[],st=[],ut=[]}function c(e){return-1!==e.indexOf("http://")||-1!==e.indexOf("https://")}function l(){y&&y.call()}function d(e,t,n){for(var i=(e<<16|t<<8|n).toString(16),a=6-i.length,r=0;a>r;r++)i="0"+i;return"#"+i}function f(e){t(e).find("*").filterNode("rdf:Description").each(function(){var e=Number(t(this).attr("xmpDM:startTime"))/1e3,n=s.getUnicodeSafeString(t(this).attr("tscDM:file")),i=t(this).attr("xmpDM:name"),a=t(this).attr("tscDM:image"),r=t(this).attr("tscDM:imagerect");r&&!H&&(H=!0,z="."===s.getSwfBase()||c(a)?s.getUnicodeSafeString(a):s.getSwfBase()+s.getUnicodeSafeString(a));var o={time:e,text:i,file:n,image:a,imageRect:r};at.push(o)})}function p(e){var n=t(e).find("*").length,i=e.find("*").eq(n-2);if(i&&i.length>0&&"tsc:fgColor"===i[0].nodeName){var a=i.attr("xmpG:red"),r=i.attr("xmpG:green"),u=i.attr("xmpG:blue");Y=d(a,r,u)}var c=e.find("*").eq(n-1);c&&c.length>0&&"tsc:bgColor"===c[0].nodeName&&($.r=c.attr("xmpG:red"),$.g=c.attr("xmpG:green"),$.b=c.attr("xmpG:blue"),j=d($.r,$.g,$.b)),t(e).find("*").filterNode("rdf:Description").each(function(){var e,n,i=Number(t(this).attr("xmpDM:startTime"))/1e3,a=Number(t(this).attr("xmpDM:duration"))/1e3,r=i+a,u=t(this).find("*").filterNode("rdf:li").text(),c=o.rtfToText(u),l=t(this).attr("tscDM:valign"),d=t(this).attr("tscDM:halign");switch(l){case"top":e="captionVAlignTop";break;default:e="captionVAlignBottom"}switch(d){case"left":n="captionHAlignLeft";break;case"right":n="captionHAlignRight";break;default:n="captionHAlignCenter"}u=o.rtfToHTML(u);var f=s.getUnicodeSafeString(t(this).attr("tscDM:file"));if(""!==c.replace(/ /g,"")){var p={start:i,end:r,text:c,htmlText:u,file:f,vAlign:l,vAlignClass:e,hAlignClass:n};rt.push(p)}})}function g(e,t){for(var n=[],i=e[4]-e[0],a=e[5]-e[1],r=i/2+e[0],o=a/2+e[1],s=e.length,u=0;s>u;u+=2){var c=h(e[u],e[u+1],i,a,r,o,t);n.push(Math.round(c[0])),n.push(Math.round(c[1]))}return n}function h(e,t,n,i,a,r,o){o=o*Math.PI/180;var s=e-a,u=t-r,c=Math.atan2(u,s),l=Math.sqrt(s*s+u*u),d=c+o,f=Math.cos(d)*l,p=Math.sin(d)*l,g=[];return g[0]=f+a,g[1]=p+r,g}function m(e){var n=0;t(e).find("*").filterNode("rdf:Description").each(function(){var e=t(this).attr("xmp:label"),i=Number(t(this).attr("xmpDM:startTime"))/1e3,a=Number(t(this).attr("xmpDM:duration"))/1e3,r=i+a,o=t(this).attr("tscDM:boundingPoly"),u=parseFloat(t(this).attr("tscDM:rotate")),c=s.getUnicodeSafeString(t(this).attr("tscHS:jumpFile")),l=o.replace(/\;/gi,",");l.lastIndexOf(",")==l.length-1&&(l=l.substr(0,l.length-1));for(var d=l.split(","),f=0;d.length>f;f++)d[f]=parseInt(d[f],10);0!==u&&(d=g(d,u));var p=!1,h="",m="",v="";"1"===t(this).attr("tscHS:pause")&&(p=!0),void 0!==t(this).attr("tscHS:jumpTime")&&(h=Number(t(this).attr("tscHS:jumpTime"))/1e3),void 0!==t(this).attr("tscHS:newWindow")&&(m=t(this).attr("tscHS:newWindow"),m="0"===m||"false"===m.toLowerCase()?!1:!0),void 0!==t(this).attr("xmpDM:location")&&(v=t(this).attr("xmpDM:location"));var A=s.getUnicodeSafeString(t(this).attr("tscDM:file")),S={id:e,start:i,end:r,pause:p,hasPausedAtEnd:!1,points:d,scaledPoints:d.concat([]),rotation:u,file:A,jumpTime:h,jumpFile:c,newWindow:m,targetURL:v,isActive:!1,index:n};ot.push(S),n++})}function v(e){var n,i,a,o,s,c,l,d,f=-1,p=!1,g=[];u.clearAllQuestions(),t(e).find("*").filterNode("rdf:Description").each(function(){var e=t(this).attr("tscIQ:questionSetName");if(e){e=r.htmlEncode(e),p&&(u.addQuestion(f,n,a,o,g,c),p=!1,o=void 0,a=void 0,g=[],c=void 0);var h="1"===t(this).attr("tscIQ:feedback"),m=Number(t(this).attr("xmpDM:startTime"));f=u.addQuestionSet(e,m,h)}else i=t(this).attr("tscIQ:type"),i?(p&&(u.addQuestion(f,n,a,o,g,c),p=!1,o=void 0,a=void 0,g=[],c=void 0),a=t(this).attr("tscIQ:id"),n=i,l=t(this).children(),o=r.htmlEncode(t(l[0]).text(),!0),c=r.htmlEncode(t(l[1]).text(),!0),p=!0):(s=t(this).attr("tscIQ:orderId"),s&&(l=t(this).children(),d=t(l[0]).text(),d&&g.push(r.htmlEncode(d,!0))))}),p&&u.addQuestion(f,n,a,o,g,c)}function A(e){var n=[];t(e).find("*").filterNode("rdf:Description").each(function(){for(var e=Number(t(this).attr("xmpDM:startTime"))/1e3,i=Number(t(this).attr("xmpDM:duration"))/1e3,a=t(this).attr("xmpDM:name"),r=s.getUnicodeSafeString(t(this).attr("tscDM:file")),o=a.split(" "),u=Number(e)+Number(i)+"",c=0;o.length>c;c++){var l={start:e,end:u,text:o[c],file:r};n.push(l)}});var i=n.length;if(!(1>i)){for(var a,r=n[0].start,o="",u=[],c=0;i>c;c++)n[c].start!==r&&(a={start:n[c-1].start,end:n[c-1].end,text:o,items:u,file:n[c-1].file},st.push(a),o="",u=[]),o+=n[c].text+" ",u.push(n[c].text),r=n[c].start;a={start:n[c-1].start,end:n[c-1].end,text:o,items:u,file:n[c-1].file},st.push(a)}}function S(e){t(e).find("*").filterNode("rdf:li").each(function(){var e=Number(t(this).attr("xmpDM:startTime"))/1e3,n=Number(t(this).attr("xmpDM:duration"))/1e3,i=t(this).attr("xmpDM:name"),a=s.getUnicodeSafeString(t(this).attr("tscDM:file")),r=t(this).attr("tscDM:image"),o=t(this).attr("tscDM:imagerect"),u={start:e,end:Number(e)+Number(n)+"",text:i,file:a,image:r,imageRef:document.createElement("canvas"),imageRect:o};ut.push(u)})}function b(){I&&f(B),w&&p(Q),x&&v(q),N&&m(V),R&&A(D),P&&S(O),M=!0,E&&E.call()}function C(r){e();var o=t(r).find("*").eq(2);L=o.attr("dc:title"),_=o.attr("tscDM:originId"),k=o.attr("tscDM:project"),W=Number(t(r).find("*").eq(3).attr("xmpDM:value")),G=L;var l,d,f=t(r).find("*").length,p=0;for(l=4;f>l;l++)if("xmpDM:Tracks"===t(r).find("*").eq(l)[0].nodeName){d=t(r).find("*").eq(l).children();break}for(var g,h=t(d).find("*").length,m=0;h>m;m++){var v=t(d).find("*").eq(m);if(g=v.attr("xmpDM:trackType"),void 0!==g)switch(g.toLowerCase()){case"tableofcontents":F=t(v).attr("tscDM:tocCellLayout"),U=s.getUnicodeSafeString(t(v).attr("tscDM:image")),"."===s.getSwfBase()||void 0===U||c(U)||(U=s.getSwfBase()+U),I=!0,B=t(v),m+=B.find("*").length;break;case"quiz":if(u&&void 0===s.getFathomId()){x=!0;var A=t(v).attr("tscIQ:quizGuid"),S=t(v).attr("tscIQ:reportMethod"),C="1"===t(v).attr("tscIQ:requireUserId"),T="1"===t(v).attr("tscIQ:hideReplay"),E=t(v).attr("tscIQ:authoredEmail"),y=t(v).attr("tscIQ:clientId"),M=t(v).attr("tscIQ:quizHash"),H=t(v).attr("tscIQ:allowSkipQuiz"),z=t(v).attr("tscIQ:locale");z||(z=i.ENGLISH),u.setLocale(z),u.setProductionMetadata(k,L,_),u.setQuizTitle(L),u.setQuizID(A),u.setReportMethod(S),u.setRequireUserId(C),u.setHideReplay(T),u.setAuthoredEmail(E),u.setClientId(y),u.setQuizHash(M),u.setMediaDuration(W),u.setAllowSkipQuiz(H)}q=t(v),m+=q.find("*").length;break;case"caption":var J=t(v).attr("stFnt:fontFamily");J&&(Z=J);var Y=t(v).attr("tscDM:fontSize");Y&&(X=Number(Y));var j=t(v).attr("tscDM:bgOpacity");j&&(K=Number(j));var $=t(v).attr("tscDM:position");$&&(et=$);var nt=t(v).attr("tscDM:captionbarheight");nt&&(tt=Number(nt)),w=!0,Q=t(v),m+=Q.find("*").length;break;case"hotspot":N=!0,V=t(v),m+=V.find("*").length;break;case"speech":O=t(v);var it=O.find("*").length;if(1>=it)break;P=!0,m+=it;break;case"screentext":R=!0,D=t(v),m+=D.find("*").length}}l+=p,t(r).find("*").filterNode("tscIQ:QuizParams").filterNode("rdf:li").each(function(){var e=t(this).attr("xmpDM:name"),i=t(this).attr("xmpDM:value");try{a.setString(e,i)}catch(r){n.logMessage(r.message)}});var at,rt,ot=0;for(l=l;f>l;l++)if("tscDM:controller"===t(r).find("*").eq(l)[0].nodeName){at=t(r).find("*").eq(l).children(),ot=t(at).find("*").length;break}t(at).find("*").filterNode("rdf:li").each(function(){if(void 0!=t(this).attr("xmpDM:name"))switch(rt=t(this).attr("xmpDM:value").toLowerCase(),t(this).attr("xmpDM:name").toLowerCase()){case"autohide":var e="true"===rt?!0:!1;s.setAutoHideControls(e);break;case"autostart":case"autoplay":var n="true"===rt?!0:!1;s.getAutoPlayMedia()||s.setAutoPlayMedia(n);break;case"searchable":var i="true"===rt?!0:!1;s.setIsSearchable(i);break;case"captionsenabled":var r="true"===rt?!0:!1;s.setCaptionsEnabled(r);break;case"sidebarenabled":var o="true"===rt?!0:!1;s.setSidebarEnabled(o);break;case"unicodeenabled":var u="true"===rt?!0:!1;s.setProcessUnicodeNames(u);break;case"backgroundcolor":var c=rt;-1===c.indexOf("#")&&(c="#"+c),s.setBackgroundColor(c);break;case"sidebarlocation":var l="right"===rt||"r"===rt?"right":"left";s.setSidebarLocation(l);break;case"endaction":s.setEndActionType(rt);break;case"endactionparam":s.setEndActionParam(rt);break;case"locale":a.setLanguage(t(this).attr("xmpDM:value"))}}),setTimeout(b,500)}function T(e,i){if(e){var a=e,r=!0;if(s.isIEOnServerWithUnicode()){var o=location.href.lastIndexOf("/"),u=location.href.substr(0,o+1);a=s.getUnicodeSafeString(u)+e,r=!1}try{t.ajax({type:"GET",url:a,isLocal:r,dataType:"xml",timeout:lt,success:function(e){ct>i&&n.logMessage("xmp: loadXMP() succeeded after "+(ct-i)+" failed attempts."),C(e)},error:function(){i>0?setTimeout(function(){T(e,--i)},dt):(n.logMessage("xmp: loadXMP() failed after "+ct+" retries."),l())}})}catch(c){n.logException(c)}}}t.fn.filterNode=function(e){return this.find("*").filter(function(){return this.nodeName===e})};var E,y,I,w,N,x,R,P,M,L,k,_,O,D,B,Q,V,q,G,F,U,H,z,W,J,Y,j,K,Z,X,$,et,tt,nt,it,at,rt,ot,st,ut,ct,lt,dt;return lt=3500,ct=2,dt=0,e(),{loadXMP:function(e){T(e,ct)},parseXMP:function(e){C(t.parseXML(e))},xmpAvailable:function(){return M},hasAdvancedFeatures:function(){return M&&(I||w||N||x)},getMediaDuration:function(){return W},getTocTitle:function(){return G},getTocImageSrc:function(){return U},getTocCellLayoutType:function(){return F},tocContainsThumbs:function(){return H},getTocThumbImageSrc:function(){return z},getTocItemArray:function(){return at},getHotspotItemArray:function(){return ot},getCaptionItemArray:function(){return rt},getCaptionFontFamily:function(){return Z},getCaptionFontSize:function(){return X},getMinCaptionFontSize:function(){return nt},getMaxCaptionFontSize:function(){return it},getCaptionBgOpacity:function(){return K},getCaptionTextColor:function(){return Y},getCaptionBgColor:function(){return j},getCaptionBg:function(){return"rgba("+$.r+", "+$.g+", "+$.b+", "+K+")"},getCaptionPosition:function(){return et},getCaptionBarHeight:function(){return tt},getSpeechTextItemArray:function(){return ut},getScreenTextItemArray:function(){return st},getLanguage:function(){return J},hasTocItems:function(){return I},hasCaptionItems:function(){return w},hasHotspotItems:function(){return N},hasQuiz:function(){return x},hasScreenTextItems:function(){return R},hasSpeechTextItems:function(){return P},getLocalErrorMessage:function(){return a.getString("xmpSecurity")},get404ErrorMessage:function(){return a.getString("xmpError")},addEventListener:function(e,t){"READY"===e?E=t:"ERROR"===e&&(y=t)},removeEventListener:function(e){"READY"===e?E=void 0:"ERROR"===e&&(y=void 0)}}}()}(this,jQuery,TSC.log,TSC.languageCodes,TSC.localizationStrings,TSC.textSanitizer,TSC.textFormatter,TSC.playerConfiguration,TSC.quizModel,TSC.log),function(e,t,n,i,a){e.TSC=e.TSC||{},e.TSC.playerSettingsView=function(){function r(){E.hide(),u()}function o(){E.show(),s()}function s(){B.mouseup(l)}function u(){B.off("mouseup",l)}function c(){y=!1,r(),D!==void 0&&D()}function l(e){y!==!1&&(E.is(e.target)||0!==E.has(e.target).length||setTimeout(function(){c()},50))}function d(){E=t("#playerSettingsContainer"),w=t("#playerSpeedContainer select")}function f(){var e=I.playbackRate;e!==Number(w.find(":selected").val())&&(e>R?p(R):x>e?p(x):w.find('option[value="'+I.playbackRate+'"]').prop("selected",!0))}function p(e){x>e?e=x:e>R&&(e=R),N=e,I.playbackRate=e,I.defaultPlaybackRate=e,!a.isIPad()&&!a.isIPhoneOrIPod()||I.paused||(I.pause(),I.play()),setTimeout(function(){c()},2e3)}function g(){var e=Number(w.find(":selected").val());p(e)}function h(){f()}function m(){var e=O.indexOf(N);-1!==e&&O.length>e+1&&p(O[e+1])}function v(){var e=O.indexOf(N);-1!==e&&e>0&&p(O[e-1])}function A(e){if(P===e.shiftKey)switch(e.keyCode){case M:e.preventDefault(),m();break;case L:e.preventDefault(),v()}}function S(){for(var e=i.getString("playerRateOptionsText"),t=[],n=O.length-1;n>=0;n--){var a=O[n];t.push({rateValue:a,rateLabel:e[a],selected:a===k})}return t}function b(){y=!1,N=k}function C(){w.unbind("change",g),B.unbind("keydown",A),I&&I.removeEventListener("ratechange",h)}function T(){w.bind("change",g),B.bind("keydown",A)}var E,y,I,w,N,x,R,P,M,L,k,_,O,D,B;return y=!1,P=!0,N=1,M=38,L=40,x=.25,R=2,k=1,_=[.25,.5,.75,1,1.25,1.5,1.75,2],O=_,B=t(e.document),{destroy:function(){C()},render:function(e){var a={playerRateText:i.getString("playerRateText"),playbackRates:S()},o=n.settings_view_template(a);t(e).append(o),b(),d(),T(),r()},setVideoElement:function(e){I=e,I.addEventListener("ratechange",h,!1)},setOnHideCallback:function(e){D=e},open:function(){y=!0,o()},close:function(){y=!1,r()},isOpen:function(){return y},setAvailableRates:function(e){O=e.length>0?e:_,x=O[0],R=O[O.length-1]},getPlaybackRate:function(){return N}}}()}(window,jQuery,TSC.templates,TSC.localizationStrings,TSC.deviceInfo),jQuery(function(e){var t,n,i,a,r,o,s,u;t={},n=function(){var t=e.fn.width,n=e("#tscVideoContent"),i=e("body");return function(){return document.msFullscreenElement&&t.call(i)!==t.call(n)}}(),i=function(e){return parseInt(e.css("margin-left"),10)+parseInt(e.css("margin-right"),10)},a=function(e){return parseInt(e.css("margin-top"),10)+parseInt(e.css("margin-bottom"),10)},r=function(e){return parseInt(e.css("padding-left"),10)+parseInt(e.css("padding-right"),10)},o=function(e){return parseInt(e.css("padding-top"),10)+parseInt(e.css("padding-bottom"),10)},s=function(e){return parseInt(e.css("border-left-width"),10)+parseInt(e.css("border-right-width"),10)},u=function(e){return parseInt(e.css("border-top-width"),10)+parseInt(e.css("border-bottom-width"),10)},t.width=e.fn.width,e.fn.width=function(){return 0===arguments.length&&0 in this&&n()&&this[0]!=window?Math.round(100*this[0].getBoundingClientRect().width-r(this)-s(this)):t.width.apply(this,e.makeArray(arguments))},t.innerWidth=e.fn.innerWidth,e.fn.innerWidth=function(){return 0===arguments.length&&0 in this&&n()&&this[0]!=window?Math.round(100*this[0].getBoundingClientRect().width-s(this)):t.innerWidth.apply(this,e.makeArray(arguments))},t.outerWidth=e.fn.outerWidth,e.fn.outerWidth=function(a){var r;return 1>=arguments.length&&0 in this&&n()&&this[0]!=window?(r=Math.round(100*this[0].getBoundingClientRect().width),a?r+i(this):r):t.outerWidth.apply(this,e.makeArray(arguments))},t.height=e.fn.height,e.fn.height=function(){return 0===arguments.length&&0 in this&&n()&&this[0]!=window?Math.round(100*this[0].getBoundingClientRect().height-o(this)-u(this)):t.height.apply(this,e.makeArray(arguments))},t.innerHeight=e.fn.innerHeight,e.fn.innerHeight=function(){return 0===arguments.length&&0 in this&&n()&&this[0]!=window?Math.round(100*this[0].getBoundingClientRect().height-u(this)):t.innerHeight.apply(this,e.makeArray(arguments))},t.outerHeight=e.fn.outerHeight,e.fn.outerHeight=function(i){var r;return 1>=arguments.length&&0 in this&&n()&&this[0]!=window?(r=Math.round(100*this[0].getBoundingClientRect().height),i?r+a(this):r):t.outerHeight.apply(this,e.makeArray(arguments))},t.offset=e.fn.offset,e.fn.offset=function(){var i;return 0===arguments.length&&0 in this&&n()?(i=t.offset.apply(this),i&&(i.top=Math.round(100*i.top),i.left=Math.round(100*i.left)),i):t.offset.apply(this,e.makeArray(arguments))}}),function(e){e.TSC=e.TSC||{},e.TSC.playedTracker=function(e){var n=.5,i=function(){var n=[],i=0,a=this;this.start=function(e){if(0>e||e>n.length-1)throw"INDEX_SIZE_ERR";return n[e].start},this.end=function(e){if(0>e||e>n.length-1)throw"INDEX_SIZE_ERR";return n[e].end},Object.defineProperty(this,"length",{get:function(){return n.length}});var r=function(){n.push(new t),i=n.length-1},o=function(e){0===a.length&&(r(),n[0].recordTime(0)),n[i].recordTime(e.data),n.length>1&&u()},s=function(e){var t=l(e.data);-1===t&&r()},u=function(){for(var e=n.length,t=0;e>t;t++)if(i!=t&&a.areMediaSegmentsOverlapping(n[i],n[t])){c(i,t);break}},c=function(e,t){var a=Math.min(e,t),r=Math.max(e,t);n[a].start=Math.min(n[e].start,n[t].start),n[a].end=Math.max(n[e].end,n[t].end),n.splice(r,1),i=a},l=function(e){for(var t=-1,i=n.length,a=0;i>a;a++)if(e>=n[a].start&&n[a].end>=e){t=a;break}return t};e.addEventListener("seeked",s),e.addEventListener("timeupdate",o)};return i.prototype.areMediaSegmentsOverlapping=function(e,t){var i=t.start>=e.start-n&&t.start<=e.end+n,a=t.end>=e.start-n&&t.end<=e.end+n;return i||a},new i};var t=function(){var e=-1,t=-1,n=function(){};return Object.defineProperty(n,"start",{get:function(){return e},set:function(t){e=+t}}),Object.defineProperty(n,"end",{get:function(){return t},set:function(e){t=+e}}),n.recordTime=function(n){(-1===e||e>n)&&(e=n),n>t&&(t=n)},n}}(window),function(e,t,n,i,a){e.onYouTubeIframeAPIReady=function(){e.onYouTubeIframeAPIReady.ready=!0;for(var t=0;e.onYouTubeIframeAPIReady.queued.length>t;t++)e.onYouTubeIframeAPIReady.queued[t]()};var r="https://www.youtube.com/iframe_api";e.onYouTubeIframeAPIReady.queued=[],e.TSC=e.TSC||{};var o=function(t,r,s,u,c,l,d){function f(){v=x.getDuration(),i.requiresManualPreload()&&u(),R("loadedmetadata"),R("canplay"),g.removeEventListener("playing",f),R("playing"),R("play")}function p(){if(E=x.getAvailablePlaybackRates(),E.length>1&&(C=!0),i.requiresManualPreload())return s(),g.addEventListener("playing",f),void 0;var e=x.getVolume();x.setVolume(0);var t=setTimeout(function(){throw"YouTube Plugin Error: Initial play failed to trigger within 10 seconds"},1e4);g.addEventListener("play",function n(){g.removeEventListener("play",n),clearTimeout(t),x.pauseVideo(),x.seekTo(0),x.setVolume(e),g.addEventListener("playing",f),s()}),x.playVideo()}if(!(this instanceof o))return new o;var g=this,h={},m=0,v=0,A=0,S=1,b=-1,C=!1,T=50,E=[],y=3;this.addEventListener=function(e,t){h[e]=h[e]||[],h[e].push(t)},this.removeEventListener=function(e,t){if(h[e]&&0!==h[e].length){var n=h[e].indexOf(t);-1!==n&&h[e].splice(n,1)}},this.bind=function(e,t){if("string"==typeof e)this.addEventListener(e,t);else if("object"==typeof e)for(var n=Object.keys(e),i=0;n.length>i;i++){var a=n[i];g.addEventListener(a,e[a])}},this.unbind=function(e,t){t!==void 0?this.removeEventListener(e,t):h[e]=[]},this.off=this.unbind;var I=function(e){switch(e.data){case 2:R("error","Invalid video url.");break;case 5:R("error","The video cannot be played.");break;case 100:R("error","This video has been removed from YouTube and is no longer available for playback.");break;case 101:case 150:R("error","This video is unavailable. Its YouTube owner either disabled embedding or marked it private.");break;default:}};c&&this.addEventListener("error",c);var w=function(e){switch(b=e.data,e.data){case YT.PlayerState.PAUSED:R("pause");break;case YT.PlayerState.ENDED:R("ended");break;case YT.PlayerState.PLAYING:R("playing"),R("play");break;case YT.PlayerState.BUFFERING:}},N=function(e){S=e.data,R("ratechange",S) +};n.getShowYouTubeAnnotations()&&(y=1);var x=new e.YT.Player(r,{width:l,height:d,videoId:t,playerVars:{wmode:"opaque",loop:0,autoplay:0,controls:0,disablekb:1,rel:0,showsearch:0,showinfo:0,iv_load_policy:y},events:{onReady:p,onStateChange:w,onPlaybackRateChange:N,onError:I}}),R=function(e,t){var n={type:e,target:g,data:t};if(h.hasOwnProperty(e))for(var i=h[e].slice(0),a=0;i.length>a;a++)i[a](n)},P=new a(this),M=function(){return{start:function(){return 0},end:function(){return v*A},length:1}};Object.defineProperty(this,"buffered",{get:M}),Object.defineProperty(this,"currentTime",{get:function(){return m},set:function(e){+e>g.buffered.end()?x.seekTo(+e,!0):x.seekTo(+e),R("seeked")}}),Object.defineProperty(this,"duration",{get:function(){return v}}),Object.defineProperty(this,"paused",{get:function(){return b===YT.PlayerState.PAUSED}}),Object.defineProperty(this,"playbackRate",{get:function(){return S},set:function(e){x.setPlaybackRate(+e)}}),Object.defineProperty(this,"played",{get:function(){return P}}),Object.defineProperty(this,"seekable",{get:function(){return{start:function(){return 0},end:function(){return v},length:1}}}),Object.defineProperty(this,"supportPlaybackRate",{get:function(){return C}}),Object.defineProperty(this,"validRateSettings",{get:function(){return E}}),Object.defineProperty(this,"volume",{get:function(){return T},set:function(e){var t=100*e;x.setVolume(t),T=t}}),this.play=function(){x.playVideo()},this.pause=function(){x.pauseVideo()},this.attr=function(e,t){var n=document.getElementById(r);n.setAttribute(e,t)},this.load=function(){};var L=function(){if(void 0!==x.getCurrentTime){var e=x.getCurrentTime();m!==e&&(m=e,R("timeupdate",e));var t=x.getVideoLoadedFraction;if(void 0!==t&&null!==t){var n=x.getVideoLoadedFraction();A!==n&&(A=n,R("progress"))}}};setInterval(L,250)};e.TSC.youTube=e.TSC.youTube||{},e.TSC.youTube.init=function(t,n,i,a,r,s,u){var c=/v=(.{11})/i,l=c.exec(t),d=l?l[1]:"*";e.onYouTubeIframeAPIReady.ready?e.TSC.youTube.player=new o(d,n,i,a,r,s,u):e.onYouTubeIframeAPIReady.queued.push(function(){e.TSC.youTube.player=new o(d,n,i,a,r,s,u)})},e.TSC.youTube.addApi=function(){var e=t("script[src='"+r+"']").length;return e||t.getScript(r),!e}}(window,jQuery,TSC.playerConfiguration,TSC.deviceInfo,TSC.playedTracker),function(e,t){e.TSC=e.TSC||{},e.TSC.searchTool=function(){function e(e,t){var n=RegExp(t,"ig");return e.replace(n,""+t+"")}function n(t,n){for(var i=[],a=t.items.length,r=n.toLowerCase().split(" "),o=0;a>o;o++){var s="",u=t.items[o],c=r[0];if(!(0>u.toLowerCase().indexOf(c))){for(var l=0;r.length>l;l++)s+=o+l>=a?"":0==l?t.items[o+l]:" "+t.items[o+l];if(-1!=s.toLowerCase().indexOf(n.toLowerCase())){var d;d=4>r.length?Math.floor(5-r.length/2):2;for(var f,p="",g="",h=0;d>h;h++)o-d+h>=0&&(p+=t.items[o-d+h]+" "),a>o+r.length+h&&(g+=" "+t.items[o+r.length+h]);s=e(s,n),f="..."+p+s+g+"...";var m=t.file,v="";void 0!==m&&(v="data-file='"+m+"'"),i.push({text:f,start:t.start,file:t.file,imageRef:void 0,imageRect:void 0})}}}return i}function i(t,n,i){for(var a=[],r=0;t.length>r;r++)if(-1!=t[r].text.toLowerCase().indexOf(n.toLowerCase()))if(i)a.push(t[r]);else{var o={text:e(t[r].text,n),start:t[r].start!==void 0?t[r].start:t[r].time,file:t[r].file,imageRef:t[r].imageRef,imageRect:t[r].imageRect};a.push(o)}return a}function a(e,t){for(var a=[],r=i(e,t,!0),o=r.length,s=0;o>s;s++)a=a.concat(n(r[s],t));return a}function r(e){var n=[];return n=n.concat(i(t.getTocItemArray(),e)),n=n.concat(i(t.getCaptionItemArray(),e)),n=n.concat(i(t.getSpeechTextItemArray(),e)),1>t.getCaptionItemArray().length&&t.getScreenTextItemArray().length>0&&(n=n.concat(a(t.getScreenTextItemArray(),e))),n}return{searchXmpForString:r}}()}(window,TSC.xmp),function(e,t,n,i,a,r,o){"use strict";e.TSC.flashView=e.TSC.flashView||{},e.TSC.flashView=function(){function e(){var e={};e.src=i.getUnicodeSafeString(i.getMediaSrc());var t=location.href.lastIndexOf("/"),n=location.href.substr(0,t+1);return i.getXMPSrc()&&(e.xmp=i.getXMPSrc(),i.isIEOnServerWithUnicode()&&(e.xmp=i.getUnicodeSafeString(n)+e.xmp)),i.getAutoPlayMedia()&&(e.autoPlayJS=i.getAutoPlayMedia()),-1!==i.getAllowRewind()&&(e.allowRewind=i.getAllowRewind()),i.getConfigurationSrc()&&(e.configuration=i.getConfigurationSrc()),e.debugHotspots=i.getDebugHotspot(),i.getPosterImageSrc()&&(e.poster=i.getPosterImageSrc(),i.isIEOnServerWithUnicode()&&(e.poster=i.getUnicodeSafeString(n)+e.poster)),e.authoredLanguage=r.getLanguage(),i.getFathomId()&&(e.fathomId=i.getFathomId(),e.fathomEnvironmentId=o.getEnvironment()),i.getTechSmithAccessToken()&&(e.quizServiceAccessToken=i.getTechSmithAccessToken()),e.quizServiceEnvironmentId=a.getEnvironment(),e.isUserIdentified=i.getIsUserIdentified(),i.getGoogleAnalyticsID()&&""!=i.getGoogleAnalyticsID()&&(e.analytics=i.getGoogleAnalyticsID(),i.getGAEventTracking()||(e.trackEvents=!1),i.getGAPageViewTracking()||(e.trackPageViews=!1)),i.getCustomEventTracking()&&(e.customEventTracking=!0,e.customEventJSCallback=i.getCustomEventCallback().name),e.altEventCategoryAsFilename=i.getAltEventCategoryAsFilename(),e.altLoadTimeAsSeconds=i.getAltLoadTimeAsSeconds(),e.debugUI=i.getDebugUIMode(),e.advancedSeeking=i.getAdvancedSeeking(),e.enforceLinearAssessments=i.getEnforceLinearAssessment(),e.scormComplete=i.getReportScormComplete(),e.hostingPage=i.getUnicodeSafeString(document.location),e.initialSeekTime=i.getScormStartPt(),e}function s(){var e={};return e.quality="high",e.bgcolor="#000000",e.allowscriptaccess="always",e.allowfullscreen="true",e.wmode="direct",e.allowNetworking="all","."!==i.getSwfBase()&&(e.base=i.getSwfBase()),e}function u(a){var r=e(),o=i.getMinFlashPlayerVersion(),u=s(),d={};d.id=l,d.name=l,d.align="middle";var f=i.getUnicodeSafeString(i.getFlashPlayerSwf());if(i.isIEOnServerWithUnicode()){var p=location.href.lastIndexOf("/"),g=location.href.substr(0,p+1);f=i.getUnicodeSafeString(g)+f}n.embedSWF(f,a.replace(/#/,""),i.getPlayerWidth(),i.getPlayerHeight(),o,i.getFlashUpdateBootstrapSwf(),r,u,d),n.createCSS(a,"display:block;text-align:left;"),t(a).show(),c=t("#"+l)[0]}var c,l="tscplayer";return{render:u,jsPlay:function(){if(!c.jsPlay)throw Error("Flash-View: jsPlay was not found");c.jsPlay()},jsDebugUI:function(){if(!c.jsDebugUI)throw Error("Flash-View: jsDebugUI was not found");c.jsDebugUI(!0)}}}()}(this,jQuery,swfobject,TSC.playerConfiguration,TSC.quizService,TSC.localizationStrings,TSC.fathomService),function(e,t,n,i,a,r,o,s,u,c,l,d,f,p,g,h,m,v,A,S,b,C){e.TSC=e.TSC||{},e.TSC.playerView=function(){"use strict";function n(e,t,n){u.getCustomEventTracking()&&u.getCustomEventCallback()&&(u.getAltEventCategoryAsFilename()?u.getCustomEventCallback().call(this,{category:u.getMediaFileName(),action:e,label:t,value:n}):u.getCustomEventCallback().call(this,{category:Zi,action:e,label:t,value:n})),u.getGoogleAnalyticsID()&&_gaq.push(["_trackEvent",Zi,e,t])}function g(){return h&&h.getQuizID()}function T(e){bn&&Pi&&e.keyCode===ea&&(e.originalEvent.preventDefault(),Cn.paused?Cn.play():Cn.pause())}function E(){i.isTouchInterface()||si.bind("keydown",T)}function y(){i.isTouchInterface()||si.unbind("keydown",T)}function I(e,t){t=t.replace(/\)/gi,"\\)"),t=t.replace(/\(/gi,"\\("),e.css("background-image","url("+t+")")}function w(e){I(t("#videoClickToPlayLink, #videoClickToReplayLink"),e)}function N(e){-1!=Si&&t("#tableOfContentsList li:nth-child("+Si+") ").removeClass("selectedTocItem"),Si=e,t("#tableOfContentsList li:nth-child("+Si+") ").addClass("selectedTocItem")}function x(){var e,n,i,a,r,o;0>di||(e=En.width(),n=En.height(),i=di*O(),a=fi*O(),r=Math.max((e-i)/2,0),o=Math.max((n-a)/2,0),ii.css({width:i,height:a,left:r,top:o}),t.each(f.getHotspotItemArray(),function(e,t){var n;l.isPlaylist()&&(n=l.getCurrentMedia().mediaSrc),(void 0===t.file||t.file===n)&&t.jqel.attr("coords",t.pointsToCoords())}))}function R(){t("#searchList").remove(),Jn.show(),Z()}function P(){if(!(void 0===bn||0>=fi)){var e=fi;"under"===f.getCaptionPosition()&&(e=fi*((Tn.height()-wn.height())/(fi+f.getCaptionBarHeight())),En.css("height",e+"px"),Zn.css("height",f.getCaptionBarHeight()*O()+"px"));var t=Math.round(Number(f.getCaptionFontSize())*O());t=f.getMinCaptionFontSize()>t?f.getMinCaptionFontSize():t,t=t>f.getMaxCaptionFontSize()?f.getMaxCaptionFontSize():t,Xn.css("font-size",t)}}function M(){yi=ai.width(),Ii=wn.height(),ai.attr("width",yi+"px"),ai.attr("height",Ii+"px")}function L(){var e=ai[0].getContext("2d");s.drawMarkers(1e3*Cn.duration,e,yi,Ii)}function k(){t("#videoSidebarContentWrapper").css({top:t("#videoSidebarHead").height()+"px"})}function _(){Bi&&k();var e=bn&&Cn;e&&Cn.duration&&g()&&s.quizEnabled()&&(M(),L(),s.viewOpen()&&s.pointViewAt(q(Ei))),f.hasCaptionItems()&&P(),f.hasHotspotItems()&&void 0!==bn&&x()}function O(){var e=1;if(void 0!==bn&&di>0&&bn.width()>0){var t=bn.width()/di,n=bn.height()/fi;e=Math.min(t,n)}return e}function D(){Bi&&!i.supportsFullScreenKeyboardInput()&&t("#videoSidebar").removeClass("search_disabled")}function B(){u.getDisableControls()||wn.show(),i.isTouchInterface()&&Ct(),Pt(),t("#ctoplay").hide(),Jt()}function Q(e){(void 0===e.target.id||""+e.target.id===gn)&&(xi=!xi,xi?(_n.removeClass("fullscreen_enter_button_normal"),_n.addClass("fullscreen_leave_button_normal")):(D(),_n.removeClass("fullscreen_leave_button_normal"),_n.addClass("fullscreen_enter_button_normal"),t("body").css("margin-left","1px"),Mi=!0,_(),t("body").css("margin-left","0"),Mi=!0),_())}function V(){Hi=!0,di=Cn.videoWidth,fi=Cn.videoHeight,i.isIPhoneOrIPod&&oi.css("cursor","pointer"),bn.bind("ratechange",function(){U(),H()},!1),bn.bind("play",function(){U(),H()},!1),pi=0,Xi?B():!g()||g()&&(!s.quizEnabled()||s.getQuizReady())?B():(Cn.pause(),Wt(s.getLastStatusMessage())),d.isEnabled()&&!d.isPercentWatchedInitialized()&&d.initPercentWatched(1e3*Cn.duration),!i.supportsFullScreen()||i.isIPad()||i.isAndroid()?e==e.top||u.getDisableFullframeMode()?_n.remove():(_n.show(),Li=!0):(si.on(i.getFullScreenChangeEventNames(),Q),ki=!0),Mi=!0,f.hasHotspotItems()&&un(),_()}function q(e){var t=qn.offset().left;if(bn&&Cn.duration&&Cn.duration>0){var n=Math.max(0,Math.min(e,Cn.duration)),i=n/Cn.duration;t+=i*qn.width()}return t}function G(){!Pi||0===Cn.duration||g()&&s.quizEnabled()&&!s.getQuizReady()||(pi=Cn?Cn.currentTime>Cn.duration?Cn.duration:Cn.currentTime:0,Ji=Number(Cn.currentTime.toFixed(2))>=Number(Cn.duration.toFixed(2)),gi=1e3*pi,ct(),d.isEnabled()&&J(),!Gi&&g()&&s.quizEnabled()&&W(),f.hasHotspotItems()&&H(),f.hasCaptionItems()&&z(),u.getReportScormComplete()&&1===d.getPercentageWatched()&&(u.setReportScormComplete(!1),t.isFunction(userSubmitVideoCompletedToLMS)&&userSubmitVideoCompletedToLMS()),Gi||-1!==Ti||!Ji||Wi||(Wi=!0,Cn.pause(),At()))}function F(){t.each(f.getHotspotItemArray(),function(e,t){t.hasPausedAtEnd=!1})}function U(){t.each(f.getHotspotItemArray(),function(t,n){n.timer&&e.clearTimeout(n.timer),n.isActive=!1,void 0!=n.jqel&&n.jqel.remove()})}function H(){t.each(f.getHotspotItemArray(),function(t,n){var i;if(l.isPlaylist()&&(i=l.getCurrentMedia().mediaSrc),void 0===n.file||n.file===i)if(pi>n.start&&n.end>=pi){n.isActive===!1&&(n.isActive=!0,n.jqel.appendTo(ii.find("map")));var a=1>=n.end-pi;if(void 0!==n.pause&&n.pause===!0&&!n.hasPausedAtEnd&&a&&!Cn.paused){var r=10/(30*c.getPlaybackRate()),o=(n.end-pi)/c.getPlaybackRate()-r;e.clearTimeout(n.timer),n.timer=setTimeout(function(){Cn.pause(),n.hasPausedAtEnd=!0},1e3*o)}}else n.isActive&&(F(),U())})}function z(){var e,n=!1,i=null;t.each(f.getCaptionItemArray(),function(t,a){e=!0;var r;l.isPlaylist()&&(r=l.getCurrentMedia().mediaSrc),void 0!==a.file&&a.file!==r&&(e=!1),pi>a.start&&a.end>=pi&&e&&(n=!0,a.text!==Xn.text()&&(i=a))}),n?null!==i&&(Zn.removeClass("captionHAlignLeft"),Zn.removeClass("captionHAlignCenter"),Zn.removeClass("captionHAlignRight"),Zn.addClass(i.hAlignClass),Zn.removeClass("captionVAlignTop"),Zn.removeClass("captionVAlignBottom"),Zn.addClass(i.vAlignClass),Xn.html(i.htmlText),vn&&vn.call(i.htmlText)):Xn.html("")}function W(){var e=s.findQuestionSet(gi);if(e.id>=0){if(Ti!==e.id){if(y(),Mt(),kt(!1),Wn&&$(!1),Ti=e.id,Ei=e.markerTime/1e3,Cn.pause(),setTimeout(function(){st(Ei,!0)},100),xi&&!i.supportsFullScreenKeyboardInput()&&cn("#videoWrapper",r.getString("txtQuizFullscreenMode"),!0),s.displayConfirm(e.id),s.pointViewAt(q(Ei)),d.isEnabled()){d.markTimeWatched(e.markerTime);var t=d.getPercentageWatchedForVideoSegment(s.findPrevMarkerTimeForMarker(e.id),e.markerTime);s.updatePercentWatchedForQuestionSet(Ti,t)}_t(!1)}}else Ti=-1}function J(){var e=Math.round(100*d.getPercentageWatched());d.markTimeWatched(gi),"function"==typeof onVideoWatchedPercentage&&onVideoWatchedPercentage(.01*e,d.getCurrentPlayTime()),u.getTrackEvents()&&e>=wi+Ni&&(wi+=Ni,e>wi&&(wi=Ni*Math.floor(e/Ni)+Ni),wi>100&&(wi=100),n("Video_Percent_Viewed","Viewed: "+wi+" Percent"))}function Y(e){e>1?e=1:0>e&&(e=0),Cn.volume=e}function j(e,n,i,a,r,o,s){var u,c,d,p="",g="",h="",m=1,v=0,A=0,S=20,b=65,C=!1;if(void 0!==a&&(h="data-file='"+a+"'"),o){var T=o.split(",");-Number(T[0]),-Number(T[1]);var E=Number(T[2]),y=Number(T[3]);u="hasThumbImage",g="style='height:"+y+"px'",b>y&&(C=!0,g="style='height:"+b+"px'"),f.getTocCellLayoutType()&&"imageOnly"===f.getTocCellLayoutType()&&void 0===s?v=(Ai-E-S)/2:E>Ai/2-S?(m=(Ai/2-S)/E,E=Ai/2-S,A=Math.floor((T[3]-T[3]*m)/2)):A=Math.floor((b-T[3]*m)/2),d={},d.width=Number(Ai-E-40)+"px",d.left=Number(E+5)+"px",d.overflow="hidden",d["line-height"]="1.2em",d["max-height"]="4.8em",c=f.getTocCellLayoutType()&&"imageOnly"===f.getTocCellLayoutType()?"":'
'+n+"
",p="
"+c+"
"}else g="",u="noThumbImage",p=n;var I="
  • ";if(t(e).append(I),r){var w=r.getContext("2d");r.width=Number(T[2])*m,r.height=Number(T[3])*m,w.scale(m,m),Yn?w.drawImage(Yn,T[0],T[1],T[2],T[3],0,0,T[2],T[3]):(w.fillStyle="#000000",w.fillRect(0,0,T[2],T[3])),t(r).css("margin-left",v),t(r).css("margin-top",A),t(e+" li:last-child").append(r)}if(t(e+" li:last-child").append(p),r){t(e+" li:last-child .tocItemLabel").css(d);var x=0,R=b;t(Wn).is(":visible")?(x=t(e+" li:last-child .tocItemLabel").height(),C||(R=t(e+" li:last-child").height())):($(!0),x=t(e+" li:last-child .tocItemLabel").height(),C||(R=t(e+" li:last-child").height()),$(!1));var P=-8;C||1!==m||(P=4);var M=-Number(R+P);M+=(R-x)/2,A=Math.floor((R-T[3]*m)/2),t(r).css("margin-top",A),t(e+" li:last-child .tocItemLabel").css("top",M+"px")}l.isPlaylist()&&N(Si)}function K(e){Yn=new Image,Yn.onload=function(){Z()},Yn.onerror=function(){Yn.onload=void 0,Yn.onerror=void 0,Yn=void 0,Z()},Yn.src=e}function Z(){var e=f.getTocItemArray(),n=e.length;t("#tableOfContentsList li").remove();for(var i=0;n>i;i++)e[i].imageRect&&(e[i].imageRef=document.createElement("canvas")),j("#tableOfContentsList",e[i].text,e[i].time,e[i].file,e[i].imageRef,e[i].imageRect)}function X(){var e,n,i,a=jn.width,r=jn.height,o=.6;a>=r?a>Ai-20?(e=(Ai-20)/a,n=Ai-20,i=r*e):(e=1,n=a,i=r):r>Ai-20?(e=(a*o-20)/r,i=Ai*o-20,n=a*e):(e=1,i=r,n=a);var s='
    ";t(s).prependTo(t("#videoSidebarHead")),t("#videoSidebarHead .video_title").text(f.getTocTitle())}function $(e){e?(Wn.show(),k(),_t(!1)):(Wn.hide(),qi||_t(!0))}function et(e){if(Fi=!1,!i.isTouchInterface()||!Ui){e.stopImmediatePropagation(),e.preventDefault();var n=t(this).attr("data-time"),a=t(this).attr("data-file");if(void 0!==a){U();var r=l.getMediaIndexBySrc(a);r===l.getCurrentMediaIndex()?st(n):(l.setCurrentMedia(r),en()),N(r+1)}else st(n)}}function tt(){$(Qi),Wn.toggleClass("right","right"===u.getSidebarLocation()),u.getIsSearchable()?(Kn.keyup(function(){if(""!=Kn.val()){Jn.hide(),t("#searchList").remove(),t("#videoSidebarContent").append("
      ");for(var e=b.searchXmpForString(Kn.val()),n=0;e.length>n;n++)j("#searchList",e[n].text,e[n].start,e[n].file,e[n].imageRef,e[n].imageRect);t("#searchList").show()}else R()}),kn.click(function(){Kn.val(""),R()})):t("#searchArea").remove(),f.getTocImageSrc()?(jn=new Image,jn.onload=X,jn.src=f.getTocImageSrc()):t("#videoSidebarHead .video_title").text(f.getTocTitle()),f.tocContainsThumbs()?K(f.getTocThumbImageSrc()):Z(),i.isTouchInterface()?(ji="touchend",Ui=!1):t("#videoSidebarContent").on(ji,"li",et)}function nt(e){var t;Gi=!0,Dt(),Cn.paused?t=!1:(t=!0,Cn.pause()),rt(),ut(e.originalEvent.pageX),Mt(),si.bind("pointermove",function(e){e.preventDefault(),ut(e.originalEvent.pageX)}),si.bind("pointerup",function(e){Bt(),Gi=!1,ot(),ut(e.originalEvent.pageX),t&&!Ji&&Cn.play(),si.unbind("pointermove pointerup"),Pt(),G()})}function it(){bn.bind("durationchange",function(){at(),ui&&e.clearInterval(ui),ui=e.setInterval(at,1e3)}),i.isTouchInterface()||qn.bind("pointerdown",nt)}function at(){var t;bn&&Cn&&(Cn.buffered&&Cn.buffered.length&&(t=Math.min(100,Math.ceil(100*Cn.buffered.end(Cn.buffered.length-1)/Cn.duration))),Gn.width((t||0)+"%"),100===t&&ui&&e.clearInterval(ui))}function rt(){document.body.focus(),document.onselectstart=function(){return!1}}function ot(){document.onselectstart=function(){return!0}}function st(e,t){U(),F(),void 0===t&&(t=!1);try{for(var n=!1,i=0;Cn.seekable.length>i;i++){var a=Cn.seekable.start(i),r=Cn.seekable.end(i);e>=a&&r>=e&&(n=!0)}n?_i?hi=e:(Cn.currentTime=e,ct()):t&&setTimeout(function(){st(e,!0)},100)}catch(o){t&&setTimeout(function(){st(e,!0)},100)}}function ut(e){var t=e-qn.offset().left,n=t/qn.width();Fn.width(Math.min(100,Math.max(0,100*n))+"%"),U(),Fi=!1,st(Number(n*Cn.duration)),lt()}function ct(){Fn.width(100*Cn.currentTime/Cn.duration+"%"),lt()}function lt(){Un[0].innerHTML=dt(Cn.currentTime),Cn.duration&&(Hn[0].innerHTML=dt(Cn.duration))}function dt(e){e=Math.round(e);var t=Math.floor(e/60);return t=t>=10?t:"0"+t,e=Math.floor(e%60),e=e>=10?e:"0"+e,t+":"+e}function ft(e,t){var n=100;try{n=void 0==localStorage.getItem("volume")?100:localStorage.getItem("volume")}catch(i){}e.slider({orientation:t,range:"min",min:0,max:100,value:n,slide:function(e,t){$n.removeClass("volume_button_high_normal"),$n.removeClass("volume_button_med_normal"),$n.removeClass("volume_button_low_normal"),$n.removeClass("volume_button_normal"),$n.removeClass("unmute_button_normal"),t.value>70?$n.addClass("volume_button_high_normal"):t.value>30?$n.addClass("volume_button_med_normal"):t.value>0?$n.addClass("volume_button_low_normal"):$n.addClass("unmute_button_normal"),Y(t.value/100);try{localStorage.setItem("volume",t.value)}catch(n){}}});try{Y(void 0==localStorage.getItem("volume")?100:localStorage.getItem("volume")/100)}catch(i){}}function pt(){ni.removeClass(Ki)}function gt(){-1!==vi&&(clearTimeout(vi),vi=-1),ni.unbind("mouseenter"),ni.unbind("mouseleave"),ni.addClass(Ki)}function ht(){U(),Bi&&Qi&&(t(this).removeClass("toc_off_button_normal"),t(this).addClass("toc_button_normal"),$(!1)),In.show()}function mt(e,t){Wi=!1,Fi=!1,In.hide(),Tn.css("visibility","visible"),U(),E(),l.isPlaylist()||st(e),t&&(l.isPlaylist()?(l.setCurrentMedia(0),N(l.getCurrentMediaIndex()+1),en()):Cn.play())}function vt(){document.exitFullscreen?document.exitFullscreen():document.webkitExitFullscreen?document.webkitExitFullscreen():document.msExitFullscreen?document.msExitFullscreen():document.mozCancelFullScreen&&document.mozCancelFullScreen()}function At(){if(Math.floor(Cn.currentTime)0&&(ni.bind("mouseenter",function(){-1!=vi&&(clearTimeout(vi),vi=-1)}),ni.bind("mouseleave",function(){vi=setTimeout(function(){gt(),vi=-1},1e3)}),-1!=vi&&(clearTimeout(vi),vi=-1),vi=setTimeout(function(){gt(),vi=-1},1e3))}),$n.click(function(){var e;Oi=!Oi,Oi?(mi=Cn.volume,e=0,ei.slider("value",[0])):(e=mi,ei.slider("value",[100*mi])),$n.removeClass("volume_button_high_normal"),$n.removeClass("volume_button_med_normal"),$n.removeClass("volume_button_low_normal"),$n.removeClass("volume_button_normal"),$n.removeClass("unmute_button_normal"),e>.7?$n.addClass("volume_button_high_normal"):e>.3?$n.addClass("volume_button_med_normal"):e>0?$n.addClass("volume_button_low_normal"):$n.addClass("unmute_button_normal"),Y(e)}),ti.length>0?(ft(ti,"horizontal"),ni.show()):ft(ei,"vertical"),f.hasCaptionItems()&&("under"===f.getCaptionPosition()?(Di=!0,Zn.css("background",f.getCaptionBg()),Zn.addClass("caption_under_video"),Zn.removeClass("hide"),wn.addClass("caption_under_video"),P()):a(),Bn.bind("click",function(){Di=!Di,a()})),i.isAndroid()?On.hide():Xi?S.player.supportPlaybackRate?r(S.player.validRateSettings):On.hide():r(),_n.click(function(e){if(Li)St();else if(xi)u.getIsSearchable()&&D(),vt();else{var n=document.getElementById(gn);i.supportsFullScreenKeyboardInput()?n.requestFullscreen?n.requestFullscreen(Element.ALLOW_KEYBOARD_INPUT):n.webkitRequestFullscreen?n.webkitRequestFullscreen(Element.ALLOW_KEYBOARD_INPUT):n.msRequestFullscreen?n.msRequestFullscreen(Element.ALLOW_KEYBOARD_INPUT):n.mozRequestFullScreen&&n.mozRequestFullScreen(Element.ALLOW_KEYBOARD_INPUT):(Bi&&u.getIsSearchable()&&t("#videoSidebar").addClass("search_disabled"),n.requestFullscreen?n.requestFullscreen():n.webkitRequestFullscreen?n.webkitRequestFullscreen():n.msRequestFullscreen?n.msRequestFullscreen():n.mozRequestFullScreen&&n.mozRequestFullScreen())}e.preventDefault()}),Bi&&(Dn.click(function(){Qi=!Qi,Qi?(t(this).removeClass("toc_off_button_normal"),t(this).addClass("toc_button_normal")):(t(this).removeClass("toc_button_normal"),t(this).addClass("toc_off_button_normal")),"none"===Wn.css("display")?$(!0):$(!1)}),u.getSidebarEnabled()?(Qi=!0,Dn.removeClass("toc_off_button_normal"),Dn.addClass("toc_button_normal"),$(!0)):(Dn.removeClass("toc_button_normal"),Dn.addClass("toc_off_button_normal"))),i.isIPad()||i.isAndroid()?(t("body").on("blur","textarea",function(){zi=!1,$t()&&C.clear(),Ct(),Ri&&xt()}),t("body").on("focus","textarea",function(e){if(zi=!0,bt(),$t()){var t=e.target;C.watch(t)}Ri&&Nt()}),t("body").on("blur","input:text",function(){zi=!1,$t()&&C.clear(),Ct(),Ri&&xt()}),t("body").on("focus","input:text",function(e){if(zi=!0,bt(),$t()){var t=e.target;C.watch(t)}Ri&&Nt()}),e.parent.onorientationchange=function(){Ri&&(Vi?(t("#searchBox").blur(),setTimeout(Rt,500)):Rt())}):i.isTouchInterface()&&qn.bind("pointerdown",nt),E(),u.getDisableControls()&&Lt()}function It(e){Pt()||kt(!0),mt(e,!0),u.getTrackEvents()&&(u.getAltEventCategoryAsFilename()?n("Video_Replay",Zi):n("Video_Replay",""+l.getCurrentMedia().mediaSrc))}function wt(){It(0)}function Nt(){si.unbind("touchmove"),si.unbind("gesturestart"),t(e.parent).unbind("gesturestart"),si.unbind("gestureend"),t(e.parent).unbind("gestureend")}function xt(){si.bind("touchmove",function(e){t.contains(Jn[0],e.target)||g()&&s.quizEnabled()&&s.viewOpen()||e.preventDefault()}),si.bind("gesturestart",function(e){e.preventDefault()}),t(e.parent).bind("gesturestart",function(e){e.preventDefault()}),si.bind("gestureend",function(){St()}),t(e.parent).bind("gestureend",function(){St()})}function Rt(){_()}function Pt(){return!u.getAutoHideControls()||f.hasCaptionItems()&&"under"===f.getCaptionPosition()?!1:(i.isTouchInterface()?oi.bind("pointerover pointerup",function(){kt(!0)}):(oi.hover(kt,Lt),oi.bind("pointermove",function(){kt(!0)})),Bt(),!0)}function Mt(){Dt(),oi.unbind("pointermove pointerenter pointerleave")}function Lt(){_t(!1),Vi||Gi||c.isOpen()||(qi=!0,wn.stop(!0,!0),wn.fadeOut(li),Qi&&(Wn.stop(!0,!0),Wn.fadeOut(li)),-1!==vi&>(),Xi&&ri.removeClass("hide"))}function kt(e){u.getDisableControls()||(qi&&(qi=!1,wn.stop(!0,!0),wn.fadeIn(li),Qi?(Wn.stop(!0,!0),Wn.fadeIn(li)):_t(!0),e&&ct(),Mi&&(Mi=!1,_())),e&&Bt(),Xi&&ri.addClass("hide"))}function _t(e){i.isNuevoApp()&&(document.location=e?"nuevo://shownavbar":"nuevo://hidenavbar")}function Ot(){if(i.isNuevoApp()){var e=document.location;document.location="nuevo://hasPlayedToEnd?url="+e}}function Dt(){e.clearTimeout(bi)}function Bt(){Dt(),u.getAutoHideControls()&&(bi=e.setTimeout(Lt,Ci))}function Qt(i){i.preventDefault();var a=f.getHotspotItemArray(),r=Number(t(i.target).attr("hotspot_index"));if(void 0!==a[r].jumpFile){var o=l.getMediaIndexBySrc(a[r].jumpFile);l.setCurrentMedia(o),N(l.getCurrentMediaIndex()+1),en()}else if(""!==a[r].jumpTime)Fi=!1,st(Number(a[r].jumpTime)),Cn.play();else if(""!==a[r].targetURL){u.getTrackEvents()&&n("Hotspot_Action",a[r].targetURL);var s="_parent";void 0!==a[r].newWindow&&a[r].newWindow===!0&&(s="_blank"),e.open(a[r].targetURL,s)}else Cn.play()}function Vt(){d.isEnabled()&&(d.setVideoLoadEndTime((new Date).getTime()),u.getTrackEvents()&&(u.getAltEventCategoryAsFilename()?u.getAltLoadTimeAsSeconds()?n("Video_Loading_Time_In_Seconds",Zi,d.getVideoLoadTime()/1e3):n("Video_Loading_Time",Zi,d.getVideoLoadTime()):u.getAltLoadTimeAsSeconds()?n("Video_Loading_Time_In_Seconds",""+l.getCurrentMedia().mediaSrc,d.getVideoLoadTime()/1e3):n("Video_Loading_Time",""+l.getCurrentMedia().mediaSrc,d.getVideoLoadTime()))),Pi=!0}function qt(){_i=!0}function Gt(){_i=!1,hi>-1&&(st(hi),hi=-1)}function Ft(){if(yn.hide(),bn.unbind("playing"),u.getScormStartPt()){var e=u.getScormStartPt();Cn.duration>e&&st(Number(e),!0)}if(u.getJumpToTime()){var t=fn(u.getJumpToTime());Cn.duration>t&&st(Number(t),!0)}u.getDebugUIMode()&&Sn&&Sn.call(this)}function Ut(){f.hasHotspotItems()&&ii.on("click","area",Qt),f.hasCaptionItems()&&(Xn.css({"font-family":f.getCaptionFontFamily(),color:f.getCaptionTextColor(),background:f.getCaptionBg()}),Di=u.getCaptionsEnabled())}function Ht(e,t,n){n||(n=!1);var a="o;o++){var s=u.getUnicodeSafeString(e[o].mediaSrc);a+=''}return a+=u.getUnableToDisplayContentString()+""}function zt(){Wt(na.getString("videoLoading"))}function Wt(e){if(ta.viewOpen())ta.setViewMessage(e);else{var t=ta.getViewMarkup(e);oi.append(t),ta.showView()}}function Jt(){ta.viewOpen()&&ta.removeView()}function Yt(){return Xi?S.player:t("video")[0]}function jt(){g()&&s.quizEnabled()?Kt():Xt()}function Kt(){yn.hide(),s.init(u.getEnforceLinearAssessment(),Yt)}function Zt(e){cn("#tscVideoContent",e.data,!1)}function Xt(){if(mn&&mn.call(),Xi)bn=e.TSC.youTube.player,Cn=e.TSC.youTube.player;else{var n=Ht(l.getCurrentMedia(),!1);t("#videoDiv").html(n),bn=t("video"),bn.length>0&&(Cn=bn[0])}if(bn.bind({loadedmetadata:V,playing:Ft,canplay:Vt,seeking:qt,seeked:Gt,timeupdate:G,progress:at}),Tn.removeClass("hide"),Ut(),yt(),Bi&&tt(),g()&&s.quizEnabled()){var i=t("
      ",{"class":"quizMarker"});oi.append(i),v.setSize(i.width()),v.setColor(i.css("color")),i.remove(),ai.show()}Mi=!0,_(),wn.hide(),$t()&&C.setOnBugCallback(function(e){1===e&&cn("#videoWrapper","For the best experience, avoid tapping the video while inputting text.",!0)}),en()}function $t(){return i.isIPad()&&8>i.getIOSMajorVersion()&&Xi&&(Bi||g()&&s.quizEnabled()&&h.quizContainsTextInputQuestions())}function en(){Wi=!1,Fi=!1,l.isPlaylist()&&(l.onFirstMedia()?(Mn.removeClass("previous_button_normal"),Mn.addClass("previous_button_disabled")):(Mn.addClass("previous_button_normal"),Mn.removeClass("previous_button_disabled")),l.onLastMedia()?(Ln.removeClass("next_button_normal"),Ln.addClass("next_button_disabled")):(Ln.addClass("next_button_normal"),Ln.removeClass("next_button_disabled")),d.isEnabled()&&(d.clearPercentWatched(),wi=0),Cn.src=l.getCurrentMedia().mediaSrc),i.isIPad()||i.isAndroid()?Cn.play():(Cn.load(),Cn.play()),d.isEnabled()&&d.setVideoLoadStartTime((new Date).getTime()),u.getTrackEvents()&&Yi&&(Yi=!1,u.getAltEventCategoryAsFilename()?n("Video_Started",Zi):n("Video_Started",""+l.getCurrentMedia().mediaSrc),n("Video_Percent_Viewed","Viewed: 0 Percent"))}function tn(e){switch(e.type){case"COMPLETE":case"REVIEW":if(Wn&&Qi?$(!0):_t(!0),E(),Pt(),L(),"REVIEW"===e.type&&u.getEnforceLinearAssessment()){var t=s.findPrevMarkerTimeForMarker(Ti);Ti=-1,st(t/1e3),Cn.play()}else Cn.play();break;case"BEGIN":case"SKIP":s.setViewContainer("#videoWrapper"),yn.unbind("click",an),bn?Hi&&s.getQuizReady()&&(B(),Cn.play(),Mi=!0,_()):Xt(),s.startTrackingProgress();break;case"ERROR":bn||Xt(),cn("#videoWrapper",r.getString("txtErrorMessage"),!0);break;case"STATUS":Wt(e.message);break;case"SUBMITTED":Jt()}}function nn(n,a){oi=t(n),pn=n,gn=pn.replace(/^[#]/,""),Bi=a,$i=i.requiresManualPreload()&&Xi,oi.html(ia),wn=t("#controls"),Nn=wn.find(".controls_left"),xn=wn.find(".controls_right"),Rn=t("#rewind"),Pn=t("#play"),Mn=t("#previous"),Ln=t("#next"),$n=t("#volume"),Bn=t("#closedCaptionButton"),Dn=t("#tocButton"),On=t("#settingsButton"),_n=t("#fullscreen_enter_button"),ei=t("#volume_slider_vertical"),ti=t("#volume_slider_horizontal"),ni=t("#volume_slider_container"),Qn=t("#progress"),Vn=t("#progress_box"),Gn=t("#load_progress"),Fn=t("#play_progress"),qn=t("#progress_scrubbar_track"),Un=t("#current_time_display"),Hn=t("#duration_display"),zn=t("#scrubbar_scrubber"),Wn=t("#videoSidebar"),Jn=t("#tableOfContentsList"),Kn=t("#searchBox"),kn=t("#clearSearchButton"),Zn=t("#caption"),Xn=t("#caption > p"),ii=t("#hotspots"),ai=t("#markers"),Tn=t("#videoWrapper"),En=t("#videoDiv"),yn=t("#videoClickToPlayLink"),In=t("#videoClickToReplayLink"),ri=t("#youtubePointerEventWorkaround"),si=t(document),$i&&yn.addClass("noClickToPlayEvents"),oi.css("background-color",u.getBackgroundColor()),u.getPosterImageSrc()&&w(u.getPosterImageSrc()),oi.fadeIn(li),In.fadeIn(li),In.hide(),(i.isIPad()||i.isAndroid())&&($n.hide(),_n.hide(),$n.remove()),Bi&&Dn.removeClass(Ki),f.hasCaptionItems()&&("under"===f.getCaptionPosition()?u.setAutoHideControls(!1):Bn.removeClass(Ki)),l.isPlaylist()?(Mn.removeClass(Ki),Ln.removeClass(Ki)):(Mn.addClass(Ki),Ln.addClass(Ki)),_(),t(e).resize(function(){Mi=!0,_() +}),Kn.focus(function(){Vi=!0,Kn.val()==na.getString("search")&&Kn.val(""),y(),Dt()}),Kn.blur(function(){Vi=!1,""===Kn.val().replace(/ /g,"")&&Kn.val(na.getString("search")),E(),Bt()})}function an(e){e.preventDefault(),hn&&hn(),g()&&s.quizEnabled()?Kt():Xt()}function rn(){TSC.playerView.displayMessagePanel("#tsc_overlay",TSC.localizationStrings.getString("txtQuizErrorMessage"),!1)}function on(){t("#alertDialog").hide()}function sn(){Kn.val(na.getString("search"));var e=i.isIPad()&&!i.isNuevoApp();if((e||i.isAndroid()||g()&&s.quizEnabled())&&!u.getMobileWebViewCanAutoPlay()&&u.setAutoPlayMedia(!1),u.getAutoPlayMedia()===!0&&void 0===u.getJumpToTime()?(hn&&hn(),setTimeout(Xt,80)):yn.bind("click",an),g()&&s.quizEnabled()){s.setViewContainer(pn);var t;t=u.getFathomId()?p:m,s.setQuestionGrader(t),s.setQuestionData(h),s.setViewControlBarOffset(wn.height()),s.addEventListener("COMPLETE",tn),s.addEventListener("REVIEW",tn),s.addEventListener("BEGIN",tn),s.addEventListener("SKIP",tn),s.addEventListener("ERROR",tn),s.addEventListener("STATUS",tn),s.addEventListener("SUBMITTED",tn),s.addEventListener("SHOW_LOADING_MESSAGE",zt),s.addEventListener("HIDE_LOADING_MESSAGE",Jt),s.addEventListener("SHOW_SUBMISSION_RETRY_MESSAGE",rn),s.addEventListener("HIDE_SUBMISSION_RETRY_MESSAGE",on),void 0!==u.getJumpToTime()&&setTimeout(Kt,80)}else void 0!==u.getJumpToTime()&&setTimeout(Xt,80);(u.getTrackEvents()||u.getReportScormComplete()||g()&&s.quizEnabled())&&(d.setEnabled(!0),f.xmpAvailable()&&d.initPercentWatched(f.getMediaDuration())),ci=!0,u.getDebugUIMode()&&An&&An.call(this)}function un(){ii.removeClass(Ki),ii.find("map").empty(),t.each(f.getHotspotItemArray(),function(e,n){var i;if(l.isPlaylist()&&(i=l.getCurrentMedia().mediaSrc),void 0===n.file||n.file===i){n.viewpoints=[];for(var e=0;n.points.length>e;e+=2){var a={xorig:Math.round(n.points[e]),yorig:Math.round(n.points[e+1]),xscale:Math.round(n.points[e])/di,yscale:Math.round(n.points[e+1])/fi};n.viewpoints.push(a)}n.pointsToCoords=function(){for(var e=[],t=0;this.viewpoints.length>t;t++)e.push(this.viewpoints[t].xorig>=0?Math.round(this.viewpoints[t].xscale*ii.width()):0),e.push(this.viewpoints[t].yorig>=0?Math.round(this.viewpoints[t].yscale*ii.height()):0);return e.join(",")},n.jqel=t("",{shape:"poly",coords:n.pointsToCoords(),hotspot_index:n.index,alt:"Hotspot",href:"#"})}})}function cn(e,n,i){n=""+n+"",i&&(n+="

      "+na.getString("clickToClose")+"

      "),ci?(t("#alertDialog").html(n),t("#alertDialog").fadeIn(li)):(t(e).css("background-color",u.getBackgroundColor()),t(e).css("height","100%"),t(e).html('
      '+n+"
      "),t(e).fadeIn(li),t("#alertDialog").show()),i&&t("#alertDialog").bind("click",function(){on(),t("#alertDialog").unbind("click")})}function ln(){var e="#000";u.getPosterImageSrc()&&(e+=" url("+u.getPosterImageSrc()+") center no-repeat"),t(".appplayer").css({background:e,position:"relative","background-size":"cover",height:"100%","z-index":"1"})}function dn(e){var n,a=t(e);if(TSC.mediaPlayer.isNuevoAppCapableAndAvailable()&&(f.hasAdvancedFeatures()||u.getFathomId())){n=u.getUseSlimAppSplashScreen()?o.ios_app_slim_splash_template({openWithSmartPlayer:na.getString("openWithSmartPlayer")}):o.ios_app_splash_template({playWithSmartPlayer:na.getString("playWithSmartPlayer"),playVideoOnly:na.getString("playVideoOnly")}),a.after(n),ln();var r=t(".appplayer");r.show(),a.hide(),u.getUseSlimAppSplashScreen()?t(".openVideoSmartPlayerContainer").click(function(){TSC.mediaPlayer.redirectToiPhoneApp()}):(t(".externalLargePlayBtn").click(function(){r.hide(),a.show(),TSC.mediaPlayer.redirectToiPhoneApp()}),t(".appNativePlayBtn").click(function(){r.hide(),a.show(),bn=t("video"),Cn.play()}),t(".appstoreBtn").click(function(){TSC.mediaPlayer.redirectToiPhoneAppDownload()}))}else if(i.isIPhoneOrIPod()){n=o.ios_app_default_template(),a.after(n);var s=t(".externalDefaultPlaybackContainer");u.getPosterImageSrc()&&(I(s,u.getPosterImageSrc()),s.addClass("fullSizePosterImgContainer")),s.show(),a.hide(),s.click(function(e){e.preventDefault(),a.show(),bn=t("video"),Cn.play(),setTimeout(function(){a.hide()},1e3)})}}function fn(e){if(isNaN(e)){var t=0,n=0,i=0,a=e.toLowerCase(),r=RegExp("(\\d+[h])","g"),o=RegExp("(\\d+[m])","g"),s=RegExp("(\\d+[s])","g"),u=RegExp("\\d+","g"),c=a.match(r),l=a.match(o),d=a.match(s),f=a.match(u);return d||l||c?(c&&(t=60*60*Number(c[0].split("h").join(""))),l&&(n=60*Number(l[0].split("m").join(""))),d&&(i=Number(d[0].split("s").join(""))),Number(t+n+i)):f?i=Number(f[0]):0}return 0>e&&(e=0),e}var pn,gn,hn,mn,vn,An,Sn,bn,Cn,Tn,En,yn,In,wn,Nn,xn,Rn,Pn,Mn,Ln,kn,_n,On,Dn,Bn,Qn,Vn,qn,Gn,Fn,Un,Hn,zn,Wn,Jn,Yn,jn,Kn,Zn,Xn,$n,ei,ti,ni,ii,ai,ri,oi,si,ui,ci=!1,li=300,di=-1,fi=-1,pi=0,gi=0,hi=-1,mi=1,vi=-1,Ai=250,Si=1,bi=-1,Ci=5e3,Ti=-1,Ei=-1,yi=0,Ii=0,wi=0,Ni=10,xi=!1,Ri=!1,Pi=!1,Mi=!1,Li=!1,ki=!1,_i=!1,Oi=!1,Di=!1,Bi=!1,Qi=!1,Vi=!1,qi=!1,Gi=!1,Fi=!1,Ui=!1,Hi=!1,zi=!1,Wi=!1,Ji=!1,Yi=!0,ji="click",Ki="hide",Zi="HTML5-Video",Xi=!1,$i=!1,ea=32,ta=a,na=r,ia=o.html5_player_template({msgSearch:na.getString("search"),msgSearchIsDisabledInFS:na.getString("searchDisabledFullScreen"),accessBtnClearSearch:na.getString("accessBtnClearSearch"),accessBtnRewind:na.getString("accessBtnRewind"),accessBtnPlay:na.getString("accessBtnPlay"),accessBtnPrevious:na.getString("accessBtnPrevious"),accessBtnNext:na.getString("accessBtnNext"),accessBtnVolume:na.getString("accessBtnVolume"),accessBtnClosedCaption:na.getString("accessBtnClosedCaption"),accessBtnTableOfContents:na.getString("accessBtnTableOfContents"),accessBtnSettings:na.getString("accessBtnSettings"),accessBtnFullScreen:na.getString("accessBtnFullScreen")});return{initHtml5View:function(e,t){nn(e,t),sn()},initSimpleHtml5View:function(n){if(l.isPlaylist()){for(var a=t(e).innerWidth()-20,r=l.getMediaList(),o=r.length,s="
        ",u="style='width: "+a+"px; height: 75px;'",c=0;o>c;c++)s+="
      1. "+Ht([r[c]],!0,!0)+"
      2. ";s+="
      ",t(n).html(s),t(n).css("background-color","#ffffff"),t("body").css("overflow","auto"),t(n).css("overflow","auto"),t(n+" ol").css("list-style","none"),t(n+" ol").css("margin","10px"),t(n+" ol").css("padding","0")}else t(n).html(Ht(l.getCurrentMedia(),!i.isIPhoneOrIPod(),!0));dn(n)},initYouTubeView:function(e,n,i){Xi=!0,nn(e,n);var a=t(e);S.init(i,"videoDiv",sn,jt,Zt,a.attr("width"),a.attr("height"))},jsSeekTime:function(e){if(ci)if(bn)Cn.duration&&Cn.duration>e&&(Ji?It(e):(!g()||g()&&!s.viewOpen())&&st(e,!0));else{var t={};t.t=e,u.setURLParams(t),g()&&s.quizEnabled()?s.viewOpen()||setTimeout(Kt,80):setTimeout(Xt,80)}},jsPlay:function(){ci&&(bn?Ji?It(0):Cn.play():g()&&s.quizEnabled()?s.viewOpen()||setTimeout(Kt,80):setTimeout(Xt,80))},displayMessagePanel:function(e,t,n){void 0===n&&(n=!0),cn(e,t,n)},addEventListener:function(e,t){switch(e){case"VIDEO_START_INITIATED":hn=t;break;case"VIDEO_START":mn=t;break;case"CAPTION_CHANGE":vn=t;break;case"READY":An=t;break;case"VIDEO_PLAY":Sn=t}},removeEventListener:function(e){switch(e){case"VIDEO_START_INITIATED":hn=void 0;break;case"VIDEO_START":mn=void 0;break;case"CAPTION_CHANGE":vn=void 0;break;case"READY":An=void 0;break;case"VIDEO_PLAY":Sn=void 0}}}}()}(this,jQuery,TSC.externalMessageController,TSC.deviceInfo,TSC.ioOverlayView,TSC.localizationStrings,TSC.templates,TSC.quizController,TSC.playerConfiguration,TSC.playerSettingsView,TSC.mediaList,TSC.videoAnalytics,TSC.xmp,TSC.fathomGrader,TSC.fathomService,TSC.quizModel,TSC.xmpGrader,TSC.quizMarker,TSC.iFrameBridge,TSC.youTube,TSC.searchTool,TSC.iOSTextInputFix),function(e,t,n,i,a){"use strict";e.TSC=e.TSC||{},e.TSC.imageView=function(){function e(e){l.css("background-image","url("+e+")"),o("Imaged_Loaded",e)}function r(e){s=e,u=t(s),u.html(f),u.fadeIn(d),u.css("background-color",a.getBackgroundColor()),c=t("#image"),l=t("#imageDiv")}function o(e,t,n){a.getCustomEventTracking()&&a.getCustomEventCallback()&&(a.getAltEventCategoryAsFilename()?a.getCustomEventCallback().call(this,{category:a.getMediaFileName(),action:e,label:t,value:n}):a.getCustomEventCallback().call(this,{category:p,action:e,label:t,value:n})),a.getGoogleAnalyticsID()&&_gaq.push(["_trackEvent",p,e,t])}var s,u,c,l,d=300,f=i.image_view_template(),p="Loaded Content";return{initView:function(t){r(t);var i=n.getCurrentMedia()[0].mediaSrc;e(i)}}}()}(this,jQuery,TSC.mediaList,TSC.templates,TSC.playerConfiguration);var _gaq=_gaq||[];(function(e,t,n,i,a,r,o,s,u,c,l,d,f,p,g,h,m,v,A,S,b){e.TSC=e.TSC||{},e.TSC.mediaPlayer=function(){"use strict";function C(){c.getMediaType()!==u.WEBM&&n.hasFlashPlayerVersion(s.getMinFlashPlayerVersion())?m.render(F):v.displayMessagePanel(F,c.getErrorMessage())}function T(){a.isLocal()?v.displayMessagePanel(F,g.getLocalErrorMessage()):v.displayMessagePanel(F,g.get404ErrorMessage())}function E(){_gaq.push(["_setAccount",s.getGoogleAnalyticsID()]),s.getGAPageViewTracking()&&_gaq.push(["_trackPageview",s.getMediaFileName()]),function(){var e=document.createElement("script");e.type="text/javascript",e.async=!0,e.src=("https:"==document.location.protocol?"https://ssl":"http://www")+".google-analytics.com/ga.js";var t=document.getElementsByTagName("script")[0];t.parentNode.insertBefore(e,t)}()}function y(){if(a.isNuevoApp()){var e=document.querySelector("meta[name=viewport]");e&&e.setAttribute("content","width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=0;")}}function I(){N()}function w(){a.lookAtDevice(),y(),r.strip(),!a.isNuevoApp()&&s.getPreRollSrc()?S.createView(s.getPreRollSrc(),I):V()||N()}function N(){c.addEventListener("READY",M),c.addEventListener("ERROR",C),c.init(s.getMediaSources())}function x(){if(a.isNuevoApp()&&g.xmpAvailable()){var e=document.location,t=g.getTocTitle(),n=g.getMediaDuration();document.location="nuevo://info?url="+e+"?title="+t+"?duration="+n}}function R(){v.removeEventListener("VIDEO_START_INITIATED",R),S&&S.viewExists()&&S.destroyView()}function P(){Y||(v.removeEventListener("VIDEO_START"),t(document).trigger("techsmith.cloud.videofirstclickplay"),Y=!0)}function M(){c.removeEventListener("READY",M),c.removeEventListener("ERROR",C);var e=d.getPlayerType();switch(e){case l.YOUTUBE:A.addApi(),L();break;case l.HTML5_VIDEO:L();break;case l.FLASH_VIDEO:m.render(F);break;case l.IMAGE:k(),b.initView(F);break;case l.NOT_SUPPORTED:c.getMediaType()===u.WEBM?v.displayMessagePanel(F,i.getString("noWebMSupport")):v.displayMessagePanel(F,i.getString("videoNotSupportedUseFlash"))}}function L(){s.getGoogleAnalyticsID()&&E(),O()}function k(){s.getGoogleAnalyticsID()&&E()}function _(e){s.getFathomId()?(h.addEventListener("GET_COMPLETE",function(){B(),"function"==typeof e&&e()}),h.addEventListener("ERROR",function(){B(),T()}),h.getFathom(s.getFathomId())):B()}function O(){s.getXMPSrc()?(g.addEventListener("READY",_),g.addEventListener("ERROR",function(){"string"==typeof TSC.embedded_config_xml?g.parseXMP(TSC.embedded_config_xml):(_(),T())}),g.loadXMP(s.getXMPSrc())):_()}function D(t){e.top!==e&&o.postMessage("CAPTION-CHANGED","*",t)}function B(){var t=!1,n=!1;if(g.xmpAvailable()&&(g.removeEventListener("READY",B),g.removeEventListener("ERROR",T)),a.isIPhoneOrIPod()&&!a.isNuevoApp())v.initSimpleHtml5View(F);else{if(g.xmpAvailable()&&((g.hasTocItems()||(g.hasCaptionItems()||g.hasScreenTextItems()||g.hasSpeechTextItems())&&s.getIsSearchable())&&(t=!0),g.hasCaptionItems()&&e.top!==e&&o.postMessage("HAS-CAPTIONS","*"),x()),p&&p.getQuizID()&&(a.isLocal()&&p.getReportMethod()!==f.NONE?(n=!0,p.setReportMethod(f.NONE)):p.getUseScorm()&&0===p.getTotalNumberOfGradedQuestionSets()&&s.setReportScormComplete(!0)),v.addEventListener("VIDEO_START_INITIATED",R),v.addEventListener("VIDEO_START",P),v.addEventListener("CAPTION_CHANGE",D),d.getPlayerType()===TSC.playerType.YOUTUBE){var r;r=c.isPlaylist()?c.getCurrentMedia().mediaSrc:c.getCurrentMedia()[0].mediaSrc,v.initYouTubeView(F,t,r)}else v.initHtml5View(F,t);n&&v.displayMessagePanel(F,i.getString("xmpSecurity"))}}function Q(e){var t=document.createElement("script");t.setAttribute("type","text/javascript"),t.setAttribute("src",e),t.async=!0,t.onload=function(){N()},t.onerror=function(){N()},t!==void 0&&document.getElementsByTagName("head")[0].appendChild(t)}function V(){return G()?(Q(H+z),!0):!1}function q(){return"true"===W}function G(){return a.isIPhoneOrIPod()&&a.isRetinaDisplay()&&!a.isNuevoApp()?!0:!1}var F,U="3.19.2",H="http://www.techsmith.com/redirect.asp?",z="target=nuevoappdata&product=camtasia&lang=enu&ver=1.0.0&os=mac",W="false",J="",Y=!1;return{init:function(e){F=e,w()},getVersion:function(){return U},keyValueDataCallback:function(e){W=e.isAppReady,J=e.appDownloadURL},isNuevoAppCapableAndAvailable:function(){return G()&&q()},redirectToiPhoneAppDownload:function(){G()&&e.open(J,"_parent")},jsSeekTime:function(e){d.getPlayerType()===l.FLASH_VIDEO?m.jsSeekTime(e):v.jsSeekTime(e)},jsPlay:function(){d.getPlayerType()===l.FLASH_VIDEO?m.jsPlay():v.jsPlay()},jsDebugUI:function(e){return d.getPlayerType()!==l.FLASH_VIDEO?"HTML5_VIDEO player does not support this method.":(s.setDebugUIMode(e),v.jsDebugUI(e),void 0)},redirectToiPhoneApp:function(){if(G()&&q()){var t=document.location+"",n=s.getPosterImageSrc(),i=(new Date).getTime();setTimeout(function(){var t=(new Date).getTime();1e3>t-i&&e.open(J,"_parent")},300);var a="nuevo://import?url=";a+=-1!==t.indexOf("?")?t+"&posterImage="+n:t+"?posterImage="+n,a+=s.getAdditionalAppQueryString(),e.open(a,"_parent")}},addEventListener:function(e,t){v.addEventListener(e,t)},removeEventListener:function(e){v.removeEventListener(e)}}}()})(this,jQuery,swfobject,TSC.localizationStrings,TSC.deviceInfo,TSC.queryParamsStripper,TSC.iFrameBridge,TSC.playerConfiguration,TSC.mediaType,TSC.mediaList,TSC.playerType,TSC.mediaPlayerController,TSC.reportType,TSC.quizModel,TSC.xmp,TSC.fathomService,TSC.flashView,TSC.playerView,TSC.youTube,TSC.preRollController,TSC.imageView); \ No newline at end of file diff --git a/junctions/skins/overlay/spritesheet.min.css b/junctions/skins/overlay/spritesheet.min.css new file mode 100644 index 0000000..936b7b9 --- /dev/null +++ b/junctions/skins/overlay/spritesheet.min.css @@ -0,0 +1 @@ +.spritesheet{display:inline-block;overflow:hidden;background-repeat:no-repeat;background-image:url(spritesheet.png)}.sprite_repeat{background-repeat:repeat-x!important}.rewind_button_normal{width:43px;height:43px;background-position:-192px -226px}.rewind_button_over{width:43px;height:43px;background-position:-240px -226px}.rewind_button_down{width:43px;height:43px;background-position:-144px -288px}.rewind_button_disabled{width:43px;height:43px;background-position:-192px -226px}.play_button_normal{width:43px;height:43px;background-position:-144px -0px}.play_button_over{width:43px;height:43px;background-position:-144px -48px}.play_button_down{width:43px;height:43px;background-position:-96px -288px}.play_button_disabled{width:43px;height:43px;background-position:-144px -0px}.pause_button_normal{width:43px;height:43px;background-position:-96px -192px}.pause_button_over{width:43px;height:43px;background-position:-96px -240px}.pause_button_down{width:43px;height:43px;background-position:-96px -144px}.pause_button_disabled{width:43px;height:43px;background-position:-96px -192px}.previous_button_normal{width:43px;height:43px;background-position:-144px -192px}.previous_button_over{width:43px;height:43px;background-position:-144px -240px}.previous_button_down{width:43px;height:43px;background-position:-144px -144px}.previous_button_disabled{width:43px;height:43px;background-position:-144px -96px}.next_button_normal{width:43px;height:43px;background-position:-96px -48px}.next_button_over{width:43px;height:43px;background-position:-96px -96px}.next_button_down{width:43px;height:43px;background-position:-96px -0px}.next_button_disabled{width:43px;height:43px;background-position:-48px -288px}.settings_button_normal{width:43px;height:43px;background-position:-380px -0px}.settings_button_over{width:43px;height:43px;background-position:-428px -0px}.settings_button_down{width:43px;height:43px;background-position:-332px -0px}.settings_button_disabled{width:43px;height:43px;background-position:-380px -0px}.settings_off_button_normal{width:43px;height:43px;background-position:-476px -0px}.settings_off_button_over{width:43px;height:43px;background-position:-476px -0px}.settings_off_button_down{width:43px;height:43px;background-position:-476px -0px}.settings_off_button_disabled{width:43px;height:43px;background-position:-476px -0px}.closed_caption_button_normal{width:43px;height:43px;background-position:-0px -48px}.closed_caption_button_over{width:43px;height:43px;background-position:-0px -96px}.closed_caption_button_down{width:43px;height:43px;background-position:-0px -0px}.closed_caption_button_disabled{width:43px;height:43px;background-position:-0px -48px}.closed_caption_off_button_normal{width:43px;height:43px;background-position:-0px -144px}.closed_caption_off_button_over{width:43px;height:43px;background-position:-0px -144px}.closed_caption_off_button_down{width:43px;height:43px;background-position:-0px -144px}.closed_caption_off_button_disabled{width:43px;height:43px;background-position:-0px -144px}.toc_button_normal{width:43px;height:43px;background-position:-353px -48px}.toc_button_over{width:43px;height:43px;background-position:-401px -48px}.toc_button_down{width:43px;height:43px;background-position:-305px -48px}.toc_button_disabled{width:43px;height:43px;background-position:-353px -48px}.toc_off_button_normal{width:43px;height:43px;background-position:-449px -48px}.toc_off_button_over{width:43px;height:43px;background-position:-449px -48px}.toc_off_button_down{width:43px;height:43px;background-position:-449px -48px}.toc_off_button_disabled{width:43px;height:43px;background-position:-449px -48px}.fullscreen_enter_button_normal{width:43px;height:43px;background-position:-48px -48px}.fullscreen_enter_button_over{width:43px;height:43px;background-position:-48px -96px}.fullscreen_enter_button_down{width:43px;height:43px;background-position:-48px -0px}.fullscreen_enter_button_disabled{width:43px;height:43px;background-position:-48px -48px}.fullscreen_leave_button_normal{width:43px;height:43px;background-position:-48px -192px}.fullscreen_leave_button_over{width:43px;height:43px;background-position:-48px -240px}.fullscreen_leave_button_down{width:43px;height:43px;background-position:-48px -144px}.fullscreen_leave_button_disabled{width:43px;height:43px;background-position:-48px -192px}.fullframe_enter_button_normal{width:43px;height:43px;background-position:-0px -240px}.fullframe_enter_button_over{width:43px;height:43px;background-position:-0px -240px}.fullframe_enter_button_down{width:43px;height:43px;background-position:-0px -240px}.fullframe_enter_button_disabled{width:43px;height:43px;background-position:-0px -240px}.fullframe_leave_button_normal{width:43px;height:43px;background-position:-0px -288px}.fullframe_leave_button_over{width:43px;height:43px;background-position:-0px -288px}.fullframe_leave_button_down{width:43px;height:43px;background-position:-0px -288px}.fullframe_leave_button_disabled{width:43px;height:43px;background-position:-0px -288px}.play_button_overlay_normal{width:108px;height:108px;background-position:-192px -0px}.play_button_overlay_over{width:108px;height:108px;background-position:-192px -0px}.play_button_overlay_down{width:108px;height:108px;background-position:-192px -0px}.play_button_overlay_disabled{width:108px;height:108px;background-position:-192px -0px}.replay_button_overlay_normal{width:108px;height:108px;background-position:-192px -113px}.replay_button_overlay_over{width:108px;height:108px;background-position:-192px -113px}.replay_button_overlay_down{width:108px;height:108px;background-position:-192px -113px}.replay_button_overlay_disabled{width:108px;height:108px;background-position:-192px -113px}.scroll_down_arrow_normal{width:16px;height:16px;background-position:-14px -213px}.scroll_down_arrow_over{width:16px;height:16px;background-position:-192px -274px}.scroll_down_arrow_down{width:16px;height:16px;background-position:-14px -213px}.scroll_down_arrow_disabled{width:16px;height:16px;background-position:-14px -213px}.scroll_up_arrow_normal{width:16px;height:16px;background-position:-232px -313px}.scroll_up_arrow_over{width:16px;height:16px;background-position:-253px -292px}.scroll_up_arrow_down{width:16px;height:16px;background-position:-232px -292px}.scroll_up_arrow_disabled{width:16px;height:16px;background-position:-232px -313px}.scroll_thumb_bottom_normal{width:14px;height:50px;background-position:-192px -295px}.scroll_thumb_bottom_over{width:14px;height:50px;background-position:-192px -295px}.scroll_thumb_bottom_down{width:14px;height:50px;background-position:-192px -295px}.scroll_thumb_bottom_disabled{width:14px;height:50px;background-position:-192px -295px}.scroll_track_normal{width:15px;height:13px;background-position:-232px -274px}.scroll_track_over{width:16px;height:4px;background-position:-69px -336px}.scroll_track_down{width:16px;height:4px;background-position:-48px -336px}.scroll_track_disabled{width:15px;height:13px;background-position:-232px -274px}.scrubbar_scrubber_normal{width:10px;height:43px;background-position:-305px -0px}.scrubbar_scrubber_over{width:10px;height:43px;background-position:-305px -0px}.scrubbar_scrubber_down{width:10px;height:43px;background-position:-305px -0px}.scrubbar_scrubber_disabled{width:10px;height:43px;background-position:-305px -0px}.unmute_button_normal{width:43px;height:43px;background-position:-545px -48px}.unmute_button_over{width:43px;height:43px;background-position:-305px -96px}.unmute_button_down{width:43px;height:43px;background-position:-497px -48px}.unmute_button_disabled{width:43px;height:43px;background-position:-545px -48px}.volume_button_normal{width:43px;height:43px;background-position:-353px -192px}.volume_button_over{width:43px;height:43px;background-position:-353px -240px}.volume_button_down{width:43px;height:43px;background-position:-305px -144px}.volume_button_disabled{width:43px;height:43px;background-position:-353px -192px}.volume_button_low_normal{width:43px;height:43px;background-position:-401px -96px}.volume_button_low_over{width:43px;height:43px;background-position:-449px -96px}.volume_button_low_down{width:43px;height:43px;background-position:-353px -96px}.volume_button_low_disabled{width:43px;height:43px;background-position:-401px -96px}.volume_button_med_normal{width:43px;height:43px;background-position:-545px -96px}.volume_button_med_over{width:43px;height:43px;background-position:-353px -144px}.volume_button_med_down{width:43px;height:43px;background-position:-497px -96px}.volume_button_med_disabled{width:43px;height:43px;background-position:-545px -96px}.volume_button_high_normal{width:43px;height:43px;background-position:-305px -240px}.volume_button_high_over{width:43px;height:43px;background-position:-305px -288px}.volume_button_high_down{width:43px;height:43px;background-position:-305px -192px}.volume_button_high_disabled{width:43px;height:43px;background-position:-305px -240px}.volumebar_slider_normal{width:13px;height:9px;background-position:-96px -336px}.volumebar_slider_over{width:13px;height:9px;background-position:-96px -336px}.volumebar_slider_down{width:13px;height:9px;background-position:-96px -336px}.volumebar_slider_disabled{width:13px;height:9px;background-position:-96px -336px}.scrubbar_loaded_track_end{width:2px;height:43px;background-position:-288px -226px}.scrubbar_track_left{width:1px;height:43px;background-position:-295px -226px}.scrubbar_track_right{width:1px;height:43px;background-position:-320px -0px}.scrubbar_track{width:2px;height:43px;background-position:-0px -479px}.scrubbar_loaded_track{width:2px;height:43px;background-position:-0px -393px}.scrubbar_played_track{width:2px;height:43px;background-position:-0px -436px}.seperator{width:1px;height:43px;background-position:-326px -0px}.volumebar_track{width:5px;height:2px;background-position:-35px -192px}.volumebar_track_end{width:5px;height:2px;background-position:-35px -199px}.volumebar_backdrop{width:31px;height:97px;background-position:-401px -144px}.control_backdrop_left{width:2px;height:43px;background-position:-0px -192px}.control_backdrop_right{width:2px;height:43px;background-position:-7px -192px}.toc_title_backdrop{width:8px;height:18px;background-position:-0px -522px}.control_backdrop{width:2px;height:43px;background-position:-0px -350px} \ No newline at end of file diff --git a/junctions/skins/overlay/spritesheet.png b/junctions/skins/overlay/spritesheet.png new file mode 100644 index 0000000..fa3a68a Binary files /dev/null and b/junctions/skins/overlay/spritesheet.png differ diff --git a/junctions/skins/overlay/techsmith-smart-player.min.css b/junctions/skins/overlay/techsmith-smart-player.min.css new file mode 100644 index 0000000..49f76f3 --- /dev/null +++ b/junctions/skins/overlay/techsmith-smart-player.min.css @@ -0,0 +1 @@ +html{color:#000}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:400}li{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:400}q:before,q:after{content:''}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit}input,textarea,select{*font-size:100%}legend{color:#000}body{font:13px/1.231 arial,helvetica,clean,sans-serif;*font-size:small;*font:x-small}table{font-size:inherit;font:100%}pre,code,kbd,samp,tt{font-family:monospace;*font-size:108%;line-height:100%}h1{font-size:138.5%}h2{font-size:123.1%}h3{font-size:108%}h1,h2,h3{margin:1em 0}h1,h2,h3,h4,h5,h6,strong{font-weight:700}abbr,acronym{border-bottom:1px dotted #000;cursor:help}em{font-style:italic}blockquote,ul,ol,dl{margin:1em}ol,ul,dl{margin-left:2em}ol li{list-style:decimal outside}ul li{list-style:disc outside}dl dd{margin-left:1em}th,td{border:0;padding:.5em}th{font-weight:700;text-align:center}caption{margin-bottom:.5em;text-align:center}p,fieldset,table,pre{margin:0}input[type=text],input[type=password],textarea{width:12.25em;*width:11.9em}html,body{height:100%}html,body,form,fieldset,p,div,h1,h2,h3,h4,h5,h6{-webkit-text-size-adjust:none}body{margin:0;padding:0;overflow:hidden;background-color:#000}object:focus{outline:0}#tscVideoContent{width:100%;height:100%;padding:0;margin:0;overflow:hidden}#tscVideoContent video{width:100%;height:100%}#videoWrapper{width:100%;height:100%}#videoDiv{width:100%;height:100%}#hotspotContainer,#hotspotContainerDebug{position:absolute}#alertDialog{display:none;position:absolute;text-align:center;z-index:12;padding:15px;color:#434343;font-size:20px;top:30px;left:25%;right:25%;background-color:#fff;border:1px solid #bcbcbc}#alertDialog span{display:block;max-height:200px;overflow-y:auto}#alertDialog h4{font-size:16px;padding:5px 0;border-radius:20px;margin-top:14px;text-align:center;margin-left:auto;margin-right:auto;max-width:200px;color:#434343;background-color:#fff;border:1px solid #bcbcbc}.alertDialogClose{display:block;float:right}#tsc_io_container{position:absolute;z-index:12;width:100%;height:100%;top:45%;padding:0;margin:0;text-align:center;color:#fff}#tsc_io_message{margin-left:auto;margin-right:auto;padding:8px;background-color:rgba(0,0,0,.8);border-top-right-radius:12px;border-top-left-radius:12px;border-bottom-right-radius:12px;border-bottom-left-radius:12px;-moz-border-radius:12px;-webkit-border-radius:12px;max-width:300px}#tsc_io_message span{display:block}#tsc_io_container img{border:0;margin:10px 10px 0}.centeredImage{vertical-align:middle;text-align:center}#screenText{display:none}#speechText{display:none}#hotspots{position:absolute;width:100%;height:100%;top:0;left:0}#hotspots.hide{display:none}#hotspots area:focus,#hotspots area:active{outline:0}.hotspots_mapimg{position:absolute;width:100%;height:100%}#youtubePointerEventWorkaround{position:absolute;width:100%;height:100%;top:0}#youtubePointerEventWorkaround.hide{display:none}#caption{position:absolute;left:20px;right:20px}#caption p{display:inline-block;background-color:#000;font-family:Arial,Helvetica,sans-serif;color:#FFF;line-height:1.2}#caption.hide{display:none}#caption.caption_under_video{position:relative;bottom:0;left:0;right:0}.captionVAlignTop{top:20px}.captionVAlignBottom{bottom:54px}.captionHAlignLeft{text-align:left}.captionHAlignCenter{text-align:center}.captionHAlignRight{text-align:right}#videoClickToPlayLink,#videoClickToReplayLink{position:absolute;top:0;left:0;display:block;width:100%;height:100%;background-position:center center;background-repeat:no-repeat;background-size:100%;cursor:pointer}.noClickToPlayEvents{pointer-events:none}#videoClickToPlay,#videoClickToReplay{position:absolute;top:50%;left:50%}#markers{width:100%;height:100%}.foundSearchText{color:#40C6E2}.appplayer{position:relative;border-radius:5px;background-size:cover;z-index:1}.posterFade{background:rgba(0,0,0,.6);border-radius:5px;height:100%}.appplayer .content{text-align:center;z-index:2}.appplayer h2{color:#fff;font-weight:700;margin:50px 0 10px;text-shadow:0 0 2px #000;filter:dropshadow(color=#000000,offx=0,offy=0);z-index:2}.externalDefaultPlaybackContainer{position:relative;background-size:cover;z-index:1;background-color:#000;width:100%;height:100%}.externalLargePlayBtn{display:block;width:73px;height:73px;background:url() no-repeat;background-size:contain;cursor:pointer;z-index:2}.centerAbsoluteElement{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.openVideoSmartPlayerContainer{display:-webkit-box;display:-webkit-flexbox;display:-webkit-flex;display:flex;-webkit-box-align:center;-webkit-flex-align:center;-webkit-align-items:center;align-items:center;height:100%;width:100%;z-index:9;-webkit-box-sizing:border-box;box-sizing:border-box}.openVideoSmartPlayerButton{text-align:center;display:block;border-radius:12px;padding:20px 10px 20px 60px;background:url() no-repeat;background-size:40px auto;background-position:10px center;background-color:#42474C;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:16px;max-width:360px;margin:auto;-webkit-box-shadow:0 2px 6px 2px rgba(0,0,0,.2);box-shadow:0 2px 6px 2px rgba(0,0,0,.2);text-shadow:1px 1px 0 rgba(0,0,0,.8);cursor:pointer;webkit-user-select:none;-webkit-box-sizing:border-box;box-sizing:border-box}.appstoreBtn{display:block;width:91px;height:30px;background:url() no-repeat;background-size:contain;margin:auto;z-index:2}.appNativePlayBtn{position:absolute;left:25%;bottom:8px;display:block;width:50%;height:30px;background:url() center no-repeat;background-size:129px 38px;color:#fff;cursor:pointer;text-shadow:0 -1px 0 #000;filter:dropshadow(color=#000000,offx=0,offy=-1);font-size:.8em;font-weight:700;text-align:center;margin:0 auto;padding-top:8px;z-index:4}.appNativePlayBtnText{font-size:.9em;font-weight:700;text-align:center;padding-top:2px}.topBrdr,.btmBrdr{height:8px;width:100%}.topBrdr{border-radius:5px 5px 0 0;border-top:1px solid #ccc}.btmBrdr{position:absolute;bottom:0;left:0;z-index:3;border-radius:0 0 5px 5px;border-top:1px solid #888;border-bottom:1px solid #000}.topBrdrInner,.btmBrdrInner{width:100%;height:7px}.topBrdrInner{padding-bottom:1px;border-radius:4px 4px 0 0;background:-webkit-linear-gradient(top,rgba(116,115,115,1) 0,rgba(54,54,54,1) 100%);background:linear-gradient(top,rgba(116,115,115,1) 0,rgba(54,54,54,1) 100%)}.btmBrdrInner{position:absolute;bottom:0;left:0;z-index:3;padding-top:1px;border-radius:0 0 4px 4px;background:-webkit-linear-gradient(top,#474747 0,#333 100%);background:linear-gradient(top,#474747 0,#333 100%)}.fullSizePosterImgContainer{display:display;background-size:contain!important;background-position:center!important;background-repeat:no-repeat!important;width:100%;height:100%;background-color:#000!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media (max-width:320px){.openVideoSmartPlayerButton{width:260px;font-size:14px;background-position:15px center}}#controls{position:absolute;bottom:0;left:0;width:100%;overflow:visible;font-family:Helvetica,Arial,sans-serif;z-index:3}.hide #controls{display:none}#controls .controls_left{float:left;margin-right:-15px}#controls .controls_right{float:right;margin-left:-15px}#controls .control_button{display:block;float:left;padding:0;border-style:none;background-color:transparent;cursor:pointer}#controls .control_button:focus{outline:0}#controls .hide{display:none}#controls.caption_under_video{position:relative;bottom:0;left:0;right:0}#progress{overflow:hidden}#progress_box{overflow:hidden;padding:0 15px}#progress_scrubbar_track_left{float:left}#progress_scrubbar_track_right{float:right}#progress_scrubbar_track{position:relative;display:block;width:auto;cursor:pointer;touch-action:none}#progress_scrubbar_track .scrubbar_track,#progress_scrubbar_track .scrubbar_loaded_track,#progress_scrubbar_track .scrubbar_played_track{position:absolute;left:0}#progress_scrubbar_track .scrubbar_track{width:100%}#play_progress{overflow:visible}#scrubbar_scrubber{position:absolute;top:0;right:0}#progress .seperator{float:right}#play_time{float:right;margin:0 15px 0 -15px;cursor:default}#markers{position:absolute;top:0;display:none}.volume_wrapper{position:relative;float:left;z-index:1}#volume_slider_container{position:absolute;bottom:100%;transition:height .1s}#volume_slider_container.hide{display:block;height:0}#volume_slider_vertical{position:relative;cursor:pointer}#volume_slider_vertical .ui-slider-range{position:absolute;bottom:0;left:0;width:100%}#volume_slider_vertical .ui-slider-handle{position:absolute;display:block}#playerSettingsContainer{position:absolute;bottom:100%;right:0;padding:10px}#videoSidebar{position:absolute;top:0;left:0;display:none;width:252px;border-color:#4c4c4c;border-width:1px;border-style:none solid;color:#fff;background:#000;background:rgba(0,0,0,.85)}#videoSidebar.right{left:auto;right:0}#videoSidebarHead{position:relative;overflow:hidden;z-index:1}#videoSidebarHead .video_title{font-size:inherit;font-weight:inherit;padding:6px 2px 4px}#searchArea{border:1px solid #ccc;border-radius:12px;margin:0 2px 4px;padding:2px 2px 2px 22px;background:#fff url() scroll no-repeat 3px center;overflow:hidden}.search_disabled #searchArea{display:none}#searchBox{display:block;float:left;width:190px;height:22px;padding:0;border-style:none;font-size:18px}#clearSearchButton{display:block;float:right;width:28px;height:22px;padding:0;border-style:none;background:#fff url() scroll no-repeat center}#fsSearchAlert{display:none;margin:5px 0;padding:10px;color:#fff;font-size:12px;background-color:#ba8a29;background-image:-webkit-gradient(linear,0 0,0 100%,from(#ba8a29),to(#a8502f));background-image:-webkit-linear-gradient(top,#ba8a29,#a8502f);background-image:-moz-linear-gradient(top,#ba8a29,#a8502f);background-image:-ms-linear-gradient(top,#ba8a29,#a8502f);background-image:-o-linear-gradient(top,#ba8a29,#a8502f);border:1px solid maroon;-moz-box-shadow:0 0 5px rgba(0,0,0,.5);-webkit-box-shadow:0 0 5px rgba(0,0,0,.5);text-shadow:1px 1px 0 rgba(0,0,0,.5)}.search_disabled #fsSearchAlert{display:block}#pipimage{background-repeat:no-repeat;background-size:contain;border:1px solid #FFF;margin-top:10px;margin-bottom:10px}#videoSidebarContentWrapper{position:absolute;top:58px;right:0;bottom:0;left:0;overflow:auto}#searchList,#tableOfContentsList{margin:0}#searchList li,#tableOfContentsList li{list-style:none;cursor:pointer}#searchList li:hover,#tableOfContentsList li:hover{background-color:#333;color:#fff}#searchList li.noThumbImage,#tableOfContentsList li.noThumbImage{padding:10px 6px 10px 8px}#searchList li.hasThumbImage,#tableOfContentsList li.hasThumbImage{padding:4px 10px}#searchList .tocItemLabel,#tableOfContentsList .tocItemLabel{position:relative;margin-left:5px}#tsc_quiz_container{font-family:Arial,Helvetica,sans-serif;font-size:14px;z-index:10;padding:20px;position:absolute;background-color:#FFF;line-height:1.3em}#tsc_quiz_container h2{font-family:Actor,Arial,Helvetica,sans-serif;font-size:32px;letter-spacing:0;line-height:1em;padding:0;margin:0;margin-bottom:12px;min-height:46px;width:480px;color:#000ad2;word-wrap:break-word;text-shadow:-1px 1px 1px rgba(0,0,0,.4)}#tsc_quiz_container label{margin:3px 0;padding:4px 4px 6px 10px;word-wrap:break-word}.active_quiz_item:hover{background-color:#cdd4fb;border-top-left-radius:12px;border-top-right-radius:12px;border-bottom-left-radius:12px;border-bottom-right-radius:12px}.active_quiz_item:active{background-color:#dadff0;border-top-left-radius:12px;border-top-right-radius:12px;border-bottom-left-radius:12px;border-bottom-right-radius:12px}.picked_quiz_item{background-color:#dadff0;border-top-left-radius:12px;border-top-right-radius:12px;border-bottom-left-radius:12px;border-bottom-right-radius:12px}.quiz_question{margin:0 0 8px;padding:0;word-wrap:break-word}.quiz_question span{font-family:Actor,Arial,Helvetica,sans-serif;font-size:22px;color:#666}#tsc_quiz_container input[type=radio]{margin-right:10px}#tsc_quiz_controls{margin-top:10px}#tsc_text_input{width:300px;margin-left:22px;margin-bottom:14px}#tsc_textarea_input{width:460px;margin-left:22px;margin-bottom:10px;font-family:Actor,sans-serif;font-size:16px;font-weight:400}#tsc_question_set_result_info{display:none;margin:-10px 0 15px 4px;padding:0;width:490px;font-size:12px;color:#666;text-shadow:-1px 0 0 rgba(0,0,0,.4)}.tsc_multiple_choice{display:block}.image_feedback{margin-left:-3px;margin-right:10px;margin-bottom:-4px}.image_fitb_feedback{margin-left:0;margin-right:-20px;margin-bottom:-4px}.feedback_placeholder{display:none}.feedback_placeholder_show{display:block}button{cursor:pointer;padding:5px 10px}#tsc_previous_button{display:none}#tsc_next_button{display:none}#tsc_submit_button{float:right;display:none}#tsc_continue_button{float:right;display:none}#tsc_quiz_setup_container{font-family:Arial,Helvetica,sans-serif;font-size:18px;z-index:10;position:absolute;text-align:center;background-color:#FFF}#tsc_quiz_setup_container label{display:none;margin-left:4px}#tsc_quiz_question_count{padding:8px;text-align:center;line-height:1.6em;width:69px;height:70px;background:url() no-repeat;position:absolute;top:-13px;right:18px}.tsc_quiz_question_count_current{margin-top:14px;margin-left:8px;display:block;font-size:32px;font-family:Quicksand,Arial,Helvetica,sans-serif;text-shadow:-1px 1px 1px rgba(0,0,0,.4);font-weight:800;color:#000}.tsc_quiz_question_count_total{display:block;margin-top:2px;margin-left:8px;font-size:14px}#tsc_answers{max-height:200px;overflow:auto;-webkit-overflow-scrolling:touch}@media screen and (min-height:401px){#tsc_quiz_container{padding:20px;left:0;bottom:0;width:580px;border:1px solid #CCC;border-top-right-radius:22px;border-top-left-radius:22px;border-bottom-right-radius:22px;border-bottom-left-radius:22px;-moz-border-radius:22px;-webkit-border-radius:22px;-moz-box-shadow:0 0 5px rgba(0,0,0,.5);-webkit-box-shadow:0 0 5px rgba(0,0,0,.5)}#tsc_quiz_setup_container{width:560px;left:50%;top:15px;margin-left:-280px;border:1px solid #CCC;border-top-right-radius:22px;border-top-left-radius:22px;border-bottom-right-radius:22px;border-bottom-left-radius:22px;-moz-border-radius:22px;-webkit-border-radius:22px;-moz-box-shadow:0 0 10px rgba(0,0,0,.5);-webkit-box-shadow:0 0 10px rgba(0,0,0,.5)}.inputBlock{margin-top:12px;text-align:left;width:404px;margin-left:auto;margin-right:auto}.inputContainer{text-align:center;margin-bottom:20px}#tsc_quiz_setup_container h2{color:#000ad2;text-align:left;font-size:1.2em;margin:20px 30px;text-shadow:1px 1px 1px rgba(0,0,0,.3)}#tsc_quiz_setup_container p{margin:20px 0}#tsc_quiz_setup_container input{font-size:1.1em;color:#325ea3;width:400px}#tsc_quiz_setup_container button{padding:10px 15px;font-size:1.4em}#tsc_quiz_setup_container a{margin-top:10px;padding:6px 10px;font-size:.75em;text-decoration:none;color:#fff;background-color:#333;-moz-border-radius:6px;-webkit-border-radius:6px;-moz-box-shadow:0 0 1px rgba(0,0,0,.5);-webkit-box-shadow:0 0 1px rgba(0,0,0,.5)}}@media screen and (max-height:400px){#tsc_quiz_container{padding:0;width:100%;height:100%;left:0!important;bottom:0!important;top:0!important;max-height:400px!important;border-top-right-radius:0;border-top-left-radius:0;border-bottom-right-radius:0;border-bottom-left-radius:0;-moz-border-radius:0;-webkit-border-radius:0}#tsc_quiz_container h2{margin:8px 4px 12px 8px;min-height:46px;font-size:28px;width:82%}.quiz_question{margin:8px}#tsc_textarea_input{width:90%}#tsc_question_set_result_info{width:80%;margin-left:10px}#tsc_answers{margin:10px}button{cursor:pointer;padding:10px 15px;font-size:18px}#tsc_previous_button{margin-left:10px;display:none}#tsc_next_button{display:none}#tsc_submit_button{float:right;margin-right:10px;display:none}#tsc_continue_button{float:right;margin-right:10px;display:none}#tsc_quiz_controls{width:100%;position:absolute;bottom:0;padding:10px 0;background-color:#fff}#tsc_quiz_setup_container{width:100%;height:100%;left:0;top:0}.inputBlock{margin-top:12px;text-align:left;width:404px;margin-left:auto;margin-right:auto}.inputContainer{text-align:center;margin-bottom:10px}#tsc_quiz_setup_container h2{color:#000ad2;font-size:1.1em;margin:15px 10px;text-shadow:1px 1px 1px rgba(0,0,0,.3)}#tsc_quiz_setup_container p{margin:20px 0}#tsc_quiz_setup_container input{font-size:1.1em;color:#325ea3;width:400px}#tsc_quiz_setup_container button{padding:10px 15px;font-size:1.4em}#tsc_quiz_setup_container a{margin-top:10px;padding:6px 10px;font-size:1.4em;text-decoration:none;color:#fff;background-color:#333;-moz-border-radius:6px;-webkit-border-radius:6px;-moz-box-shadow:0 0 1px rgba(0,0,0,.5);-webkit-box-shadow:0 0 1px rgba(0,0,0,.5)}#tsc_quiz_question_count{top:-13px;right:-5px}}#tsc_confirmation_container{font-family:Arial,Helvetica,sans-serif;font-size:18px;z-index:10;padding:6px;position:absolute;left:0;bottom:0;width:200px;background-color:#FFF;border:1px solid #CCC;line-height:1.3em;border-top-right-radius:22px;border-top-left-radius:22px;border-bottom-right-radius:22px;border-bottom-left-radius:22px;-moz-border-radius:22px;-webkit-border-radius:22px;-moz-box-shadow:0 0 5px rgba(0,0,0,.5);-webkit-box-shadow:0 0 5px rgba(0,0,0,.5)}#tsc_review_confirmation_container{font-family:Arial,Helvetica,sans-serif;font-size:18px;z-index:10;padding:6px;position:absolute;left:0;bottom:0;width:200px;background-color:#FFF;border:1px solid #CCC;line-height:1.3em;border-top-right-radius:22px;border-top-left-radius:22px;border-bottom-right-radius:22px;border-bottom-left-radius:22px;-moz-border-radius:22px;-webkit-border-radius:22px;-moz-box-shadow:0 0 5px rgba(0,0,0,.5);-webkit-box-shadow:0 0 5px rgba(0,0,0,.5)}#tsc_overlay{position:absolute;z-index:9;top:0;left:0;background-color:#000;width:100%;height:100%;padding:0;margin:0;opacity:.7}.largeButton{cursor:pointer;text-align:center;color:#fff;padding:15px;margin:5px;font-size:18px;-moz-border-radius:12px;-webkit-border-radius:12px;-moz-box-shadow:0 0 5px rgba(0,0,0,.5);-webkit-box-shadow:0 0 5px rgba(0,0,0,.5);-webkit-box-shadow:0 0 0 1px #666,0 0 0 2px #999,0 0 0 3px #666,1 1 1 6px #666;background:#45484d;background:-moz-linear-gradient(top,rgba(69,72,77,1) 0,rgba(0,0,0,1) 100%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0%,rgba(69,72,77,1)),color-stop(100%,rgba(0,0,0,1)));background:-webkit-linear-gradient(top,rgba(69,72,77,1) 0,rgba(0,0,0,1) 100%);background:-o-linear-gradient(top,rgba(69,72,77,1) 0,rgba(0,0,0,1) 100%);background:-ms-linear-gradient(top,rgba(69,72,77,1) 0,rgba(0,0,0,1) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#45484d', endColorstr='#000000', GradientType=0);text-shadow:1px 1px 1px rgba(0,0,0,.8)}.blueButton{background:#84c4e2;background:url();background:-moz-linear-gradient(top,#84c4e2 0,#369ad6 36%,#3786c9 61%,#66adf1 100%);background:-webkit-gradient(linear,left top,left bottom,color-stop(0%,#84c4e2),color-stop(36%,#369ad6),color-stop(61%,#3786c9),color-stop(100%,#66adf1));background:-webkit-linear-gradient(top,#84c4e2 0,#369ad6 36%,#3786c9 61%,#66adf1 100%);background:-o-linear-gradient(top,#84c4e2 0,#369ad6 36%,#3786c9 61%,#66adf1 100%);background:-ms-linear-gradient(top,#84c4e2 0,#369ad6 36%,#3786c9 61%,#66adf1 100%);background:linear-gradient(top,#84c4e2 0,#369ad6 36%,#3786c9 61%,#66adf1 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#84c4e2', endColorstr='#66adf1', GradientType=0)}#tsc_continue_control{font-size:14px}#tsc_review_answers_control{margin-bottom:7px}#tsc_review_control{font-size:14px}#tsc_confirm_control{margin-bottom:7px}.chat-bubble-arrow-border{border-color:#CCC transparent transparent;border-style:solid;border-width:15px;height:0;width:0;position:absolute;bottom:-30px;left:130px}.chat-bubble-arrow{border-color:#FFF transparent transparent;border-style:solid;border-width:15px;height:0;width:0;position:absolute;bottom:-28px;left:130px}.preRoll{position:absolute;z-index:20;overflow:hidden;border:0}.preRollHidden{visibility:hidden}.preRoll-disableMouse{pointer-events:none}.preRoll-fullPage{top:0;left:0;width:100%;height:100%}.spritesheet{display:inline-block;overflow:hidden;background-repeat:no-repeat;background-image:url(spritesheet.png)}.sprite_repeat{background-repeat:repeat-x!important}.rewind_button_normal{width:43px;height:43px;background-position:-192px -226px}.rewind_button_over{width:43px;height:43px;background-position:-240px -226px}.rewind_button_down{width:43px;height:43px;background-position:-144px -288px}.rewind_button_disabled{width:43px;height:43px;background-position:-192px -226px}.play_button_normal{width:43px;height:43px;background-position:-144px -0px}.play_button_over{width:43px;height:43px;background-position:-144px -48px}.play_button_down{width:43px;height:43px;background-position:-96px -288px}.play_button_disabled{width:43px;height:43px;background-position:-144px -0px}.pause_button_normal{width:43px;height:43px;background-position:-96px -192px}.pause_button_over{width:43px;height:43px;background-position:-96px -240px}.pause_button_down{width:43px;height:43px;background-position:-96px -144px}.pause_button_disabled{width:43px;height:43px;background-position:-96px -192px}.previous_button_normal{width:43px;height:43px;background-position:-144px -192px}.previous_button_over{width:43px;height:43px;background-position:-144px -240px}.previous_button_down{width:43px;height:43px;background-position:-144px -144px}.previous_button_disabled{width:43px;height:43px;background-position:-144px -96px}.next_button_normal{width:43px;height:43px;background-position:-96px -48px}.next_button_over{width:43px;height:43px;background-position:-96px -96px}.next_button_down{width:43px;height:43px;background-position:-96px -0px}.next_button_disabled{width:43px;height:43px;background-position:-48px -288px}.settings_button_normal{width:43px;height:43px;background-position:-380px -0px}.settings_button_over{width:43px;height:43px;background-position:-428px -0px}.settings_button_down{width:43px;height:43px;background-position:-332px -0px}.settings_button_disabled{width:43px;height:43px;background-position:-380px -0px}.settings_off_button_normal{width:43px;height:43px;background-position:-476px -0px}.settings_off_button_over{width:43px;height:43px;background-position:-476px -0px}.settings_off_button_down{width:43px;height:43px;background-position:-476px -0px}.settings_off_button_disabled{width:43px;height:43px;background-position:-476px -0px}.closed_caption_button_normal{width:43px;height:43px;background-position:-0px -48px}.closed_caption_button_over{width:43px;height:43px;background-position:-0px -96px}.closed_caption_button_down{width:43px;height:43px;background-position:-0px -0px}.closed_caption_button_disabled{width:43px;height:43px;background-position:-0px -48px}.closed_caption_off_button_normal{width:43px;height:43px;background-position:-0px -144px}.closed_caption_off_button_over{width:43px;height:43px;background-position:-0px -144px}.closed_caption_off_button_down{width:43px;height:43px;background-position:-0px -144px}.closed_caption_off_button_disabled{width:43px;height:43px;background-position:-0px -144px}.toc_button_normal{width:43px;height:43px;background-position:-353px -48px}.toc_button_over{width:43px;height:43px;background-position:-401px -48px}.toc_button_down{width:43px;height:43px;background-position:-305px -48px}.toc_button_disabled{width:43px;height:43px;background-position:-353px -48px}.toc_off_button_normal{width:43px;height:43px;background-position:-449px -48px}.toc_off_button_over{width:43px;height:43px;background-position:-449px -48px}.toc_off_button_down{width:43px;height:43px;background-position:-449px -48px}.toc_off_button_disabled{width:43px;height:43px;background-position:-449px -48px}.fullscreen_enter_button_normal{width:43px;height:43px;background-position:-48px -48px}.fullscreen_enter_button_over{width:43px;height:43px;background-position:-48px -96px}.fullscreen_enter_button_down{width:43px;height:43px;background-position:-48px -0px}.fullscreen_enter_button_disabled{width:43px;height:43px;background-position:-48px -48px}.fullscreen_leave_button_normal{width:43px;height:43px;background-position:-48px -192px}.fullscreen_leave_button_over{width:43px;height:43px;background-position:-48px -240px}.fullscreen_leave_button_down{width:43px;height:43px;background-position:-48px -144px}.fullscreen_leave_button_disabled{width:43px;height:43px;background-position:-48px -192px}.fullframe_enter_button_normal{width:43px;height:43px;background-position:-0px -240px}.fullframe_enter_button_over{width:43px;height:43px;background-position:-0px -240px}.fullframe_enter_button_down{width:43px;height:43px;background-position:-0px -240px}.fullframe_enter_button_disabled{width:43px;height:43px;background-position:-0px -240px}.fullframe_leave_button_normal{width:43px;height:43px;background-position:-0px -288px}.fullframe_leave_button_over{width:43px;height:43px;background-position:-0px -288px}.fullframe_leave_button_down{width:43px;height:43px;background-position:-0px -288px}.fullframe_leave_button_disabled{width:43px;height:43px;background-position:-0px -288px}.play_button_overlay_normal{width:108px;height:108px;background-position:-192px -0px}.play_button_overlay_over{width:108px;height:108px;background-position:-192px -0px}.play_button_overlay_down{width:108px;height:108px;background-position:-192px -0px}.play_button_overlay_disabled{width:108px;height:108px;background-position:-192px -0px}.replay_button_overlay_normal{width:108px;height:108px;background-position:-192px -113px}.replay_button_overlay_over{width:108px;height:108px;background-position:-192px -113px}.replay_button_overlay_down{width:108px;height:108px;background-position:-192px -113px}.replay_button_overlay_disabled{width:108px;height:108px;background-position:-192px -113px}.scroll_down_arrow_normal{width:16px;height:16px;background-position:-14px -213px}.scroll_down_arrow_over{width:16px;height:16px;background-position:-192px -274px}.scroll_down_arrow_down{width:16px;height:16px;background-position:-14px -213px}.scroll_down_arrow_disabled{width:16px;height:16px;background-position:-14px -213px}.scroll_up_arrow_normal{width:16px;height:16px;background-position:-232px -313px}.scroll_up_arrow_over{width:16px;height:16px;background-position:-253px -292px}.scroll_up_arrow_down{width:16px;height:16px;background-position:-232px -292px}.scroll_up_arrow_disabled{width:16px;height:16px;background-position:-232px -313px}.scroll_thumb_bottom_normal{width:14px;height:50px;background-position:-192px -295px}.scroll_thumb_bottom_over{width:14px;height:50px;background-position:-192px -295px}.scroll_thumb_bottom_down{width:14px;height:50px;background-position:-192px -295px}.scroll_thumb_bottom_disabled{width:14px;height:50px;background-position:-192px -295px}.scroll_track_normal{width:15px;height:13px;background-position:-232px -274px}.scroll_track_over{width:16px;height:4px;background-position:-69px -336px}.scroll_track_down{width:16px;height:4px;background-position:-48px -336px}.scroll_track_disabled{width:15px;height:13px;background-position:-232px -274px}.scrubbar_scrubber_normal{width:10px;height:43px;background-position:-305px -0px}.scrubbar_scrubber_over{width:10px;height:43px;background-position:-305px -0px}.scrubbar_scrubber_down{width:10px;height:43px;background-position:-305px -0px}.scrubbar_scrubber_disabled{width:10px;height:43px;background-position:-305px -0px}.unmute_button_normal{width:43px;height:43px;background-position:-545px -48px}.unmute_button_over{width:43px;height:43px;background-position:-305px -96px}.unmute_button_down{width:43px;height:43px;background-position:-497px -48px}.unmute_button_disabled{width:43px;height:43px;background-position:-545px -48px}.volume_button_normal{width:43px;height:43px;background-position:-353px -192px}.volume_button_over{width:43px;height:43px;background-position:-353px -240px}.volume_button_down{width:43px;height:43px;background-position:-305px -144px}.volume_button_disabled{width:43px;height:43px;background-position:-353px -192px}.volume_button_low_normal{width:43px;height:43px;background-position:-401px -96px}.volume_button_low_over{width:43px;height:43px;background-position:-449px -96px}.volume_button_low_down{width:43px;height:43px;background-position:-353px -96px}.volume_button_low_disabled{width:43px;height:43px;background-position:-401px -96px}.volume_button_med_normal{width:43px;height:43px;background-position:-545px -96px}.volume_button_med_over{width:43px;height:43px;background-position:-353px -144px}.volume_button_med_down{width:43px;height:43px;background-position:-497px -96px}.volume_button_med_disabled{width:43px;height:43px;background-position:-545px -96px}.volume_button_high_normal{width:43px;height:43px;background-position:-305px -240px}.volume_button_high_over{width:43px;height:43px;background-position:-305px -288px}.volume_button_high_down{width:43px;height:43px;background-position:-305px -192px}.volume_button_high_disabled{width:43px;height:43px;background-position:-305px -240px}.volumebar_slider_normal{width:13px;height:9px;background-position:-96px -336px}.volumebar_slider_over{width:13px;height:9px;background-position:-96px -336px}.volumebar_slider_down{width:13px;height:9px;background-position:-96px -336px}.volumebar_slider_disabled{width:13px;height:9px;background-position:-96px -336px}.scrubbar_loaded_track_end{width:2px;height:43px;background-position:-288px -226px}.scrubbar_track_left{width:1px;height:43px;background-position:-295px -226px}.scrubbar_track_right{width:1px;height:43px;background-position:-320px -0px}.scrubbar_track{width:2px;height:43px;background-position:-0px -479px}.scrubbar_loaded_track{width:2px;height:43px;background-position:-0px -393px}.scrubbar_played_track{width:2px;height:43px;background-position:-0px -436px}.seperator{width:1px;height:43px;background-position:-326px -0px}.volumebar_track{width:5px;height:2px;background-position:-35px -192px}.volumebar_track_end{width:5px;height:2px;background-position:-35px -199px}.volumebar_backdrop{width:31px;height:97px;background-position:-401px -144px}.control_backdrop_left{width:2px;height:43px;background-position:-0px -192px}.control_backdrop_right{width:2px;height:43px;background-position:-7px -192px}.toc_title_backdrop{width:8px;height:18px;background-position:-0px -522px}.control_backdrop{width:2px;height:43px;background-position:-0px -350px}.quizMarker{width:3px;color:rgba(255,255,255,.5);display:none}#videoClickToPlay,#videoClickToReplay{margin:-54px 0 0 -54px}#progress .seperator{display:none}#play_time{padding:0 5px 0 13px;font-size:15px;line-height:43px;color:#fff}#progress_scrubbar_track{height:43px;margin:0 1px}#scrubbar_scrubber{margin-right:-6px}#volume_slider_container{left:6px;margin-bottom:-4px}#volume_slider_vertical{height:61px;margin-top:19px}#volume_slider_vertical .ui-slider-handle{left:9px;width:13px;height:9px;background-image:url(spritesheet.png);background-position:-96px -336px}#volume_slider_vertical .ui-slider-range{margin-left:15px;width:1px;background-color:#151515}#playerSettingsContainer{margin-bottom:1px;background-color:#4b4b4b;color:#fff}#videoSidebar{bottom:43px}.captionVAlignBottom{bottom:53px} \ No newline at end of file diff --git a/src/ADDBEDLV.F90 b/src/ADDBEDLV.F90 new file mode 100644 index 0000000..39feeb7 --- /dev/null +++ b/src/ADDBEDLV.F90 @@ -0,0 +1,18 @@ + SUBROUTINE ADDBEDLV + + USE BLK1MOD + +! process node with weighting values + DO N=1,NP +! IF(ICN(N) .EQ. 2) THEN + IF(NRIVCR1(N) .GT. 0) THEN + NC1=NRIVCR1(N) + NC2=NRIVCR2(N) + WT1=WTRIVCR1(N) + WT2=WTRIVCR2(N) + WD(N)=CRSDAT(NC1,1,1)*WT1+CRSDAT(NC2,1,1)*WT2 + ENDIF +! ENDIF + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/ADDCRS.f90 b/src/ADDCRS.f90 new file mode 100644 index 0000000..e8412d5 --- /dev/null +++ b/src/ADDCRS.f90 @@ -0,0 +1,136 @@ + SUBROUTINE ADDSLOT + +! ADD SLOT TO 1-D + + USE BLK1MOD + +! GET SLOT PARAMETERS + + CALL GETSLOTPARAM(ISLTYP,SLDEP,SLRNG,SLPOR) + IF(ISLTYP .EQ. -1) RETURN + +! SEARCH FOR CROSS-SECTION REACH/TYPE + IF(ISLTYP .EQ. 0) THEN + DO N=1,MCRS + IF(IVMIL(N) .LT. 1) EXIT + MM=NRIVL(IVMIL(N)) + IF(MM .GT. 0) THEN + CALL ADDSLOTDATA(IVMIL(N),MM,SLDEP,SLRNG,SLPOR) + ENDIF + NRIVL(IVMIL(N))=MM + ENDDO + ELSE +! SEARCH FOR CROSS-SECTION REACH/TYPE +! +! IVMIL = CROSS-SECTION NUMBER +! NRIVL = NUMBER OF POINTS IN SECTION +! NOREACH = REACH/TYPE NUMBER +! CRSDAT 1 = ELEVATION +! CRSDAT 2 = AREA +! CRSDAT 3 = WIDTH + + DO N=1,MCRS + IF(ISLTYP .EQ. NOREACH(N)) THEN + MM=NRIVL(IVMIL(N)) + CALL ADDSLOTDATA(IVMIL(N),MM,SLDEP,SLRNG,SLPOR) + NRIVL(IVMIL(N))=MM + ENDIF + ENDDO + ENDIF +! APPLY CHANGE + + RETURN + END + + SUBROUTINE GETSLOTPARAM(ISLTYP,SLDEP,SLRNG,SLPOR) + use winteracter + USE BLK1MOD + +!- + + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: IERR,ISET,IBOX + REAL :: ASET + CHARACTER*1 :: IFLAG + + call wdialogload(IDD_ADDSLOT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_ADDSLOT) + ierr=infoerror(1) + + ISLTYP=0 + SLDEP=4. + SLRNG=0.5 + SLPOR=0.1 + 100 continue + + + CALL WDialogPutINTEGER(IDF_INTEGER1,ISLTYP) + CALL WDialogPutReal(idf_real1,SLDEP) + CALL WDialogPutReal(idf_real2,SLRNG) + CALL WDialogPutReal(idf_real3,SLPOR) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + DO +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + CALL WDialogGetINTEGER(IDF_INTEGER1,ISLTYP) + CALL WDialogGetReal(idf_real1,SLDEP) + CALL WDialogGetReal(idf_real2,SLRNG) + CALL WDialogGetReal(idf_real3,SLPOR) + GO TO 200 + else + ISLTYP=-1 + RETURN + endif + ENDDO + 200 CONTINUE + RETURN + END + SUBROUTINE ADDSLOTDATA(N,M,SLDEP,SLRNG,SLPOR) + USE BLK1MOD + BLEVL=CRSDAT(N,1,1) + BWIDT=CRSDAT(N,1,3) + IF(BWIDT .LT. 1) THEN + CRSDAT(N,1,3)=1.0 + CRSDAT(N,0,1)=BLEVL-SLRNG + CRSDAT(N,0,3)=SLPOR + CRSDAT(N,-1,1)=CRSDAT(N,0,1)-SLDEP + CRSDAT(N,-1,3)=SLPOR + MLT=-1 + ELSE + CRSDAT(N,0,1)=BLEVL-SLRNG + CRSDAT(N,0,3)=1.0 + CRSDAT(N,-1,1)=BLEVL-2.*SLRNG + CRSDAT(N,-1,3)=SLPOR + CRSDAT(N,-2,1)=CRSDAT(N,0,1)-SLDEP + CRSDAT(N,-2,3)=SLPOR + MLT=-2 + ENDIF + DO I=M,MLT,-1 + DO J=1,3 + CRSDAT(N,I+1-MLT,J)=CRSDAT(N,I,J) + ENDDO + ENDDO + M=M+1-MLT + DO I=2,M + if(i .gt. 1) then + CRSDAT(N,I,2)=CRSDAT(N,I-1,2)+& + (CRSDAT(N,I,1)-CRSDAT(N,I-1,1))*& + (CRSDAT(N,I,3)+CRSDAT(N,I-1,3))/2. + endif + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/BLK1.f90 b/src/BLK1.f90 index 539c563..a9d6bed 100644 --- a/src/BLK1.f90 +++ b/src/BLK1.f90 @@ -74,7 +74,7 @@ NCSPTS,XELVP(50),YELVP(50),ZELVP(50),SELVP(50),& ZREF,DFACTOR,ZMIN,IXNOD,LCROSS& ,IVMIL(MCRS),NRIVL(MCRS),NOREACH(MCRS)& - ,CRSDAT(MCRS,MPTS,3),NCRSEC,XCRS(MCRS),YCRS(MCRS) + ,CRSDAT(MCRS,-4:MPTS,3),NCRSEC,XCRS(MCRS),YCRS(MCRS) ALLOCATABLE NRIVCR1(:),WTRIVCR1(:),NRIVCR2(:),WTRIVCR2(:) diff --git a/src/D.INC b/src/D.INC index d57a9ba..135319c 100644 --- a/src/D.INC +++ b/src/D.INC @@ -1,4 +1,4 @@ -! Winteracter resource identifiers. Created : 03/Mar/2017 13:04:04 +! Winteracter resource identifiers. Created : 19/Oct/2017 10:30:12 ! ! This file is generated by the Winteracter resource editor. ! It should not be edited manually. It is also not advisable to load this @@ -403,3 +403,7 @@ INTEGER, PARAMETER :: IDF_GREEN = 1036 INTEGER, PARAMETER :: IDF_BLUE = 1038 INTEGER, PARAMETER :: IDD_DIALOG002 = 169 + INTEGER, PARAMETER :: ID_ADDSLOT = 40150 + INTEGER, PARAMETER :: IDF_CANCEL = 1088 + INTEGER, PARAMETER :: IDD_ADDSLOT = 171 + INTEGER, PARAMETER :: ID_ADDBEDLEV = 40151 diff --git a/src/EVENT.F90 b/src/EVENT.F90 index e1897f3..13e9360 100644 --- a/src/EVENT.F90 +++ b/src/EVENT.F90 @@ -772,8 +772,8 @@ INQUIRE (FILE = fname, EXIST = exists) IF (.NOT. exists) THEN - CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'ORG file does not exist!!'//CHAR(13)// & - 'Do you wish to create file and view image','Looking for ORG file') + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Location file does not exist!!'//CHAR(13)// & + 'Do you wish to create file and view image','Looking for location file') ! If answer 'Yes' set ifrmel to 0 ! IF (WInfoDialog(4) .ne. 2) then @@ -1075,10 +1075,16 @@ IACTVFIL=IOLDACT CALL ADDTOMESH(IFILADD,1) GO TO 100 + !ipk sep16 ADD MESH FROM POINTS CASE (ID_ADDMESHTR) CALL ADDMESHT GO TO 100 + +!ipk sep16 ADD MESH FROM POINTS + CASE (ID_ADDBEDLEV) + CALL ADDBEDLV + GO TO 100 !ipk may03 CASE (ID_TRIANG) ! add a triangle of elements CALL ADDTRIANG @@ -1201,6 +1207,11 @@ CASE (ID_SAVELTLD) CALL SAVEEQ GO TO 100 + + CASE (ID_ADDSLOT) + CALL ADDSLOT + GO TO 100 + CASE (ID_ITEM17) ! Exit option !IPK SEP02 diff --git a/src/GETCRS.F90 b/src/GETCRS.F90 index 767afdc..5d6e328 100644 --- a/src/GETCRS.F90 +++ b/src/GETCRS.F90 @@ -43,7 +43,15 @@ IF(ID1(1:3) .EQ. 'ICS') THEN READ(DLIN1,'(2I8,8x,2f16.0)') IVMIL(N),NRIVL(IVMIL(N)),XCRS(IVMIL(N)),YCRS(IVMIL(N)) - write(90,'(a)') 'ics',id1,dlin1 +! +! IVMIL = CROSS-SECTION NUMBER +! NRIVL = NUMBER OF POINTS IN SECTION +! NOREACH = REACH/TYPE NUMBER +! CRSDAT 1 = ELEVATION +! CRSDAT 2 = AREA +! CRSDAT 3 = WIDTH + + write(90,'(a)') 'ics',id1,dlin1 NOREACH(IVMIL(N))=NOREACHTMP IF(NRIVL(IVMIL(N)) .GT. MPTS) THEN CALL WMessageBox(0,3,1,'Allowable number of points in a cross-section (75) exceeded'//char(13)//& diff --git a/src/GETTRIANG.F90 b/src/GETTRIANG.F90 index 06f8e7a..64c8c9b 100644 --- a/src/GETTRIANG.F90 +++ b/src/GETTRIANG.F90 @@ -104,7 +104,8 @@ DO J=1,NEDGE IF(IEDGE(J,1) .NE. 0) THEN - CALL FORMT(XMAP1,YMAP1,J,N,NGAP,KK) +!ipk dec17 add wd + CALL FORMT(XMAP1,YMAP1,J,N,NGAP,KK,wd) ENDIF END DO diff --git a/src/INOUT.F90 b/src/INOUT.F90 index 0d054db..0888a57 100644 --- a/src/INOUT.F90 +++ b/src/INOUT.F90 @@ -1702,6 +1702,12 @@ ELSEIF(ID .EQ. 'E4Q') THEN ICOUNT=5 GO TO 90 + ELSEIF(ID .EQ. 'E6T') THEN + ICOUNT=7 + GO TO 90 + ELSEIF(ID .EQ. 'E8Q') THEN + ICOUNT=9 + GO TO 90 ENDIF ENDDO 90 CONTINUE @@ -1723,6 +1729,14 @@ NTMP(4)=0 NTMP(6)=0 NTMP(8)=0 + ELSEIF(ICOUNT .EQ. 7) THEN + READ(DLIN1,*) J, (NTMP(K),K=1,6),NTMP(9) + IF(NTMP(9) .EQ. 0) NTMP(9)=1 + NTMP(7)=0 + NTMP(8)=0 + ELSEIF(ICOUNT .EQ. 9) THEN + READ(DLIN1,*) J, (NTMP(K),K=1,9) + IF(NTMP(9) .EQ. 0) NTMP(9)=1 ENDIF ELSE READ(DLIN1,*) J, (NTMP(K),K=1,9) diff --git a/src/NEWRMGN.F90 b/src/NEWRMGN.F90 index 6f2ccbd..18c7fed 100644 --- a/src/NEWRMGN.F90 +++ b/src/NEWRMGN.F90 @@ -700,8 +700,8 @@ ENDIF INQUIRE (FILE = fname, EXIST = exists) IF (.NOT. exists) THEN - CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'ORG file does not exist!!'//CHAR(13)// & - 'Do you wish to create file and view image','Looking for ORG file') + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Location file does not exist!!'//CHAR(13)// & + 'Do you wish to create file and view image','Looking for location file') ! If answer 'Yes' set ifrmel to 0 ! IF (WInfoDialog(4) .ne. 2) then diff --git a/src/PLOTR1.F90 b/src/PLOTR1.F90 index d3510c9..6adcc20 100644 --- a/src/PLOTR1.F90 +++ b/src/PLOTR1.F90 @@ -1537,14 +1537,24 @@ D2=CORD(NOP(N,1),2) ELSE DIR=ATAN2(DIRX,-DIRY) - D1=CORD(NOP(N,2),1) - D2=CORD(NOP(N,2),2) + IF(NOP(N,2) .NE. 0) THEN + D1=CORD(NOP(N,2),1) + D2=CORD(NOP(N,2),2) + ELSE + D1=(CORD(NOP(N,1),1)+CORD(NOP(N,3),1))/2. + D2=(CORD(NOP(N,1),2)+CORD(NOP(N,3),2))/2. + ENDIF ENDIF - DIR1=DIR+2.35619 - DIR2=DIR-2.35619 + DIR1=DIR+2.35619 + DIR2=DIR-2.35619 IF(IESKP(N) .EQ. 0) THEN - D1=CORD(NOP(N,2),1) - D2=CORD(NOP(N,2),2) + IF(NOP(N,2) .NE. 0) THEN + D1=CORD(NOP(N,2),1) + D2=CORD(NOP(N,2),2) + ELSE + D1=(CORD(NOP(N,1),1)+CORD(NOP(N,3),1))/2. + D2=(CORD(NOP(N,1),2)+CORD(NOP(N,3),2))/2. + ENDIF DE1=D1+0.4*COS(DIR) DE2=D2+0.4*SIN(DIR) DEA1=DE1+0.1*COS(DIR1) diff --git a/src/REFINB.F90 b/src/REFINB.F90 index 72fabb6..28f71a0 100644 --- a/src/REFINB.F90 +++ b/src/REFINB.F90 @@ -592,7 +592,10 @@ !ipk sep99 add test for line element - if(ncn .eq. 3) go to 500 + if(ncn .eq. 3) then + if(nef(i,2) .eq. nop(n,2)) go to 600 + go to 500 + endif ! ! Loop on sides ! @@ -665,7 +668,26 @@ !ipk sep99 add test for line element - if(ncn .eq. 3) go to 500 + if(ncn .eq. 3) then + do i=1,nentry + if(nop(n,2) .eq. nef(i,2)) then + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + nop(nem,1)=nef(I,2) + nop(nem,3)=nef(I,3) + imat(nem)=imat(n) + ncorn(nem)=3 + IESKP(NEM)=0 + IERC=0 + CALL PLTELM(NEM,IERC) + nop(n,2)=0 + nop(n,3)=nef(I,2) + go to 500 + endif + enddo + go to 500 + endif ! ! Loop on sides ! @@ -892,8 +914,10 @@ INTEGER*2 IRGEN DIMENSION NTRAN(9),IRGEN(8,5,5) ! - DATA IRGEN /1,0,2,0,9,0,8,0,3,0,4,0,9,0,2,0,5,0,6,0,9,0,4,0, & - & 7,0,8,0,9,0,6,0,8*0, & +! DATA IRGEN /1,0,2,0,9,0,8,0,3,0,4,0,9,0,2,0,5,0,6,0,9,0,4,0, & +! & 7,0,8,0,9,0,6,0,8*0, & + DATA IRGEN /1,0,2,0,9,0,8,0,2,0,3,0,4,0,9,0,9,0,4,0,5,0,6,0, & + & 8,0,9,0,6,0,7,0,8*0, & & 1,0,2,0,7,8,0,0,3,4,5,0,2,0,0,0,5,6,7,0,2,0,0,0,16*0, & & 1,0,2,0,7,8,0,0,3,0,4,0,2,0,0,0,5,6,7,0,4,0,0,0, & & 7,0,2,0,4,0,0,0,8*0, & @@ -948,7 +972,7 @@ ! DO 300 N=1,4 IF(ITGEN(1,N,NTYP) .EQ. 0) GO TO 310 - CALL GETELM(NEM) + CALL GETELM(NEM) NEUNDO=NEUNDO+1 IELDEL(NEUNDO)=NEM DO 250 K=1,7,2 diff --git a/src/RMAGENV83e.rc b/src/RMAGENV83e.rc index 8486c40..9076675 100644 --- a/src/RMAGENV83e.rc +++ b/src/RMAGENV83e.rc @@ -8,7 +8,7 @@ // // Winteracter resource script. // -// Modified : 03/Mar/2017 13:04:04 +// Modified : 19/Oct/2017 10:30:12 // /////////////////////////////////////////////////// // @@ -413,6 +413,10 @@ #define IDF_GREEN 1036 #define IDF_BLUE 1038 #define IDD_DIALOG002 169 +#define ID_ADDSLOT 40150 +#define IDF_CANCEL 1088 +#define IDD_ADDSLOT 171 +#define ID_ADDBEDLEV 40151 /////////////////////////////////////////////////// // @@ -2208,6 +2212,30 @@ BEGIN ,0 END +IDD_ADDSLOT DIALOG 0, 0, 160, 139 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "ADD SLOT TO 1-D" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 17, 40, 14 + CONTROL "Type Number",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 18, 74, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 20, 107, 40, 14 + CONTROL "Cancel",IDF_CANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 100, 107, 40, 14 + CONTROL "Slot Depth",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 40, 74, 14 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 40, 40, 14 + CONTROL "Slot Range",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 60, 74, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 60, 40, 14 + CONTROL "Slot Porosity",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 80, 74, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 80, 40, 14 +END + +IDD_ADDSLOT RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + /////////////////////////////////////////////////// // // Menus @@ -2385,6 +2413,7 @@ BEGIN MENUITEM "Fill a Gap Between Elements", ID_FILLAGAP MENUITEM "Set Type by Level", ID_SETTYPLEV MENUITEM "Form a complex line of elements", ID_Complex + MENUITEM "Add bed levels from cross-sections", ID_ADDBEDLEV MENUITEM "Interpolate Map File for Stress File", ID_GETSTRESSFIL MENUITEM "Smooth Map Contours", ID_SMOOTHMAP MENUITEM "Smooth Mesh Using Reversal", ID_RVSDIAG @@ -2395,6 +2424,7 @@ BEGIN MENUITEM "Re-Show Element Loads", ID_RESHOWELTLD MENUITEM "Save Element Load File", ID_SAVELTLD MENUITEM "Form Elements from Map File", ID_FILLTR + MENUITEM "Add Slot to 1-D Sections", ID_ADDSLOT END MENUITEM "E&xit", ID_EXIT END diff --git a/src/RMAGENV83e.res b/src/RMAGENV83e.res index 82e9228..165b772 100644 Binary files a/src/RMAGENV83e.res and b/src/RMAGENV83e.res differ diff --git a/src/SYMBL.F90 b/src/SYMBL.F90 index 4278653..e60cdb2 100644 --- a/src/SYMBL.F90 +++ b/src/SYMBL.F90 @@ -975,6 +975,8 @@ ELSE N1=NOP(IELEM,1) N2=NOP(IELEM,3) +!ipk dec17 + if(ncorn(ielem) .eq. 2) n2=nop(ielem,2) IF(IPW1 .EQ. 1) THEN wd11=width(n1)/txscal wd2=width(n2)/txscal diff --git a/src/src83e/ADD999.F90 b/src/src83e/ADD999.F90 new file mode 100644 index 0000000..905ee4e --- /dev/null +++ b/src/src83e/ADD999.F90 @@ -0,0 +1,487 @@ + SUBROUTINE ADD999(ISWT9,NELC) + +! add type 999 elements to all 1-d elements + + USE BLK1MOD + USE BLK2MOD + COMMON ISEQ(4000,10),LIST1(2000),LIST2(2000) + INCLUDE 'TXFRM.COM' + + IF(.NOT. ALLOCATED(IUSEDM)) THEN + ALLOCATE (IUSEDM(MAXE)) + IUSEDM=0 + ENDIF + IF(.NOT. ALLOCATED(HSET)) THEN + ISWTH=0 + ELSE + ISWTH=1 + ENDIF +! loop on elements looking for 1-d + PI2=3.14159/2. + + NTEMPLC=0 + NCM=MAXECON + NCMi=MAXECON + IUSEDM=0 + DO N=1,NE + IF(IMAT(N) .NE. 999) CYCLE + CALL KCON(0) + GO TO 75 + ENDDO + GO TO 90 + 75 CONTINUE + DO N=1,NE + IF(IMAT(N) .EQ. 999) THEN + DO J=1,NCMi + IF(NCORN(ICON(N,J)) .EQ. 3) THEN + M=ICON(N,J) + IF(NOP(M,1) .EQ. NOP(N,1) .AND. NOP(M,3) .EQ. NOP(N,3) .OR.& + NOP(M,1) .EQ. NOP(N,3) .AND. NOP(M,3) .EQ. NOP(N,1)) THEN + IUSEDM(ICON(N,J))=1 + GO TO 80 + ENDIF + ENDIF + ENDDO + ENDIF + 80 CONTINUE + ENDDO +90 n=1 + ICL=0 + do k=1,10 + iseqp=2000 + iseqm=2000 + do ns=n,ne + if(imat(ns) .eq. 0 .or. (imat(ns) .ge. 900 .and. imat(ns) .lt. 2000)) cycle + if(ncorn(ns) .gt. 3) cycle + if(IUSEDM(ns) .eq. 1) cycle +! renumber elements to put them in order + N=NS + N1=NOP(NS,1) + N3=NOP(NS,3) + iseq(iseqp,k)=ns + IUSEDM(n)=1 + go to 100 + enddo + go to 200 + 100 continue +! search for element connected to n1 or n3 + do m=1,ne + if(imat(ns) .eq. 0 .or. (imat(ns) .ge. 900 .and. imat(ns) .lt. 2000)) cycle +! if(imat(m) .gt. 0 .and. imat(m) .lt. 900) then + if(ncorn(m) .lt. 4) then + if(IUSEDM(m) .eq. 1) cycle + if(nop(m,1) .eq. n3) then + IUSEDM(m)=1 + iseqp=iseqp+1 + iseq(iseqp,k)=m +! n1=nop(m,1) + n3=nop(m,3) + n=m + go to 100 + elseif(nop(m,1) .eq. n1) then + nop(m,1)=nop(m,3) + nop(m,3)=n1 + IUSEDM(m)=1 + iseqm=iseqm-1 + iseq(iseqm,k)=m + n1=nop(m,1) +! n3=nop(m,3) + n=m + go to 100 + elseif(nop(m,3) .eq. n1) then + IUSEDM(m)=1 + iseqm=iseqm-1 + iseq(iseqm,k)=m + n1=nop(m,1) +! n3=nop(m,3) + n=m + go to 100 + elseif(nop(m,3) .eq. n3) then + nop(m,3)=nop(m,1) + nop(m,1)=n3 + IUSEDM(m)=1 + iseqp=iseqp+1 + iseq(iseqp,k)=m +! n1=nop(m,1) + n3=nop(m,3) + n=m + go to 100 + endif + endif +! endif + enddo + enddo +200 continue +! do n=990,1005 +! write(150,*) n,(iseq(n,m),m=1,5) +! enddo + NETEMP=NE + + do k=1,10 + nss=0 + do ns=1,4000 + if(iseq(ns,k) .eq. 0) cycle + n=iseq(ns,k) + N1=NOP(N,1) + N2=NOP(N,2) + N3=NOP(N,3) + + if(nss .eq. 0) then + ELDIR=ATAN2(YUSR(N3)-YUSR(N1),XUSR(N3)-XUSR(N1)) + CALL GETNOD(J1) + INEW(J1) = 1 + INSKP(J1) =0 + IF(ISWTH .EQ. 1) THEN + WD(J1)=HSET(N1,3) + ELSE + WD(J1)=-9999. + ENDIF + CALL GETNOD(J2) + INEW(J2) = 1 + INSKP(J2) =0 + IF(ISWTH .EQ. 1) THEN + WD(J2)=HSET(N1,1) + ELSE + WD(J2)=-9999. + ENDIF + +! XUSR(J1)=+WIDTHD(N1)/2.*COS(ELDIR-PI2)+XUSR(N1) +! YUSR(J1)=+WIDTHD(N1)/2.*SIN(ELDIR-PI2)+YUSR(N1) + XUSR(J1)=+WIDTH(N1)/2.*COS(ELDIR-PI2)+XUSR(N1) + YUSR(J1)=+WIDTH(N1)/2.*SIN(ELDIR-PI2)+YUSR(N1) + CORD(J1,1)=(XUSR(J1)+XS)/TXSCAL + CORD(J1,2)=(YUSR(J1)+YS)/TXSCAL + IF(ISWT9 .EQ. 2) THEN + WD(J1)=WD(N1) + ENDIF + nnn=iseq(ns+1,k) + if(nnn .eq. 0) then + ELDIR=ATAN2(YUSR(N3)-YUSR(N1),XUSR(N3)-XUSR(N1)) + else + n4=nop(nnn,3) + ELDIR=ATAN2(YUSR(N4)-YUSR(N1),XUSR(N4)-XUSR(N1)) + endif +! XUSR(J2)=+WIDTHD(N1)/2.*COS(ELDIR+PI2)+XUSR(N1) +! YUSR(J2)=+WIDTHD(N1)/2.*SIN(ELDIR+PI2)+YUSR(N1) + XUSR(J2)=+WIDTH(N1)/2.*COS(ELDIR+PI2)+XUSR(N1) + YUSR(J2)=+WIDTH(N1)/2.*SIN(ELDIR+PI2)+YUSR(N1) + CORD(J2,1)=(XUSR(J2)+XS)/TXSCAL + CORD(J2,2)=(YUSR(J2)+YS)/TXSCAL + IF(ISWT9 .EQ. 2) THEN + WD(J2)=WD(N1) + ENDIF + nss=1 + else + nnn=iseq(ns+1,k) + if(nnn .eq. 0) then + ELDIR=ATAN2(YUSR(N3)-YUSR(N1),XUSR(N3)-XUSR(N1)) + else + n4=nop(nnn,3) + ELDIR=ATAN2(YUSR(N4)-YUSR(N1),XUSR(N4)-XUSR(N1)) + endif + endif + N0=N1 +! get two node numbers and store in ntempc + CALL GETNOD(J3) + INEW(J3) = 1 + INSKP(J3) =0 + IF(ISWTH .EQ. 1) THEN + WD(J3)=HSET(N3,3) + ELSE + WD(J3)=-9999. + ENDIF + CALL GETNOD(J4) + INEW(J4) = 1 + INSKP(J4) =0 + IF(ISWTH .EQ. 1) THEN + WD(J4)=HSET(N3,1) + ELSE + WD(J4)=-9999. + ENDIF + IF(J4 .GT. NP) NP=J4 + nn= imat(n) + if(nn .gt. 1999) then +! XUSR(J3)=+WIDTHD(N3)/2.*COS(ELDIR-PI2)+XUSR(N3) +! YUSR(J3)=+WIDTHD(N3)/2.*SIN(ELDIR-PI2)+YUSR(N3) +! XUSR(J4)=+WIDTHD(N3)/2.*COS(ELDIR+PI2)+XUSR(N3) +! YUSR(J4)=+WIDTHD(N3)/2.*SIN(ELDIR+PI2)+YUSR(N3) + XUSR(J3)=+WIDTH(N3)/2.*COS(ELDIR-PI2)+XUSR(N3) + YUSR(J3)=+WIDTH(N3)/2.*SIN(ELDIR-PI2)+YUSR(N3) + XUSR(J4)=+WIDTH(N3)/2.*COS(ELDIR+PI2)+XUSR(N3) + YUSR(J4)=+WIDTH(N3)/2.*SIN(ELDIR+PI2)+YUSR(N3) + ELSEIF(KID(nn,1) .NE. 0) THEN + JR2=KID(IMAT(N),2) + JR1=KID(IMAT(N),3) + JR4=KID(IMAT(N),4) + JR3=KID(IMAT(N),5) + XUSR(J1)=XUSR(JR1) + YUSR(J1)=YUSR(JR1) + XUSR(J2)=XUSR(JR2) + YUSR(J2)=YUSR(JR2) + XUSR(J3)=XUSR(JR3) + YUSR(J3)=YUSR(JR3) + XUSR(J4)=XUSR(JR4) + YUSR(J4)=YUSR(JR4) +! nop(n-1,7)=jr3 + ELSE +! XUSR(J3)=+WIDTHD(N3)/2.*COS(ELDIR-PI2)+XUSR(N3) +! YUSR(J3)=+WIDTHD(N3)/2.*SIN(ELDIR-PI2)+YUSR(N3) +! XUSR(J4)=+WIDTHD(N3)/2.*COS(ELDIR+PI2)+XUSR(N3) +! YUSR(J4)=+WIDTHD(N3)/2.*SIN(ELDIR+PI2)+YUSR(N3) + XUSR(J3)=+WIDTH(N3)/2.*COS(ELDIR-PI2)+XUSR(N3) + YUSR(J3)=+WIDTH(N3)/2.*SIN(ELDIR-PI2)+YUSR(N3) + XUSR(J4)=+WIDTH(N3)/2.*COS(ELDIR+PI2)+XUSR(N3) + YUSR(J4)=+WIDTH(N3)/2.*SIN(ELDIR+PI2)+YUSR(N3) + ENDIF + + CORD(J3,1)=(XUSR(J3)+XS)/TXSCAL + CORD(J3,2)=(YUSR(J3)+YS)/TXSCAL + CORD(J4,1)=(XUSR(J4)+XS)/TXSCAL + CORD(J4,2)=(YUSR(J4)+YS)/TXSCAL + IF(ISWT9 .EQ. 2) THEN + WD(J3)=WD(N3) + WD(J4)=WD(N3) + ENDIF +350 CONTINUE + CALL GETELM(I3) +! RECORD IN LIST FOR FUTURE + ICL=ICL+1 + LIST1(ICL)=I3 + LIST2(I3)=icl + NCORN(I3) = 8 + IESKP(I3) = 0 + NOP(I3,1)=J1 + NOP(I3,3)=J3 + NOP(I3,5)=N3 + NOP(I3,6)=N2 + NOP(I3,7)=N1 + IF(ISWT9 .EQ. 0) THEN + IMAT(I3)=999 + ELSE + IMAT(I3)=IMAT(N) + ENDIF + CALL GETELM(I4) +! RECORD IN LIST FOR FUTURE + ICL=ICL+1 + LIST1(ICL)=I4 + LIST2(I4)=-icl + NCORN(I4) = 8 + IESKP(I4) = 0 + IF(I4 .GT. NETEMP) NETEMP=I4 + IMAT(I4)=999 + NOP(I4,1)=J4 + NOP(I4,2)= 0 + NOP(I4,3)=J2 + NOP(I4,5)=N1 + NOP(I4,6)=N2 + NOP(I4,7)=N3 + IF(ISWT9 .EQ. 0) THEN + IMAT(I4)=999 + ELSE + IMAT(I4)=IMAT(N) + CALL DELTEL(N) + ENDIF + J2=J4 + J1=J3 + ENDDO + enddo + NE=NETEMP + ICLM=ICL + NELCT=2 +400 CONTINUE + CALL FILM(1) + call KCON(0) + + do n=1,ne + + if(imat(n) .eq. 2000) then + nm=nop(n,4) + if(necon(nm,1) .eq. n) then + nat=necon(nm,2) + else + nat=necon(nm,1) + endif + if(list2(n) .gt. 0) then + nm=nop(n,4) + if(necon(nm,1) .eq. n) then + nat=necon(nm,2) + else + nat=necon(nm,1) + endif + n1=nop(nat,7) + n2=nop(nat,1) + j1=nop(n,5) + j2=nop(n,7) + j3=nop(n,1) + j4=nop(n,3) + else + nm=nop(n,8) + if(necon(nm,1) .eq. n) then + nat=necon(nm,2) + else + nat=necon(nm,1) + endif + n1=nop(nat,3) + n2=nop(nat,5) + j1=nop(n,1) + j2=nop(n,3) + j3=nop(n,5) + j4=nop(n,7) + endif + xusr(j1)=xusr(n1) + yusr(j1)=yusr(n1) + cord(j1,1)=cord(n1,1) + cord(j1,2)=cord(n1,2) + xusr(j2)=xusr(n1) + yusr(j2)=yusr(n1) + cord(j2,1)=cord(n1,1) + cord(j2,2)=cord(n1,2) + xusr(j3)=xusr(n2) + yusr(j3)=yusr(n2) + cord(j3,1)=cord(n2,1) + cord(j3,2)=cord(n2,2) + xusr(j4)=xusr(n2) + yusr(j4)=yusr(n2) + cord(j4,1)=cord(n2,1) + cord(j4,2)=cord(n2,2) + elseif(imat(n) .eq. 2001) then + if(list2(n) .gt. 0) then + nm=nop(n,8) + if(necon(nm,1) .eq. n) then + nat=necon(nm,2) + else + nat=necon(nm,1) + endif + n1=nop(nat,5) + n2=nop(nat,3) + j1=nop(n,5) + j2=nop(n,7) + j3=nop(n,1) + j4=nop(n,3) + else + nm=nop(n,4) + if(necon(nm,1) .eq. n) then + nat=necon(nm,2) + else + nat=necon(nm,1) + endif + n1=nop(nat,1) + n2=nop(nat,7) + j1=nop(n,1) + j2=nop(n,3) + j3=nop(n,5) + j4=nop(n,7) + endif + xusr(j1)=xusr(n1) + yusr(j1)=yusr(n1) + cord(j1,1)=cord(n1,1) + cord(j1,2)=cord(n1,2) + xusr(j2)=xusr(n1) + yusr(j2)=yusr(n1) + cord(j2,1)=cord(n1,1) + cord(j2,2)=cord(n1,2) + xusr(j3)=xusr(n2) + yusr(j3)=yusr(n2) + cord(j3,1)=cord(n2,1) + cord(j3,2)=cord(n2,2) + xusr(j4)=xusr(n2) + yusr(j4)=yusr(n2) + cord(j4,1)=cord(n2,1) + cord(j4,2)=cord(n2,2) + endif + enddo + 450 CALL DELETM(0) + IF(NELC .LE. NELCT) THEN + do n=1,ne + if(imat(n) .gt. 1000) then + CALL DELTEL(n) + endif + enddo + RETURN + ENDIF + DO I=1,ICLM,2 + NEL=LIST1(I) + IF(IMAT(NEL) .EQ. 0) CYCLE + IF(I .GT. 1) THEN + J3=J4 + ELSE + CALL GETNOD(J3) + XUSR(J3)=(XUSR(NOP(NEL,7))+XUSR(NOP(NEL,1)))/2. + YUSR(J3)=(YUSR(NOP(NEL,7))+YUSR(NOP(NEL,1)))/2. + CORD(J3,1)=(XUSR(J3)+XS)/TXSCAL + CORD(J3,2)=(YUSR(J3)+YS)/TXSCAL + WD(J3)=(WD(NOP(NEL,1))+WD(NOP(NEL,7)))/2. + INEW(J3) = 1 + INSKP(J3) =0 + IF(J3 .GT. NP) NP=J3 + ENDIF + + CALL GETNOD(J4) + XUSR(J4)=(XUSR(NOP(NEL,3))+XUSR(NOP(NEL,5)))/2. + YUSR(J4)=(YUSR(NOP(NEL,3))+YUSR(NOP(NEL,5)))/2. + CORD(J4,1)=(XUSR(J4)+XS)/TXSCAL + CORD(J4,2)=(YUSR(J4)+YS)/TXSCAL + WD(J4)=(WD(NOP(NEL,3))+WD(NOP(NEL,5)))/2. + INEW(J4) = 1 + INSKP(J4) =0 + IF(J4 .GT. NP) NP=J4 + CALL GETELM(I3) +! RECORD IN LIST FOR FUTURE + ICL=ICL+1 + LIST1(ICL)=I3 + NCORN(I3) = 8 + IESKP(I3) = 0 + IF(I3 .GT. NETEMP) NETEMP=I3 + NOP(I3,5)=J4 + NOP(I3,7)=J3 + NOP(I3,1)=NOP(NEL,1) + NOP(I3,3)=NOP(NEL,3) + NOP(NEL,1)=J3 + NOP(NEL,3)=J4 + IMAT(I3)=IMAT(NEL) + + NEL=LIST1(I+1) + IF(IMAT(NEL) .EQ. 0) CYCLE + IF(I .GT. 1) THEN + J3A=J4A + ELSE + CALL GETNOD(J3A) + XUSR(J3A)=(XUSR(NOP(NEL,3))+XUSR(NOP(NEL,5)))/2. + YUSR(J3A)=(YUSR(NOP(NEL,3))+YUSR(NOP(NEL,5)))/2. + CORD(J3A,1)=(XUSR(J3A)+XS)/TXSCAL + CORD(J3A,2)=(YUSR(J3A)+YS)/TXSCAL + WD(J3A)=(WD(NOP(NEL,3))+WD(NOP(NEL,5)))/2. + INEW(J3A) = 1 + INSKP(J3A) =0 + IF(J3A .GT. NP) NP=J3A + ENDIF + CALL GETNOD(J4A) + XUSR(J4A)=(XUSR(NOP(NEL,1))+XUSR(NOP(NEL,7)))/2. + YUSR(J4A)=(YUSR(NOP(NEL,1))+YUSR(NOP(NEL,7)))/2. + CORD(J4A,1)=(XUSR(J4A)+XS)/TXSCAL + CORD(J4A,2)=(YUSR(J4A)+YS)/TXSCAL + WD(J4A)=(WD(NOP(NEL,1))+WD(NOP(NEL,7)))/2. + INEW(J4A) = 1 + INSKP(J4A) =0 + IF(J4A .GT. NP) NP=J4A + CALL GETELM(I3) +! RECORD IN LIST FOR FUTURE + ICL=ICL+1 + LIST1(ICL)=I3 + NCORN(I3) = 8 + IESKP(I3) = 0 + IF(I3 .GT. NETEMP) NETEMP=I3 + NOP(I3,1)=J4A + NOP(I3,3)=J3A + NOP(I3,5)=NOP(NEL,5) + NOP(I3,7)=NOP(NEL,7) + NOP(NEL,5)=J3A + NOP(NEL,7)=J4A + IMAT(I3)=IMAT(NEL) + + ENDDO + NELCT=NELCT*2 + GO TO 450 +! RETURN + END + \ No newline at end of file diff --git a/src/src83e/ADDLAY.F90 b/src/src83e/ADDLAY.F90 new file mode 100644 index 0000000..fad4044 --- /dev/null +++ b/src/src83e/ADDLAY.F90 @@ -0,0 +1,343 @@ +! Last change: IPK 12 Jan 98 11:21 am +! +!**************************************************************** +! + SUBROUTINE ADDLAY +! +! Add nodal layer data and write to file +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 IFLAG,ANSW(10) + REAL RLAY(9) + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ +! + 4 CONTINUE + + call openlay + + NHTP=0 + NBRR=0 + NMESS=45 + CALL HEDR + NMESS=4 + xprt=3.2 +! + IPOS=ILAYTP + call GETLAYDAT(NLAY,ipos,RLAY) + ILAYTP=IPOS +! call getint(nlay) +! READ(*,*) NLAY +! +! Write out current layers +! + 7 CONTINUE + NHTP=0 + NMESS=0 + NBRR=4 + CALL HEDR + CALL RCYAN + DO 10 K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .GT. 5) THEN + DO 9 N=1,NCORN(K),2 + J=NOP(K,N) + FPN = LAY(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.0) THEN + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + ENDIF + 9 CONTINUE + ENDIF + ENDIF + 10 END DO + CALL RBLUE +! +! Input new layers +! + 5 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + + IF(IRMAIN .EQ. 1) THEN + REWIND 102 + DO J=1,NP + IF(LAY(J) .GT. -9998) THEN + if(ILAYTP .eq. 1) then + write(102,6000) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + 6000 format('LD2 ',2i8,9F8.2) + else + write(102,6001) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + 6001 format('LD3 ',2i8,9F8.2) + endif + ENDIF + ENDDO + RETURN + ENDIF +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 4 + ELSEIF(IFLAG .EQ. 'q') THEN + NLAYD=1 + REWIND 102 + DO J=1,NP + IF(LAY(J) .GT. -9998) THEN + if(ILAYTP .eq. 1) then + write(102,6000) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + else + write(102,6001) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + endif + ENDIF + ENDDO + CALL WRTOUT(0) + RETURN + ENDIF +! + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.2,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + LAY(INODE) = NLAY + DO J=1,7 + WTLAY(INODE,J)=RLAY(J) + ENDDO + FPN = NLAY + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + CALL RBLUE +! + ELSEIF(IFLAG .EQ. 'a') THEN + DO 100 K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .GT. 5) THEN + DO 90 N=1,NCORN(K),2 + J=NOP(K,N) + DO I=1,7 + WTLAY(J,I)=RLAY(I) + ENDDO + LAY(J)=NLAY + FPN=NLAY + X = CORD(J,1) + Y = CORD(J,2) + .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.0) THEN + CALL RRED + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + CALL RBLUE + ENDIF + 90 CONTINUE + ENDIF + ENDIF + 100 CONTINUE + NLAYD=1 + CALL WRTOUT(0) + ELSEIF(IFLAG .EQ. 'f') THEN + DO 120 K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .GT. 5) THEN + DO 110 N=1,NCORN(K),2 + J=NOP(K,N) + IF(LAY(J) .EQ. -9999.) THEN + LAY(J)=NLAY + DO I=1,7 + WTLAY(J,I)=RLAY(I) + ENDDO + FPN=NLAY + X = CORD(J,1) + Y = CORD(J,2) + .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.0) THEN + CALL RRED + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + CALL RBLUE + ENDIF + ENDIF + 110 CONTINUE + ENDIF + ENDIF + 120 CONTINUE + NLAYD=1 + CALL WRTOUT(0) +! + ELSE +!ipk jan98 WRITE(*,*) CHAR(7),CHAR(7) + ENDIF +! + GOTO 5 +! + END + subroutine openlay + use winteracter + + implicit none + + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + LOGICAL :: OPENED + INTEGER :: IERR + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INQUIRE(102, OPENED=OPENED) + if(.not. opened) then + CALL WSelectFile(ID_STRING9,SaveDialog+PromptOn,FNAME,'Save layer file') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='lay' + CALL ADDSUB(FNAME,SUB) + open(102,file=fname, form='formatted', status='unknown') + ENDIF + endif + + RETURN + END + + SUBROUTINE RDLAYER +! +! Read nodal layer data +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*8 ID + CHARACTER*72 DLIN + DIMENSION WTTEMP(7) + +! + 100 CONTINUE + READ(103,7000,END=400) ID,DLIN + 7000 FORMAT(A8,A72) + IF(ID(1:2) .EQ. 'LD') THEN + READ(DLIN,5000) NODNUM,NLAYD,(WTTEMP(I),I=1,7) + 5000 FORMAT(2I8,7F8.0) + IF(NODNUM .EQ. 0) THEN + DO N=0,NP + LAY(N)=NLAYD + IF(NLAYD .GT. 0) THEN + DO I=0,NLAYD + WTLAY(N,I)=WTTEMP(I) + ENDDO + ENDIF + ENDDO + ELSEIF(NODNUM .GT. 0) THEN + LAY(NODNUM)=NLAYD + IF(NLAYD .GT. 0) THEN + DO I=1,NLAYD + WTLAY(NODNUM,I)=WTTEMP(I) + ENDDO + ENDIF + + ENDIF + ENDIF + IF(ID(3:3) .EQ. '2') THEN + ILAYTP=1 + ELSE + ILAYTP=0 + ENDIF + GO TO 100 + 400 CONTINUE + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + NCN=NCORN(K) + IF(NCN .EQ. 5) NCN=3 + DO N=1,NCORN(K),2 + J=NOP(K,N) + FPN=LAY(N) + X = CORD(J,1) + Y = CORD(J,2) + .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.0) THEN + CALL RRED + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + CALL RBLUE + ENDIF + ENDDO + ENDIF + ENDDO + RETURN + END + + SUBROUTINE WRTLAYER + use winteracter + +! +! Read nodal layer data +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*8 ID + CHARACTER*72 DLIN + DIMENSION WTTEMP(7) + LOGICAL :: OPENED + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INQUIRE(102, OPENED=OPENED) + if(.not. opened) then + CALL WSelectFile(ID_STRING9,SaveDialog+PromptOn,FNAME,'Save layer file') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='lay' + CALL ADDSUB(FNAME,SUB) + open(102,file=fname, form='formatted', status='unknown') + ENDIF + else + rewind 102 + endif + + DO J=0,NP + IF(LAY(J) .GT. -9998) THEN + if(j .gt. 0) then + if(lay(j) .ne. lay(0)) then + go to 300 + else + do i=1,lay(j) + if(wtlay(j,i) .ne. wtlay(0,i)) then + go to 300 + endif + enddo + endif + go to 500 + 300 continue + if(ILAYTP .eq. 1) then + write(102,6000) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + 6000 format('LD2 ',2i8,9F8.2) + else + write(102,6001) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + 6001 format('LD3 ',2i8,9F8.2) + endif + else + if(ILAYTP .eq. 1) then + write(102,6000) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + else + write(102,6001) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + endif + endif + ENDIF + 500 CONTINUE + ENDDO + RETURN + END diff --git a/src/src83e/ADDQUAD.F90 b/src/src83e/ADDQUAD.F90 new file mode 100644 index 0000000..a273dae --- /dev/null +++ b/src/src83e/ADDQUAD.F90 @@ -0,0 +1,192 @@ + SUBROUTINE ADDQUAD + +! Subroutine to add a quadrilateral block + + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + INCLUDE 'TXFRM.COM' + + CHARACTER*1 IFLAG + + DATA N1,N2,N3,N4/1,1,1,1/ + +! Initiliaze list etc + + NHTPSV=NHTP + NMESSSV=NMESS + NBRRSV=NBRR + + DO N=1,NP + LIST(N)=0 + ENDDO +! Get the points that form the triangle + + 4 CONTINUE + NHTP=0 + NMESS=8 + NBRR = 3 + CALL HEDR +! +! Get screen coordinates of each end of line +! + 7 CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ALX=XTEMP + ALY=YTEMP + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + CALL WRTOUT(0) + RETURN + elseif(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + ENDIF +! +! Exit input +! +! 9 CALL PLOTT(XTEMP,YTEMP,3) +! CALL PLOTT(XTEMP,YTEMP,2) + NBRR=0 + CALL HEDR + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ARX=XTEMP + ARY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! + CALL PLOTT(ALX,ALY,3) + CALL PLOTT(XTEMP,YTEMP,2) + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + BRX=XTEMP + BRY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! + 16 CONTINUE +! CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + BLX=XTEMP + BLY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! + 20 CONTINUE +! CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + CALL PLOTT(ALX,ALY,2) + +! Get the number of element information + + CALL PANELQUAD(N1,N2,N3,N4) + +! Get number For 1 and 3 and 2 and 4 + + NMID1=(N1+N3)/2 + NMID2=(N2+N4)/2 + +! Form the new nodes + + CALL DEFNOD(ALX,ALY) + CALL DEFNOD(ARX,ARY) + CALL DEFNOD(BRX,BRY) + CALL DEFNOD(BLX,BLY) + +! Now work on sides + + DO N=1,N1-1 + RATIO=FLOAT(N)/FLOAT(N1) + X1=ALX+RATIO*(ARX-ALX) + Y1=ALY+RATIO*(ARY-ALY) + CALL DEFNOD(X1,Y1) + ENDDO + DO N=1,N2-1 + RATIO=FLOAT(N)/FLOAT(N2) + X1=ARX+RATIO*(BRX-ARX) + Y1=ARY+RATIO*(BRY-ARY) + CALL DEFNOD(X1,Y1) + ENDDO + DO N=1,N3-1 + RATIO=FLOAT(N)/FLOAT(N3) + X1=BRX+RATIO*(BLX-BRX) + Y1=BRY+RATIO*(BLY-BRY) + CALL DEFNOD(X1,Y1) + ENDDO + DO N=1,N4-1 + RATIO=FLOAT(N)/FLOAT(N4) + X1=BLX+RATIO*(ALX-BLX) + Y1=BLY+RATIO*(ALY-BLY) + CALL DEFNOD(X1,Y1) + ENDDO + CALL FRMNODQ(ALX,ALY,ARX,ARY,BRX,BRY,BLX,BLY,NMID1,NMID2) + +! Form triangles for the added nodes + + CALL DELN2(NP,1) + + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + + RETURN + END + + SUBROUTINE PANELQUAD(N1,N2,N3,N4) + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,N4,IERR +! real :: + character*3 :: sub + + call wdialogload(IDD_QUAD) + ierr=infoerror(1) + + CALL WDialogPutInteger(idf_integer1,n1) + CALL WDialogPutInteger(idf_integer2,n2) + CALL WDialogPutInteger(idf_integer3,n3) + CALL WDialogPutInteger(idf_integer4,n4) + + + CALL WDialogSelect(IDD_QUAD) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(idf_integer1,n1) + CALL WDialogGetInteger(idf_integer2,n2) + CALL WDialogGetInteger(idf_integer3,n3) + CALL WDialogGetInteger(idf_integer4,n4) + + + ENDIF + RETURN + END diff --git a/src/src83e/ADDTRIANG.F90 b/src/src83e/ADDTRIANG.F90 new file mode 100644 index 0000000..9694a10 --- /dev/null +++ b/src/src83e/ADDTRIANG.F90 @@ -0,0 +1,191 @@ + SUBROUTINE ADDTRIANG + +! Subroutine to add a triangular block + + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + INCLUDE 'TXFRM.COM' + + CHARACTER*1 IFLAG + + DATA N1,N2,N3/1,1,1/ + +! Initiliaze list etc + + NHTPSV=NHTP + NMESSSV=NMESS + NBRRSV=NBRR + + DO N=1,NP + LIST(N)=0 + ENDDO +! Get the points that form the triangle + + 4 CONTINUE + NHTP=0 + NMESS=8 + NBRR = 3 + CALL HEDR +! +! Get screen coordinates of each end of line +! + 7 CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ALX=XTEMP + ALY=YTEMP + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + CALL WRTOUT(0) + RETURN + elseif(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + ENDIF +! +! Exit input +! +! 9 CALL PLOTT(ALX,ALY,3) +! CALL PLOTT(ALX,ALY,2) + NBRR=0 + CALL HEDR + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ARX=XTEMP + ARY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! +! 12 CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(ALX,ALY,3) + CALL PLOTT(XTEMP,YTEMP,2) + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + BRX=XTEMP + BRY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! + 16 CONTINUE + ! CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + CALL PLOTT(ALX,ALY,2) + +! Get the number of element information + + CALL PANELTRG(N1,N2,N3) + +! Get middle number + + IF(N1 .GT. N2) THEN + IF(N1 .GT. N3) THEN + IF(N2 .GT. N3) THEN + NMID=N2 + ELSE + NMID=N1 + ENDIF + ELSE + NMID=N1 + ENDIF + ELSE + IF(N2 .GT. N3) THEN + IF(N1 .GT. N3) THEN + NMID=N1 + ELSE + NMID=N3 + ENDIF + ELSE + NMID=N2 + ENDIF + ENDIF + +! Form the new nodes + + CALL DEFNOD(ALX,ALY) + CALL DEFNOD(ARX,ARY) + CALL DEFNOD(BRX,BRY) + +! Now work on sides + + DO N=1,N1-1 + RATIO=FLOAT(N)/FLOAT(N1) + X1=ALX+RATIO*(ARX-ALX) + Y1=ALY+RATIO*(ARY-ALY) + CALL DEFNOD(X1,Y1) + ENDDO + DO N=1,N2-1 + RATIO=FLOAT(N)/FLOAT(N2) + X1=ARX+RATIO*(BRX-ARX) + Y1=ARY+RATIO*(BRY-ARY) + CALL DEFNOD(X1,Y1) + ENDDO + DO N=1,N3-1 + RATIO=FLOAT(N)/FLOAT(N3) + X1=BRX+RATIO*(ALX-BRX) + Y1=BRY+RATIO*(ALY-BRY) + CALL DEFNOD(X1,Y1) + ENDDO + CALL FRMNODT(ALX,ALY,ARX,ARY,BRX,BRY,NMID) + +! For triangles for the added nodes + + CALL DELN2(NP,1) + + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + + RETURN + END + + SUBROUTINE PANELTRG(N1,N2,N3) + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR +! real :: + character*3 :: sub + + call wdialogload(IDD_TRIANG) + ierr=infoerror(1) + + CALL WDialogPutInteger(idf_integer1,n1) + CALL WDialogPutInteger(idf_integer2,n2) + CALL WDialogPutInteger(idf_integer3,n3) + + + CALL WDialogSelect(IDD_TRIANG) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(idf_integer1,n1) + CALL WDialogGetInteger(idf_integer2,n2) + CALL WDialogGetInteger(idf_integer3,n3) + + + ENDIF + RETURN + END diff --git a/src/src83e/ADDWID.F90 b/src/src83e/ADDWID.F90 new file mode 100644 index 0000000..abfd900 --- /dev/null +++ b/src/src83e/ADDWID.F90 @@ -0,0 +1,464 @@ +!IPK LAST UPDATE JULY 18 1998 MAJOR CHANGES +! Last change: IPK 12 Jan 98 11:22 am +!ipk jan98 delete old call to char(7) +!**************************************************************** +! + SUBROUTINE ADDWID +! +! Add nodal width data +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 IFLAG,ANSW(10),ANSW1(10) + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + DATA ANSW1/ 'w','1','2','d','e','s','b','z','r','q'/ +! + 4 CONTINUE + NHTP=13 + NMESS=0 + NBRR=0 +!ipk apr95 add call to flushwn + call flushwn + CALL HEDR + 102 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW1(IBOX) + ENDIF + IF(IFLAG .EQ. 'w') THEN +! +! get width +! + 104 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = WIDTH(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=5 + xprt=3.2 + call getfpn(cwid) +! +! Input new widths +! + 105 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 104 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + WIDTH(INODE) = CWID + FPN = WIDTH(INODE) + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 105 + elseif(iflag .eq. '1') then +! +! get ss1 +! + 204 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = ss1(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=22 + xprt=3.2 + call getfpn(ss1tp) +! +! Input new ss1 +! + 205 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 204 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + SS1(INODE) = SS1TP + FPN = SS1TP + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 205 + elseif(iflag .eq. '2') then +! +! get ss2 +! + 304 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = ss2(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=23 + xprt=3.2 + call getfpn(ss2tp) +! +! Input new ss2 +! + 305 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 304 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + SS2(INODE) = SS2TP + FPN = SS2TP + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 305 + elseif(iflag .eq. 'd') then +! +! get storage width +! + 404 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = wids(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=24 + xprt=3.2 + call getfpn(wids1tp) +! +! Input new storgae width +! + 405 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 404 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + WIDS(INODE) = wids1TP + FPN = wids1TP + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 405 + elseif(iflag .eq. 'e') then +! +! get storage elevation +! + 504 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = widbs(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=39 + xprt=3.2 + call getfpn(widbs1tp) +! +! Input new storage elevations +! + 505 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 504 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + WIDBS(INODE) = widbs1TP + FPN = widbs1tp + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 505 + elseif(iflag .eq. 's') then +! +! get storage slopes +! + 604 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = sso(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=40 + xprt=3.2 + call getfpn(widslp) +! +! Input new storage slopes +! + 605 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 604 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + SSO(INODE) = widslp + FPN = widslp + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 605 +!ipk mar02 +! +! get bed slopes +! + elseif(iflag .eq. 'b') then + 704 continue + call plotot(1) + CALL RCYAN + DO K=1,NE + IF(IMAT(K) .GT. 0) THEN + IF(NCORN(K) .LT. 6) THEN + IF(NCORN(K) .GT. 2 .AND. IMAT(K) .LT. 900) THEN + DO N=1,3,2 + J=NOP(K,N) + FPN = BS1(J) + X = CORD(J,1) + Y = CORD(J,2) - .11 + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + enddo + ENDIF + ENDIF + ENDIF + enddo + CALL RBLUE + nmess=45 + nhtp=0 + nbrr=4 + call flushwn + CALL HEDR + nmess=44 + xprt=3.2 + call getfpn(bedslp) +! +! Input new bed slopes +! + 705 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'n') THEN + GO TO 704 + ELSEIF(IFLAG .EQ. 'q') THEN + CALL WRTOUT(0) + go to 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= INODE + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + BS1(INODE) = bedslp + FPN = bedslp + X = CORD(INODE,1) + Y = CORD(INODE,2) + .11 + CALL RRED + CALL NUMBR(X,Y,0.20,FPN,0.0,-1) + CALL RBLUE + endif + go to 705 + + elseif(iflag .eq. 'q') then + return + endif + go to 4 + END diff --git a/src/src83e/AREA.F90 b/src/src83e/AREA.F90 new file mode 100644 index 0000000..2cbf190 --- /dev/null +++ b/src/src83e/AREA.F90 @@ -0,0 +1,457 @@ +!IPK LAST UPDATE JULY 7 2016 ADD TEST FOR ZERO WIDTH + SUBROUTINE CHKAREA + + USE WINTERACTER + USE BLK1MOD + include 'd.inc' +! INCLUDE 'BLK1.COM' + + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + + dimension itran(0:16) + data itran/0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16/ + + DATA I1,I2,I3,I4/1,0,0,0/,EMAX/-1./ + + WRITE(90,*) 'GOING TO CHKOPT' + CALL GETCHOPT(I1,I2,I3,I4,EREF,WIDEL) + WRITE(90,*) I1 + IF(I1 .LT. 0) THEN + I1=1 + I2=0 + RETURN + ENDIF + IF(I1 .EQ. 1) THEN +! and see if all corner nodes exist +! +! Test for areas of each element +! + INEG = 0 +!IPK JUL16 + IERW=0 + DO 250 N=1,NE + IF(IMAT(N) .GT. 0 .AND. NCORN(N) .GT. 5) THEN + J1=NOP(N,1) + J2=NOP(N,3) + J3=NOP(N,5) + if(cord(j1,1) .lt. -1.e9 .or. cord(j2,1) .lt. -1.e9 .or. cord(j3,1) .lt. -1.e9) then + WRITE(90,*) ' NODE UNDEFINED FOR ELEMENT NUMBER',N + CALL DELTEL(N) + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Element removed','ELEMENT REMOVED') + GO TO 250 + ENDIF + AREA=(CORD(J2,1)-CORD(J1,1))*(CORD(J3,2)-CORD(J1,2))- & + & (CORD(J3,1)-CORD(J1,1))*(CORD(J2,2)-CORD(J1,2)) + IF(AREA .LT. 0.) THEN + WRITE(90,*) ' NEGATIVE AREA FOR ELEMENT NUMBER',N + INEG = 1 + GO TO 250 + ENDIF + IF(NCORN(N) .EQ. 8) THEN + J1=NOP(N,3) + J2=NOP(N,5) + J3=NOP(N,7) + if(cord(j1,1) .lt. -1.e9 .or. cord(j2,1) .lt. -1.e9 .or. cord(j3,1) .lt. -1.e9) then + WRITE(90,*) ' NODE UNDEFINED FOR ELEMENT NUMBER',N + CALL DELTEL(N) + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Element removed','ELEMENT REMOVED') + GO TO 250 + ENDIF + AREA=(CORD(J2,1)-CORD(J1,1))*(CORD(J3,2)-CORD(J1,2))- & + & (CORD(J3,1)-CORD(J1,1))*(CORD(J2,2)-CORD(J1,2)) + IF(AREA .LT. 0.) THEN + WRITE(90,*) ' NEGATIVE AREA FOR ELEMENT NUMBER',N + INEG = 1 + ENDIF + ENDIF +!IPK JUL16 ADD TEST FOR MISSING WIDTH + ELSEIF(IMAT(N) .GT. 0) THEN + IF(WIDTH(NOP(N,1)) .EQ. 0. .OR. WIDTH(NOP(N,3)) .EQ. 0) THEN + IF(IERW .EQ. 0) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Nodal width missing in 1-D element'//Char(13)//& + 'See file MESSGEN.OUT for details' ,'WARNING 1-D WIDTH MISSING') + write(90,6000) + write(90,6001) n,nop(n,1),width(nop(n,1)),nop(n,3),width(nop(n,3)) +6000 FORMAT(' NODAL WIDTH MISSING FOR 1-D ELEMENT'/' ELEMENT NODE1 WIDTH1 NODE2 WIDTH2') +6001 FORMAT(I8,2(I10,F10.2)) + IERW=1 + ELSE + write(90,6001) n,nop(n,1),width(nop(n,1)),nop(n,3),width(nop(n,3)) + ENDIF + ENDIF + ENDIF + 250 END DO + + IF(INEG .EQ. 1) THEN +!cipk aug00 + + Call WMessageBox(3,2,1,'Negative Areas have been found'//Char(13)//& + 'See file MESSGEN.OUT for details'//'Press YES to set positive',& + 'ERROR IN NETWORK AREAS!!') + + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then +! +! Test for areas of each element +! + INEG=0 + DO 300 N=1,NE + IF(IMAT(N) .GT. 0 .AND. NCORN(N) .GT. 5) THEN + J1=NOP(N,1) + J2=NOP(N,3) + J3=NOP(N,5) + AREA=(CORD(J2,1)-CORD(J1,1))*(CORD(J3,2)-CORD(J1,2))- & + & (CORD(J3,1)-CORD(J1,1))*(CORD(J2,2)-CORD(J1,2)) + IF(AREA .LT. 0.) THEN + if(NCORN(N) .EQ. 6) THEN + JM12=NOP(N,2) + JM23=NOP(N,4) + JM31=NOP(N,6) + NOP(N,2)=JM31 + NOP(N,3)=J3 + NOP(N,4)=JM23 + NOP(N,5)=J2 + NOP(N,6)=JM12 + GO TO 300 + ELSEIF(NCORN(N) .EQ. 8) THEN + INEG=1 + ENDIF + ENDIF + IF(NCORN(N) .EQ. 8) THEN + J1=NOP(N,3) + J2=NOP(N,5) + J3=NOP(N,7) + AREA=(CORD(J2,1)-CORD(J1,1))*(CORD(J3,2)-CORD(J1,2))- & + & (CORD(J3,1)-CORD(J1,1))*(CORD(J2,2)-CORD(J1,2)) + IF(AREA .LT. 0.) THEN + IF(INEG .EQ. 1) THEN + J0=NOP(N,1) + JM01=NOP(N,2) + JM12=NOP(N,4) + JM23=NOP(N,6) + JM30=NOP(N,8) + NOP(N,2)=JM30 + NOP(N,3)=J3 + NOP(N,4)=JM23 + NOP(N,5)=J2 + NOP(N,6)=JM12 + NOP(N,7)=J1 + NOP(N,8)=JM01 + ELSE + WRITE(90,*) ' CROSS OVER NEGATIVE AREA FOR ELEMENT NUMBER',N + Call WMessageBox(3,2,1,'cross-over element diagonals have been found'//Char(13)//& + 'See file MESSGEN.OUT for details'//'Press YES to set delete',& + 'ERROR IN NETWORK AREAS!!') + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then + CALL DELTEL(N) + ENDIF + ENDIF + ENDIF + ENDIF + ENDIF + 300 END DO + ENDIF + ENDIF + ENDIF +! CARRY OUT TEST FOR ELEMENT ELEVATION DIFFERENCES + IF(I2 .EQ. 1) THEN + EMAX=0. + DO N=1,NE + EDIF(N)=0 + IF(IMAT(N) .LE. 0) GO TO 400 + IF(NCORN(N) .GT. 5) THEN + DO M=1,NCORN(N)-1,2 + DO MM=M,NCORN(N)-1,2 + EDIF(N)=MAX(ABS(WD(NOP(N,M))-WD(NOP(N,MM))),EDIF(N)) + ENDDO + ENDDO + ELSE + IF(I4 .EQ. 0) THEN + EDIF(N)=ABS(WD(NOP(N,3))-WD(NOP(N,1))) + ELSE + if(icrin .eq. 0) then + CALL WMessageBox(0, 4, 1,'Cross-section data not loaded '//CHAR(13)// & + 'Click OK start again','ERROR GETTING NO SECTION DATA') + RETURN + endif + N1=NOP(N,1) + N2=NOP(N,3) + BT1= & + CRSDAT(NRIVCR1(N1),1,1)*WTRIVCR1(N1)+ & + CRSDAT(NRIVCR2(N1),1,1)*WTRIVCR2(N1) + BT2= & + CRSDAT(NRIVCR1(N2),1,1)*WTRIVCR1(N2)+ & + CRSDAT(NRIVCR2(N2),1,1)*WTRIVCR2(N2) + H1=WIDEL-BT1 + H2=WIDEL-BT2 + IF(H1 .LT. 0. .OR. H2 .LT. 0.) THEN + CALL WMessageBox(1, 4, 1,'Depth negative '//CHAR(13)// & + 'Click OK to continue with depth=1.'//CHAR(13)//'Click Cancel to start again','ERROR GETTING SECTION DATA') + if(WInfoDialog(4) .eq. 0) then + RETURN + else + IF(H1 .LT. 0.) H1=1.0 + IF(H2 .LT. 0.) H2=1.0 + endif + ENDIF + CALL INTERPWLV(N1,H1,AR1,WR1,DWR1) + CALL INTERPWLV(N2,H2,AR2,WR2,DWR2) + IF(I4 .EQ. 1) THEN + EDIF(N)=ABS(WR1-WR2) + ELSE + EDIF(N)=ABS(AR1-AR2) + ENDIF + ENDIF + ENDIF + IF(EDIF(N) .GT. EMAX) EMAX=EDIF(N) + 400 CONTINUE + ENDDO + NUMV=11 + CONTUR(1)=0. + DO K=2,11 + CONTUR(K)=EMAX/10.+CONTUR(K-1) + ENDDO + + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + ICOL=EDIF(N)*10./EMAX+.999 + icll=itran(icol) + CALL FILLEMC(N,ICLL) + ENDIF + ENDDO + XLEG=8.8 + YLEG=7.4 + + CALL LEGND(XLEG,YLEG,CONTUR,NUMV,NUMCOL) + + ENDIF + EDIF(0)=EMAX + CALL WMenuSetState(ID_SECGRP,ItemEnabled,1) + IF(I2 .EQ. 1) RETURN +! CARRY OUT TEST FOR ELEMENT NORMAILZED DEPTH DIFFERENCES + IF(I3 .EQ. 1) THEN + EMAX=0. + DO N=1,NE + EDIF(N)=0 + IF(IMAT(N) .LE. 0) GO TO 500 + IF(NCORN(N) .GT. 5) THEN + DO M=1,NCORN(N)-1,2 + DO MM=M,NCORN(N)-1,2 + D1=EREF-WD(NOP(N,M)) + D2=EREF-WD(NOP(N,MM)) + if(d1 .lt. 0.0) d1=0.0 + if(d2 .lt. 0.0) d2=0.0 + DMEAN=(D1+D2)/2. + if(DMEAN .LE. 1.) DMEAN=1.0 + EDIF(N)=MAX(ABS(D1-D2)/DMEAN,EDIF(N)) + ENDDO + ENDDO + ELSE + IF(I4 .EQ. 0) THEN + D1=EREF-WD(NOP(N,1)) + D2=EREF-WD(NOP(N,3)) + IF(D1 .LT. 0. .OR. D2 .LT. 0.) THEN + CALL WMessageBox(1, 4, 1,'Depth negative '//CHAR(13)// & + 'Click OK to continue with depth=1.'//CHAR(13)//'Click Cancel to start again','ERROR GETTING SECTION DATA') + if(WInfoDialog(4) .eq. 0) then + RETURN + else + IF(D1 .LT. 0.) D1=1.0 + IF(D2 .LT. 0.) D2=1.0 + endif + ENDIF + + DMEAN=(D1+D2)/2. + if(DMEAN .LE. 1.) DMEAN=1.0 + EDIF(N)=ABS(D1-D2)/DMEAN + ELSE + if(icrin .eq. 0) then + CALL WMessageBox(0, 4, 1,'Cross-section data not loaded '//CHAR(13)// & + 'Click OK start again','ERROR GETTING NO SECTION DATA') + RETURN + endif + N1=NOP(N,1) + N2=NOP(N,3) + BT1= & + CRSDAT(NRIVCR1(N1),1,1)*WTRIVCR1(N1)+ & + CRSDAT(NRIVCR2(N1),1,1)*WTRIVCR2(N1) + BT2= & + CRSDAT(NRIVCR1(N2),1,1)*WTRIVCR1(N2)+ & + CRSDAT(NRIVCR2(N2),1,1)*WTRIVCR2(N2) + H1=WIDEL-BT1 + H2=WIDEL-BT2 + IF(H1 .LT. 0. .OR. H2 .LT. 0.) THEN + CALL WMessageBox(1, 4, 1,'Depth negative '//CHAR(13)// & + 'Click OK to continue with depth=1.'//CHAR(13)//'Click Cancel to start again','ERROR GETTING SECTION DATA') + if(WInfoDialog(4) .eq. 0) then + RETURN + else + IF(H1 .LT. 0.) H1=1.0 + IF(H2 .LT. 0.) H2=1.0 + endif + ENDIF + CALL INTERPWLV(N1,H1,AR1,WR1,DWR1) + CALL INTERPWLV(N2,H2,AR2,WR2,DWR2) + IF(I4 .EQ. 1) THEN + EDIF(N)=ABS(WR1-WR2)*2./(WR1+WR2) + ELSE + EDIF(N)=ABS(AR1-AR2)*2./(AR1+AR2) + ENDIF + ENDIF + + ENDIF + IF(EDIF(N) .GT. EMAX) EMAX=EDIF(N) + 500 CONTINUE + ENDDO + NUMV=11 + CONTUR(1)=0. + DO K=2,11 + CONTUR(K)=EMAX/10.+CONTUR(K-1) + ENDDO + + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + ICOL=EDIF(N)*10./EMAX+.999 + icll=itran(icol) + CALL FILLEMC(N,ICLL) + ENDIF + ENDDO + XLEG=8.8 + YLEG=7.4 + + CALL LEGND(XLEG,YLEG,CONTUR,NUMV,NUMCOL) + + ENDIF + EDIF(0)=EMAX + CALL WMenuSetState(ID_SECGRP,ItemEnabled,1) + FLUSH(90) + IF(I3 .EQ. 1) RETURN + + CALL PLOTOT(0) + CALL HEDR + RETURN + END + + + SUBROUTINE GETCHOPT(I1,I2,I3,I4,EREF,WIDEL) +! +! Generate continuity lines +! + + USE WINTERACTER + include 'd.inc' + SAVE + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: I1,I2,I3,I4,I4A,ITIME,IPOS + + REAL :: WIDEL + + REAL :: EREF + + data itime/0/ + + IF(ITIME .EQ. 0) THEN + EREF=0. + WIDEL=0. + itime=1. + I4=0 + ENDIF + + call wdialogload(IDD_CHKOPT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_CHKOPT) + ierr=infoerror(1) + + I4A=I4 + IF(I4 .GT. 0) I4A=1 + call wdialogputCheckBox(idf_check1,I1) + call wdialogputCheckBox(idf_check2,I4A) + if(i2 .eq. 1) then + CALL WDialogPutRadioButton(IDF_RADIO1) + elseif(i3 .eq. 1) then + CALL WDialogPutRadioButton(IDF_RADIO2) + endif + CALL WDialogPutReal(IDF_REAL1,EREF) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialogGetCheckBox(idf_check1,I1) + call wdialogGetCheckBox(idf_check2,I4A) + call wdialogGetRadioButton(idf_radio1,IPOS) + IF(IPOS .EQ. 1) THEN + I2=1 + I3=0 + ELSEIF(IPOS .EQ. 2) THEN + I2=0 + I3=1 + ELSE + I2=0 + I3=0 + ENDIF + CALL WDialoggetReal(IDF_REAL1,EREF) + GO TO 100 + + ELSEIF(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + I1=-1 + I2=0 + I3=0 + WRITE(90,*) 'CANCEL',I1,I2,I3,I4A + return + ENDIF + + enddo + 100 CONTINUE + WRITE(90,*) 'IN CHKOPT',I1,I2,I3,I4A + + IF(I4A .NE. 0) THEN + call wdialogload(IDD_CHK1DOPT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_CHK1DOPT) + ierr=infoerror(1) + + if(i4 .le. 1) then + CALL WDialogPutRadioButton(IDF_RADIO1) + elseif(i4 .eq. 2) then + CALL WDialogPutRadioButton(IDF_RADIO2) + endif + CALL WDialogPutReal(IDF_REAL1,WIDEL) + + CALL WDialogShow(-1,-1,0,Modal) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialogGetRadioButton(idf_radio1,I4) + CALL WDialogGetReal(IDF_REAL1,WIDEL) + + WRITE(90,*) 'OUT OF CHKOPT',I1,I2,I3,I4A + return + + ELSEIF(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + + I4=0 + I4A=0 + + ENDIF + + enddo + + ENDIF + WRITE(90,*) 'OUT OF CHKOPT',I1,I2,I3,I4A + return + end + \ No newline at end of file diff --git a/src/src83e/ASSIGNEQ.f90 b/src/src83e/ASSIGNEQ.f90 new file mode 100644 index 0000000..497f782 --- /dev/null +++ b/src/src83e/ASSIGNEQ.f90 @@ -0,0 +1,33 @@ + SUBROUTINE ASSIGNEQ + + USE BLK1MOD + USE BLKELTLD + COMMON XCEN(5000),YCEN(5000) + DIST(I,J)=(XYCEL(I,1)-XCEN(J))**2+(XYCEL(I,2)-YCEN(J))**2 + VOID=1.E20 + +! get centroids of mesh + XCEN=VOID + YCEN=VOID + DO J=1,NE + CALL GETXCL(J,XCJ,YCJ) + XCEN(J)=XCJ + YCEN(J)=YCJ + ENDDO + +! test for nearest centroid + DO I=1,NQHYD + NCLINE(I)=0 + DISTM=VOID + DO J=1,NE + IF(XCEN(J) .GE. VOID) CYCLE + IF(DIST(I,J) .LT. DISTM) THEN + DISTM=DIST(I,J) + NCLINE(I)=J + ENDIF + ENDDO + WRITE(103,6001) NCLINE(I),ILAYRE(1,NQHYD),HAE(1,I),(HDE(1,I,K),K=1,3) +6001 FORMAT('EFE',5X,2I8,7X,'1',F8.3,3F8.2,7X,'1') + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/src83e/BFILES.I90 b/src/src83e/BFILES.I90 new file mode 100644 index 0000000..3e14d2f --- /dev/null +++ b/src/src83e/BFILES.I90 @@ -0,0 +1,9 @@ + INTEGER :: NBKFL,ISWBKFL,IACTVFIL,ITOTFIL,I3DVIEW,IRDONE + REAL :: BFMINMAX + CHARACTER(LEN=255) :: BFNAME,BFNAMR,FNAMKEP,DIRECT + CHARACTER(LEN=48) :: FNAMEDISP + COMMON /BFLSI/ NBKFL,ISWBKFL(10),I3DVIEW,IRDONE + COMMON /BFLSR/ BFMINMAX(10,4) + COMMON /BFLSC/ BFNAME(10),BFNAMR(10),FNAMKEP,DIRECT,FNAMEDISP + CHARACTER(LEN=255) :: FNAMEOUT + COMMON /RSTOR/ IACTVFIL,ITOTFIL,FNAMEOUT(10) diff --git a/src/src83e/BLK1.f90 b/src/src83e/BLK1.f90 new file mode 100644 index 0000000..539c563 --- /dev/null +++ b/src/src83e/BLK1.f90 @@ -0,0 +1,123 @@ + MODULE BLK1MOD + + INCLUDE 'PARAM.COM' +! BLK1 +!- + REAL HSIZE + COMMON /SSIZE/ HSIZE + + INTEGER MAXP,MAXE,MAXLIN,MAXSTO,MAXECON,MAXLN,MAELN + + + INTEGER*2 INSKP,IESKP,INEW,NCORN,IJUN,ISWTAGN,iswtintp +!IPK MAY02 INTEGER*2 NOP,IMAT,IEM,NEF,NEFLAG,LINTYP,LAY + INTEGER*2 IMAT,LINTYP,LAY,IRTYP + INTEGER*4 NOP,IEM,NEF,NEFLAG,ILINEL +! REAL*8 CORD,XUSR,YUSR,XC,YC,CMAP,XMAP,YMAP,pscale,xref,yref + REAL*8 CORD,XUSR,YUSR,XC,YC,pscale,xref,yref + REAL*8 ALXX,ALYY,ALWD,BLXX,BLYY,BLWD,XBRLEN,CNX,CNY,WIDTHD,HLEFT,HMID,HRIGHT,HSET + + INTEGER*2 MSN + ALLOCATABLE MSN(:) + + + ALLOCATABLE CORD(:,:),XUSR(:),YUSR(:),XC(:),YC(:),IRTYP(:)& + ,NOP(:,:),IMAT(:),THTA(:),IMATL(:),CORDSN(:,:)& + ,WD(:) ,WD1(:),INSKP(:), IESKP(:),NCORN(:)& + ,WIDTH(:), SS1(:), SS2(:), WIDS(:)& + ,IJUN(:),INEW(:),IEM(:),LINTYP(:),NEFLAG(:),NEF(:,:),LAY(:),WTLAY(:,:)& + ,WIDBS(:),SSO(:),NODDEL(:),IELDEL(:)& + ,NOPSV(:,:),nefsv(:,:),IMATSV(:),LOCK(:),BS1(:),NKEY1(:),EDIF(:),ANGOP(:)& + ,IGRPNUM(:,:),MAXENT(:),IGRPSER(:),IUSEDM(:),IOD(:)& + ,ALXX(:),ALYY(:),BLXX(:),BLYY(:),ALWD(:),BLWD(:),ITYPBC(:),CNX(:,:),CNY(:,:),XBRLEN(:)& + ,HLEFT(:),HMID(:),HRIGHT(:),HSET(:,:),WIDTHD(:) + ALLOCATABLE NRF(:),AREF(:),LEVREM(:),TRANSEL(:),WLEN(:),WHGT(:) + INTEGER*8 MAXPTS + COMMON /BLK/ MAXPTS,PSCALE,xref,yref& + , IPNN, IPEN, XMIN, YMIN, XMAX, YMAX, NLAYD,ILAYTP& + ,VOID, VDX, XSCALE, YSCALE,AMAP,IRESTT& + ,NXPMIN, NYPMIN, NXPMAX, NYPMAX, IPP& + ,XPMIN, YPMIN, XPMAX, YPMAX, WDSCAL,IESW& + ,NPLAST,NELAST,NEFL,NENTRY,IECHG,ICHG& + ,IIN, IBAK, LUNIT,IGIN,IS11,IMP,IGFG,ISWAP,ITRIAN& + ,klint,jlint,lmpnam,IDELV,nmapf,NSIGF,NPUNDO,NEUNDO,nefsav,nesav& + ,xadded,yadded,icolsw,rad,colint,ielvsw,ISWTAGN,iswtintp,eref,igrp,igrpout,MAXIGRP& + ,JPTSB,ILINEL +!IPK MAR02 ADD BS1 +!IPK FEB02 ADD LOCK +!IPK MAY01 ADD NODDEL AND IELDEL +!IPK JUL98 WIDBS AND SSO ADDED +!IPK JAN98 IDELV ADDED +!ipk feb94 line above added, two lines changed may 94 to add xref,yref +! 9 ,LINTYP(MAXLIN),NEFLAG(150),NEF(600,3),LAY(MAXP) +! +!IPK MAR04 INTEGER*2 ILIST,LLIST + INTEGER*4 ILIST,LLIST + + ALLOCATABLE ILIST(:,:),LLIST(:) + COMMON /BLK1/ NLST, ICCLN(140,350),NCLM +! + CHARACTER*80 TITLE + CHARACTER*24 HLABL +!ipk feb94 add + character*40 mpnam +!ipk dec97 line above modified + + CHARACTER*1 ALABL(10) + COMMON /BLKA1/ TITLE,HLABL,ALABL,MPNAM +!ipk dec97 line above modified +! +!IPK JAN01 INCREASE IPSW TO 10 + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout +!ycw mar97 add + COMMON /CROSS/ ICRS,XPCS(2),YPCS(2),NCSNOD,XCND(50),YCND(50),& + NCSPTS,XELVP(50),YELVP(50),ZELVP(50),SELVP(50),& + ZREF,DFACTOR,ZMIN,IXNOD,LCROSS& + ,IVMIL(MCRS),NRIVL(MCRS),NOREACH(MCRS)& + ,CRSDAT(MCRS,MPTS,3),NCRSEC,XCRS(MCRS),YCRS(MCRS) + + ALLOCATABLE NRIVCR1(:),WTRIVCR1(:),NRIVCR2(:),WTRIVCR2(:) + +!NRIVCR1(MAXP),WTRIVCR1(MAXP)& +! ,NRIVCR2(MAXP),WTRIVCR2(MAXP), + + LOGICAL LCROSS + + COMMON /UNITS/IOT,IOT1 + + COMMON /INTERPL/ IGRID(MAXGRD,MAXGRD),NX,NY,XGRID,YGRID + + real*8 xusrsto,yusrsto + INTEGER*2 IMATSTO + + ALLOCATABLE xusrsto(:,:),yusrsto(:,:),wdsto(:,:),& + WIDTHsto(:,:), SS1sto(:,:), SS2sto(:,:), WIDSsto(:,:)& + ,WIDBSsto(:,:),SSOsto(:,:),bs1sto(:,:)& + ,nopsto(:,:,:),imatsto(:,:),thtasto(:,:) + +! loaded/ xusrsto(maxp,maxsto),yusrsto(maxp,maxsto),wdsto(maxp,maxsto),& +! WIDTHsto(MAXP,maxsto), SS1sto(MAXP,maxsto), SS2sto(MAXP,maxsto), WIDSsto(MAXP,maxsto)& +! ,WIDBSsto(MAXP,maxsto),SSOsto(MAXP,maxsto),bs1sto(maxp,maxsto)& +! ,nopsto(maxe,8,maxsto),imatsto(maxe,maxsto),thtasto(maxe,maxsto) + + ALLOCATABLE ICCLNSTO(:,:,:)& + ,NPSTO(:),NESTO(:),NLSTSTO(:),NCLMSTO(:) + + + INTEGER*4 ILISTSTO,LLISTSTO + ALLOCATABLE ILISTSTO(:,:,:),LLISTSTO(:,:) + + COMMON /TMPLIST/ ilisttmp(100),INREORD + + ALLOCATABLE ICN(:) + + ALLOCATABLE ICONNCT(:,:),NKEP(:) + + ALLOCATABLE IOUTLST(:,:),NOUTLST(:),XOUT(:,:),YOUT(:,:) + + COMMON /VIEWS/ HANG,VANG,VRTSCAL,HANGOLD,VANGOLD,VRTORIG,IASPCT + + INTEGER KID(900,5) + + + END MODULE \ No newline at end of file diff --git a/src/src83e/BLK1OLD.COM b/src/src83e/BLK1OLD.COM new file mode 100644 index 0000000..ce4fbc1 --- /dev/null +++ b/src/src83e/BLK1OLD.COM @@ -0,0 +1,85 @@ + + + INCLUDE 'PARAM.COM' +! BLK1 +!- + REAL HSIZE + COMMON /SSIZE/ HSIZE + + + INTEGER*2 INSKP,IESKP,INEW,NCORN,IJUN,ISWTAGN,iswtintp +!IPK MAY02 INTEGER*2 NOP,IMAT,IEM,NEF,NEFLAG,LINTYP,LAY + INTEGER*2 IMAT,LINTYP,LAY + INTEGER*4 NOP,IEM,NEF,NEFLAG +! REAL*8 CORD,XUSR,YUSR,XC,YC,CMAP,XMAP,YMAP,pscale,xref,yref + REAL*8 CORD,XUSR,YUSR,XC,YC,pscale,xref,yref +! + COMMON /BLK/ CORD(MAXP,2),XUSR(MAXP),YUSR(MAXP),XC(MAXP),YC(MAXP)& + ,PSCALE,xref,yref& + , IPNN, IPEN, XMIN, YMIN, XMAX, YMAX, NLAYD,ILAYTP& + ,VOID, VDX, XSCALE, YSCALE,AMAP,IRESTT& + ,NXPMIN, NYPMIN, NXPMAX, NYPMAX, IPP& + ,XPMIN, YPMIN, XPMAX, YPMAX, WDSCAL,IESW& + ,MAXPTS,NPLAST,NELAST,NEFL,NENTRY,IECHG,ICHG& + ,NOP(MAXE,8),IMAT(MAXE),THTA(MAXE),IMATL(MAXE),CORDSN(MAXP,2)& + ,WD(MAXP) ,WD1(MAXP) ,INSKP(MAXP), IESKP(MAXE)& + ,NCORN(MAXP),IIN, IBAK, LUNIT,IGIN,IS11,IMP,IGFG,ISWAP,ITRIAN& + ,WIDTH(MAXP), SS1(MAXP), SS2(MAXP), WIDS(MAXP)& + ,IJUN(MAXP),INEW(MAXP),IEM(MAXE)& + ,LINTYP(MAXLIN),NEFLAG(MAXP),NEF(MAXP,3),LAY(0:MAXP+1),WTLAY(0:MAXP,9)& + ,klint,jlint,lmpnam,IDELV& + ,WIDBS(MAXP),SSO(MAXP),nmapf,NSIGF,NODDEL(MAXP),IELDEL(MAXE)& + ,NPUNDO,NEUNDO,NOPSV(MAXE,8),nesav,nefsv(maxp,3),nefsav,IMATSV(MAXE)& + ,LOCK(MAXP),xadded,yadded,BS1(MAXP),icolsw,rad,colint,ielvsw,ISWTAGN,iswtintp +!IPK MAR02 ADD BS1 +!IPK FEB02 ADD LOCK +!IPK MAY01 ADD NODDEL AND IELDEL +!IPK JUL98 WIDBS AND SSO ADDED +!IPK JAN98 IDELV ADDED +!ipk feb94 line above added, two lines changed may 94 to add xref,yref +! 9 ,LINTYP(MAXLIN),NEFLAG(150),NEF(600,3),LAY(MAXP) +! +!IPK MAR04 INTEGER*2 ILIST,LLIST + INTEGER*4 ILIST,LLIST + COMMON /BLK1/ ILIST(MAXLN,MAELN),LLIST(MAXLN),NLST& + , ICCLN(50,350),NCLM +! + CHARACTER*80 TITLE + CHARACTER*24 HLABL +!ipk feb94 add + character*40 mpnam +!ipk dec97 line above modified + + CHARACTER*1 ALABL(10) + COMMON /BLKA1/ TITLE,HLABL,ALABL,MPNAM +!ipk dec97 line above modified +! +!IPK JAN01 INCREASE IPSW TO 10 + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout +!ycw mar97 add + COMMON /CROSS/ ICRS,XPCS(2),YPCS(2),NCSNOD,XCND(50),YCND(50),& + NCSPTS,XELVP(50),YELVP(50),ZELVP(50),SELVP(50),& + ZREF,DFACTOR,ZMIN,IXNOD,LCROSS& + ,IVMIL(MCRS),NRIVL(MCRS),NOREACH(MCRS)& + ,CRSDAT(MCRS,MPTS,3),NRIVCR1(MAXP),WTRIVCR1(MAXP)& + ,NRIVCR2(MAXP),WTRIVCR2(MAXP),NCRSEC,XCRS(MCRS),YCRS(MCRS) + LOGICAL LCROSS + + COMMON /UNITS/IOT,IOT1 + + COMMON /INTERPL/ IGRID(MAXGRD,MAXGRD),NX,NY,XGRID,YGRID + + real*8 xusrsto,yusrsto + INTEGER*2 IMATSTO + common /loaded/ xusrsto(maxp,maxsto),yusrsto(maxp,maxsto),wdsto(maxp,maxsto),& + WIDTHsto(MAXP,maxsto), SS1sto(MAXP,maxsto), SS2sto(MAXP,maxsto), WIDSsto(MAXP,maxsto)& + ,WIDBSsto(MAXP,maxsto),SSOsto(MAXP,maxsto),bs1sto(maxp,maxsto)& + ,nopsto(maxe,8,maxsto),imatsto(maxe,maxsto),thtasto(maxe,maxsto)& + ,ICCLNSTO(50,350,MAXSTO)& + ,NPSTO(MAXSTO),NESTO(MAXSTO),NLSTSTO(MAXSTO),NCLMSTO(MAXSTO) + + + INTEGER*4 ILISTSTO,LLISTSTO + COMMON /LOADED2/ ILISTSTO(MAXLN,MAELN,MAXSTO),LLISTSTO(MAXLN,MAXSTO) + + COMMON /TMPLIST/ ilisttmp(100),INREORD \ No newline at end of file diff --git a/src/src83e/BLK2.COM b/src/src83e/BLK2.COM new file mode 100644 index 0000000..740bd0d --- /dev/null +++ b/src/src83e/BLK2.COM @@ -0,0 +1,23 @@ +!IPK LAST UPDATED OCT 18 1996 +! +! BLK2 +! + INTEGER*8 MTSUM,MRSUM,MTSUMSV,MSUM + COMMON /BLKKB4/MTSUM,MRSUM,MTSUMSV(0:100),MSUM + INTEGER ENXT,NCM,NCMI,KNT,NDP,NNEW,MP,NAD,NAE,MLIST,NDELM & + ,LIST,NINC,LNEW,NDROP,NELIM,NITST,NFWSAV,MTSUM1,NSEQ,NFWSV + COMMON /BLKB/ NCM,NCMI,KNT,NDP,NNEW,MP,NAD,NAE & + ,MLIST(MAXE),ENXT(MAXE),NDELM(MAXP),LIST(MAXP) & + ,NINC(MAXP),LNEW(8),NDROP(8),NELIM(MAXE),NITST & + ,NFWS,NFWSAV,mtsum1,NSEQ,NFWSV(0:100) +!IPK MAY94 LINE ABOVE ADDED +! + INTEGER ICON + COMMON /BLKB1/ ICON(MAXE,MAXECON) +! + INTEGER NECON + COMMON /BLKB2/ NECON(MAXP,MAXECON) +! + INTEGER ITRAC,NTRAC + COMMON /BLKB3/ ITRAC(350),NTRAC,JTRAC(350),KTRAC(350) +! \ No newline at end of file diff --git a/src/src83e/BLK2MOD.F90 b/src/src83e/BLK2MOD.F90 new file mode 100644 index 0000000..811cf15 --- /dev/null +++ b/src/src83e/BLK2MOD.F90 @@ -0,0 +1,30 @@ + MODULE BLK2MOD + +!IPK LAST UPDATED OCT 18 1996 +! +! BLK2 +! + INTEGER*8 MTSUM,MRSUM,MTSUMSV,MSUM,MTSUM1 + COMMON /BLKKB4/MTSUM,MRSUM,MTSUMSV(0:100),MSUM + INTEGER ENXT,NCM,NCMI,KNT,NDP,NNEW,MP,NAD,NAE,MLIST,NDELM & + ,LIST,NINC,LNEW,NDROP,NELIM,NITST,NFWSAV,NSEQ,NFWSV + COMMON /BLKB/ mtsum1,NCM,NCMI,KNT,NDP,NNEW,MP,NAD,NAE & + ,LNEW(8),NDROP(8),NITST & + ,NFWS,NFWSAV,NSEQ,NFWSV(0:100) +!IPK MAY94 LINE ABOVE ADDED + + ALLOCATABLE MLIST(:),ENXT(:),NDELM(:),LIST(:) & + ,NINC(:),NELIM(:) + +! + INTEGER ICON + ALLOCATABLE ICON(:,:) +! + INTEGER NECON + ALLOCATABLE NECON(:,:) +! + INTEGER ITRAC,NTRAC,NTRACT + COMMON /BLKB3/ ITRAC(1000),NTRAC,JTRAC(1000),KTRAC(1000) +! + END MODULE + \ No newline at end of file diff --git a/src/src83e/BLKELTLD.F90 b/src/src83e/BLKELTLD.F90 new file mode 100644 index 0000000..eb21fdc --- /dev/null +++ b/src/src83e/BLKELTLD.F90 @@ -0,0 +1,6 @@ + MODULE BLKELTLD + REAL DYE,TAE,HAE,XYCEL + INTEGER NCLINE,NEST,IYDATE,NHYE,IQUENIT,IBINEL,NQHYD,NQP,IRMATYP + ALLOCATABLE DYE(:,:),TAE(:,:),HAE(:,:),NCLINE(:),NEST(:),IYDATE(:),NHYE(:),ILAYRE(:,:),HDE(:,:,:),XYCEL(:,:) + + END \ No newline at end of file diff --git a/src/src83e/BLKMAP.COM b/src/src83e/BLKMAP.COM new file mode 100644 index 0000000..a7b70e2 --- /dev/null +++ b/src/src83e/BLKMAP.COM @@ -0,0 +1,14 @@ + + PARAMETER (MAXPL=500000,MAXELMP=50000) + + REAL*8 XCEN,YCEN,RADS,MAP,XMAP,YMAP,CMAP + + COMMON /MAPBLK/ NOPEL(MAXELMP,3),XCEN(MAXELMP),YCEN(MAXELMP)& + ,RADS(MAXELMP) ,NKEY(MAXELMP),IEDGE(500,2),IGAP(500),CMAP(MAXPL,2)& + ,XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL),NELFM(500) + + + COMMON /MAPINFO/ NELTS + + common /mapc/imap(maxpl),NCRS(MAXPL) + diff --git a/src/src83e/BRKDWN.F90 b/src/src83e/BRKDWN.F90 new file mode 100644 index 0000000..3f5039b --- /dev/null +++ b/src/src83e/BRKDWN.F90 @@ -0,0 +1,856 @@ +!ipk lsdt update nov 10 1995 + SUBROUTINE BRKDWN(NCN,NELNO) +! SUBROUTINE BRKDWN(X,Y,VL,NCN) + SAVE + DOUBLE PRECISION XN,XLN,YLN,XLP,YLP + PARAMETER (NTB=100) +! +! Routine to subdivide quadrilaterals and triangles for plotting +! +!ipkoct93 COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + COMMON /PLTC/IPSAV,IFLG,XLL,YLL + LOGICAL SWITCH +! +! DIMENSION X(10),Y(10),VL(10) + COMMON /BRK/ X(10),Y(10),VL(10),DL(10),VLM(10) + DIMENSION IQ(3,8),RIX(3,8),RIY(3,8) + DIMENSION IT(3,4),ZIX(3,4),ZIY(3,4) + DIMENSION IST(3,3) + DIMENSION CX(3,NTB),CY(3,NTB),VAL(3,NTB),XLC(3,NTB),YLC(3,NTB) + DIMENSION ISPLT(3),XP(6),YP(6),VP(6),XLP(6),YLP(6) + DATA IQ / 1, 2, 9, 2, 3, 4, 2, 4, 9, 4, 5, 9,& + 1, 9, 8, 8, 9, 6, 8, 6, 7, 9, 5, 6/ + DATA RIX/ -1.,0.,0., 0.,1.,1., 0.,1.,0., 1.,1.,0.,& + -1.,0.,-1., -1.,0.,0., -1.,0.,-1., 0.,1.,0./ + DATA RIY/ -1.,-1.,0., -1.,-1.,0., -1.,0.,0., 0.,1.,0.,& + -1.,0.,0., 0.,0.,1., 0.,1.,1., 0.,1.,1./ + DATA IT / 1, 2, 6, 3, 4, 2, 5, 6, 4, 2, 4, 6/ + DATA ZIX/0.,.5,0., 1.,.5,.5, 0.,0.,.5, .5,.5,0./ + DATA ZIY/0.,0.,.5, 0.,.5,0., 1.,.5,.5, 0.,.5,.5/ + DATA IST/ 1,4,5, 4,2,5, 1,5,3/ +! DATA XCSQ/1.0/ +! +! Distance function squared +! + DISTSQ(AX,AY,BX,BY)=(AX-BX)**2+(AY-BY)**2 + +! do n=1,ncn +! write(90,*) n,x(n),y(n),vl(n) +! enddo + IF(NCN .LT. 6) THEN + CALL EXPND(NCN,NELNO) + ENDIF + + XCSQ=0.25 +! +! If NCN = 3 then copy over values +! + IF(NCN .EQ. 3) THEN + ITT=-1 + DO 180 L=1,3 + CX(L,1)=X(L) + CY(L,1)=Y(L) + VAL(L,1)=VL(L) + 180 CONTINUE + XLC(1,1)=0. + XLC(2,1)=1. + XLC(3,1)=0. + YLC(1,1)=0. + YLC(2,1)=0. + YLC(3,1)=0. + NTAB=1 +! +! Subdivide quadrilateral to 2 triangles and develop list +! + ELSEIF(NCN .EQ. 4) THEN + ITT=0 + DO 190 I=1,3 + X(I+4)=X(I) + Y(I+4)=Y(I) + VL(I+4)=VL(I) + 190 CONTINUE +! +! Pick long side for diagonal +! + IF (DISTSQ(X(1),Y(1),X(3),Y(3)) .GT. DISTSQ(X(2),Y(2),X(4),Y(4))) THEN +! +! Rotate if its longer +! + DO 200 I=1,5 + X(I)=X(I+1) + Y(I)=Y(I+1) + VL(I)=VL(I+1) + 200 CONTINUE + ENDIF +! +! Now process it +! + DO 210 L=1,3 + CX(L,1)=X(L) + CY(L,1)=Y(L) + VAL(L,1)=VL(L) + 210 CONTINUE + XLC(1,1)=-1. + XLC(2,1)=1. + XLC(3,1)=1. + YLC(1,1)=-1. + YLC(2,1)=-1. + YLC(3,1)=1. + DO 220 L=1,3 + CX(L,2)=X(L+2) + CY(L,2)=Y(L+2) + VAL(L,2)=VL(L+2) + 220 CONTINUE + XLC(1,2)=1. + XLC(2,2)=-1. + XLC(3,2)=-1. + YLC(1,2)=1. + YLC(2,2)=1. + YLC(3,2)=-1. + NTAB=2 +! +! Subdivide 6 node triangle to 4 triangles and develop list +! + ELSEIF(NCN .EQ. 6) THEN + ITT=2 +! write(90,*) (x(i),i=1,8) + DO 300 K=1,4 + DO 280 L=1,3 + CX(L,K)=X(IT(L,K)) + CY(L,K)=Y(IT(L,K)) + VAL(L,K)=VL(IT(L,K)) + XLC(L,K)=ZIX(L,K) + YLC(L,K)=ZIY(L,K) + 280 CONTINUE + 300 CONTINUE + NTAB=4 +! +! Subdivide 8 node quadrilateral to 8 triangles and develop list +! + ELSEIF(NCN .GE. 8) THEN + IF(NCN .EQ. 8) THEN + ITT=1 + ELSE + ITT=0 + X9=X(9) + Y9=Y(9) + VL9=VL(9) + ENDIF + DO 310 I=1,2 + X(I+8)=X(I) + Y(I+8)=Y(I) + VL(I+8)=VL(I) + 310 CONTINUE +! +! Pick long side for diagonal +! + IF (DISTSQ(X(1),Y(1),X(5),Y(5)) .GT. & + DISTSQ(X(3),Y(3),X(7),Y(7))) THEN +! +! Rotate if its longer +! + DO 320 I=1,8 + X(I)=X(I+2) + Y(I)=Y(I+2) + VL(I)=VL(I+2) + 320 CONTINUE + ENDIF +! +! Define center point +! + IF(NCN .LT. 9) THEN + X(9)=0. + Y(9)=0. + VL(9)=0. + DO 360 I=1,8 + SH=XN(ITT,I,0.d0,0.d0) + X(9)=X(9)+SH*X(I) + Y(9)=Y(9)+SH*Y(I) + VL(9)=VL(9)+SH*VL(I) + 360 CONTINUE + ELSE + X(9)=X9 + Y(9)=Y9 + VL(9)=VL9 + ENDIF + DO 400 K=1,8 + DO 380 L=1,3 + CX(L,K)=X(IQ(L,K)) + CY(L,K)=Y(IQ(L,K)) + VAL(L,K)=VL(IQ(L,K)) + XLC(L,K)=RIX(L,K) + YLC(L,K)=RIY(L,K) + 380 CONTINUE + 400 CONTINUE + NTAB=8 + ENDIF +! +! Start at bottom of list +! + 420 CONTINUE + N=NTAB +! +! Check lengths of sides and nore values +! + ISTART=0 + ICNT=0 + IF(DISTSQ(CX(1,N),CY(1,N),CX(2,N),CY(2,N)) .GT. XCSQ) THEN + ICNT=1 + ISPLT(1)=1 + ISTART=1 + ELSE + ISPLT(1)=0 + ENDIF + IF(DISTSQ(CX(2,N),CY(2,N),CX(3,N),CY(3,N)) .GT. XCSQ) THEN + ICNT=ICNT+1 + ISPLT(2)=1 + ISTART=2 + ELSE + ISPLT(2)=0 + ENDIF + IF(DISTSQ(CX(3,N),CY(3,N),CX(1,N),CY(1,N)) .GT. XCSQ) THEN + ICNT=ICNT+1 + ISPLT(3)=1 + ISTART=3 + ELSE + ISPLT(3)=0 + ENDIF + IF(ICNT .EQ. 0) THEN +! +! Call to plot contours for each triangle +! + IF(IPSAV .EQ. 0) THEN + CALL CBLOK(CX(1,N),CY(1,N),VAL(1,N)) + ELSE + CALL CONTRD(CX(1,N),CY(1,N),VAL(1,N)) + ENDIF + NTAB=N-1 + IF(NTAB .EQ. 0) THEN + RETURN + ELSE + GO TO 420 + ENDIF + ELSEIF(ICNT .EQ. 1) THEN +! +! We must split the triangle into 2. Rotate first into temporary array. +! + IF(NTAB .GT. NTB-1) THEN + WRITE(*,*) 'ELEMENT TABLE SIZE EXCEEDED PLOT CURTAILED' + RETURN + ENDIF + DO 440 I=1,3 + J=MOD(ISTART+I-2,3)+1 + XP(I)=CX(J,N) + YP(I)=CY(J,N) + VP(I)=VAL(J,N) + XLP(I)=XLC(J,N) + YLP(I)=YLC(J,N) + 440 CONTINUE + XLN=(XLP(1)+XLP(2))/2. + YLN=(YLP(1)+YLP(2))/2. + XNEW=0. + YNEW=0. + VNEW=0. + DO 460 I=1,NCN + SH=XN(ITT,I,XLN,YLN) + XNEW=XNEW+SH*X(I) + YNEW=YNEW+SH*Y(I) + VNEW=VNEW+SH*VL(I) + 460 CONTINUE + CX(1,N)=XP(1) + CX(2,N)=XNEW + CX(3,N)=XP(3) + CY(1,N)=YP(1) + CY(2,N)=YNEW + CY(3,N)=YP(3) + VAL(1,N)=VP(1) + VAL(2,N)=VNEW + VAL(3,N)=VP(3) + XLC(1,N)=XLP(1) + XLC(2,N)=XLN + XLC(3,N)=XLP(3) + YLC(1,N)=YLP(1) + YLC(2,N)=YLN + YLC(3,N)=YLP(3) + + CX(1,N+1)=XP(2) + CX(2,N+1)=XP(3) + CX(3,N+1)=XNEW + CY(1,N+1)=YP(2) + CY(2,N+1)=YP(3) + CY(3,N+1)=YNEW + VAL(1,N+1)=VP(2) + VAL(2,N+1)=VP(3) + VAL(3,N+1)=VNEW + XLC(1,N+1)=XLP(2) + XLC(2,N+1)=XLP(3) + XLC(3,N+1)=XLN + YLC(1,N+1)=YLP(2) + YLC(2,N+1)=YLP(3) + YLC(3,N+1)=YLN + NTAB=N+1 + ELSEIF(ICNT .EQ. 2) THEN + IF(NTAB .GT. NTB-2) THEN + WRITE(*,*) 'ELEMENT TABLE SIZE EXCEEDED PLOT CURTAILED' + RETURN + ENDIF +! +! We must split the triangle into 3. Rotate first into temporary array. +! + IF(ISTART .EQ. 3) THEN + IF(ISPLT(1) .EQ. 1) ISTART=3 + IF(ISPLT(2) .EQ. 1) ISTART=2 + ELSE + ISTART=1 + ENDIF + DO 540 I=1,3 + J=MOD(ISTART+I-2,3)+1 + XP(I)=CX(J,N) + YP(I)=CY(J,N) + VP(I)=VAL(J,N) + XLP(I)=XLC(J,N) + YLP(I)=YLC(J,N) + 540 CONTINUE + XLP(4)=(XLP(1)+XLP(2))/2. + YLP(4)=(YLP(1)+YLP(2))/2. + XLP(5)=(XLP(2)+XLP(3))/2. + YLP(5)=(YLP(2)+YLP(3))/2. + XP(4)=0. + YP(4)=0. + VP(4)=0. + XP(5)=0. + YP(5)=0. + VP(5)=0. + DO 560 I=1,NCN + SH=XN(ITT,I,XLP(4),YLP(4)) + XP(4)=XP(4)+SH*X(I) + YP(4)=YP(4)+SH*Y(I) + VP(4)=VP(4)+SH*VL(I) + SH=XN(ITT,I,XLP(5),YLP(5)) + XP(5)=XP(5)+SH*X(I) + YP(5)=YP(5)+SH*Y(I) + VP(5)=VP(5)+SH*VL(I) + 560 CONTINUE + N=NTAB-1 + DO 600 K=1,3 + N=N+1 + DO 580 L=1,3 + CX(L,N)=XP(IST(L,K)) + CY(L,N)=YP(IST(L,K)) + VAL(L,N)=VP(IST(L,K)) + XLC(L,N)=XLP(IST(L,K)) + YLC(L,N)=YLP(IST(L,K)) + 580 CONTINUE + 600 CONTINUE + NTAB=N + ELSEIF(ICNT .EQ. 3) THEN + IF(NTAB .GT. NTB-3) THEN + WRITE(*,*) 'ELEMENT TABLE SIZE EXCEEDED PLOT CURTAILED' + RETURN + ENDIF +! +! We must split the triangle into 4. Fill midsides +! + DO 640 I=1,3 + XP(2*I-1)=CX(I,N) + YP(2*I-1)=CY(I,N) + VP(2*I-1)=VAL(I,N) + XLP(2*I-1)=XLC(I,N) + YLP(2*I-1)=YLC(I,N) + 640 CONTINUE + XLP(2)=(XLP(1)+XLP(3))/2. + YLP(2)=(YLP(1)+YLP(3))/2. + XLP(4)=(XLP(3)+XLP(5))/2. + YLP(4)=(YLP(3)+YLP(5))/2. + XLP(6)=(XLP(5)+XLP(1))/2. + YLP(6)=(YLP(5)+YLP(1))/2. + XP(2)=0. + YP(2)=0. + VP(2)=0. + XP(4)=0. + YP(4)=0. + VP(4)=0. + XP(6)=0. + YP(6)=0. + VP(6)=0. + DO 660 I=1,NCN + SH=XN(ITT,I,XLP(2),YLP(2)) + XP(2)=XP(2)+SH*X(I) + YP(2)=YP(2)+SH*Y(I) + VP(2)=VP(2)+SH*VL(I) + SH=XN(ITT,I,XLP(4),YLP(4)) + XP(4)=XP(4)+SH*X(I) + YP(4)=YP(4)+SH*Y(I) + VP(4)=VP(4)+SH*VL(I) + SH=XN(ITT,I,XLP(6),YLP(6)) + XP(6)=XP(6)+SH*X(I) + YP(6)=YP(6)+SH*Y(I) + VP(6)=VP(6)+SH*VL(I) + 660 CONTINUE + N=NTAB-1 + DO 700 K=1,4 + N=N+1 + DO 680 L=1,3 + CX(L,N)=XP(IT(L,K)) + CY(L,N)=YP(IT(L,K)) + VAL(L,N)=VP(IT(L,K)) + XLC(L,N)=XLP(IT(L,K)) + YLC(L,N)=YLP(IT(L,K)) + 680 CONTINUE + 700 CONTINUE + NTAB=N + ENDIF + GO TO 420 +! + END + SUBROUTINE CONTRD(X,Y,V) + SAVE +! +! Routine to draw contours across triangle +! + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + LOGICAL SWITCH + DIMENSION X(3),Y(3),V(3),XX(2),YY(2) +! +! Get VMIN and VMAX +! + VMIN=MIN(V(1),V(2),V(3)) + VMAX=MAX(V(1),V(2),V(3)) +! +! Process each contour value +! + DO 500 N=1,NUMV +! +! Test if contour lies in range +! + IF(CONTUR(N) .LT. VMIN) GO TO 500 + IF(CONTUR(N) .GT. VMAX) GO TO 500 +! +! Its active +! + I=0 +! +! Look for an intercept V(1) AND V(2) +! + IF(CONTUR(N) .GE. MIN(V(1),V(2)) & + .AND. CONTUR(N) .LE. MAX(V(1),V(2))) THEN +! +! We have an intercept +! + I=I+1 + if(v(2) .ne. v(1)) then + FACT=(CONTUR(N)-V(1))/(V(2)-V(1)) + else + fact=0.5 + endif +! +! Locate point +! + XX(I)=X(1)+FACT*(X(2)-X(1)) + YY(I)=Y(1)+FACT*(Y(2)-Y(1)) + ENDIF +! +! Look for an intercept V(2) AND V(3) +! + IF(CONTUR(N) .GE. MIN(V(2),V(3)) & + .AND. CONTUR(N) .LE. MAX(V(2),V(3))) THEN +! +! We have an intercept +! + I=I+1 + if(v(3) .ne. v(2)) then + FACT=(CONTUR(N)-V(2))/(V(3)-V(2)) + else + fact=0.5 + endif +! +! Locate point +! + XX(I)=X(2)+FACT*(X(3)-X(2)) + YY(I)=Y(2)+FACT*(Y(3)-Y(2)) + IF(I .EQ. 2) GO TO 450 + ENDIF +! +! Look for an intercept V(3) AND V(1) +! + IF(CONTUR(N) .GE. MIN(V(3),V(1)) & + .AND. CONTUR(N) .LE. MAX(V(3),V(1))) THEN +! +! We have an intercept +! + I=I+1 + if(v(1) .ne. v(3)) then + FACT=(CONTUR(N)-V(3))/(V(1)-V(3)) + else + fact=0.5 + endif +! +! Locate point +! + XX(I)=X(3)+FACT*(X(1)-X(3)) + YY(I)=Y(3)+FACT*(Y(1)-Y(3)) + ENDIF +! +! Test for no intercept *ERROR* +! + IF(I .LT. 2) THEN + WRITE(*,*) 'ERROR NO INTERCEPT NOTED, PLOT CURTAILED' + WRITE(90,*) ' NON INTERCEPT VALUES ARE' + WRITE(90,*) v(1),v(2),v(3),contur(n) + RETURN + ENDIF +! +! Now draw line +! + 450 CONTINUE + CALL PLOTT(XX(1),YY(1),3) + CALL PLOTT(XX(2),YY(2),2) +! +! Go back for next contour +! + 500 CONTINUE +! +! We are done +! + RETURN + END + SUBROUTINE CBLOK(X,Y,V) +! +! Given a triangle (X,Y) with values V Draw polygons of the +! contours in CONTUR that cross the triangle +! + DIMENSION X(3),Y(3),V(3),AX(10),AY(10) + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + LOGICAL SWITCH +! +! Sort out order for values of V +! + 200 IF(V(1) .LE. V(2)) THEN + IF(V(3) .LT. V(2)) THEN + VT=V(2) + V(2)=V(3) + V(3)=VT + XT=X(2) + X(2)=X(3) + X(3)=XT + YT=Y(2) + Y(2)=Y(3) + Y(3)=YT + GO TO 200 + ENDIF + ELSE + VT=V(1) + V(1)=V(2) + V(2)=VT + XT=X(1) + X(1)=X(2) + X(2)=XT + YT=Y(1) + Y(1)=Y(2) + Y(2)=YT + GO TO 200 + ENDIF +! +! INITIALIZE +! + IPAN12=0 + IPAN23=0 +! +! Loop on contours +! + cjfact=1.001 + DO 900 N=1,NUMV + nn=float(n)*cjfact + if(numv .le. 10) nn=nn+2 +! +! Check for passing lowest contour +! + IF(CONTUR(N) .GE. V(1)) THEN +! +! Possible active contour +! + IF(CONTUR(N) .LE. V(3)) THEN +! +! Definitely active. Get intercept on 1-3 +! + if(v(3) .ne. v(1)) then + FACT=(CONTUR(N)-V(1))/(V(3)-V(1)) + else + fact=0.5 + endif +! +! Locate point +! + XX1=X(1)+FACT*(X(3)-X(1)) + YY1=Y(1)+FACT*(Y(3)-Y(1)) + IF(CONTUR(N) .LE. V(2)) THEN +! +! Second intercept is on 1-2 +! + IPAN12=IPAN12+1 + if(v(2) .ne. v(1)) then + FACT=(CONTUR(N)-V(1))/(V(2)-V(1)) + else + fact=0.5 + endif +! +! Locate point +! + XX2=X(1)+FACT*(X(2)-X(1)) + YY2=Y(1)+FACT*(Y(2)-Y(1)) + IF(IPAN12 .EQ. 1) THEN +! +! This is the first contour across 1-2 +! + AX(1)=X(1) + AX(2)=XX1 + AX(3)=XX2 + AY(1)=Y(1) + AY(2)=YY1 + AY(3)=YY2 + XX1F=XX1 + XX2F=XX2 + YY1F=YY1 + YY2F=YY2 + CALL POLYG(AX,AY,3,NN) + ELSE +! +! This is a second contour line +! + AX(1)=XX1 + AX(2)=XX2 + AX(3)=XX2F + AX(4)=XX1F + AY(1)=YY1 + AY(2)=YY2 + AY(3)=YY2F + AY(4)=YY1F + XX1F=XX1 + XX2F=XX2 + YY1F=YY1 + YY2F=YY2 + CALL POLYG(AX,AY,4,NN) + ENDIF + ELSE +! +! Second intercept is on 2-3 +! + IPAN23=IPAN23+1 + if(v(3) .ne. v(2)) then + FACT=(CONTUR(N)-V(2))/(V(3)-V(2)) + else + fact=0.5 + endif +! +! Locate point +! + XX2=X(2)+FACT*(X(3)-X(2)) + YY2=Y(2)+FACT*(Y(3)-Y(2)) + IF(IPAN23 .EQ. 1) THEN +! +! This is the first contour on 2-3 +! + IF(IPAN12 .EQ. 0) THEN +! +! There is no previous contour across this element +! + AX(1)=X(1) + AX(2)=XX1 + AX(3)=XX2 + AX(4)=X(2) + AY(1)=Y(1) + AY(2)=YY1 + AY(3)=YY2 + AY(4)=Y(2) + XX1F=XX1 + XX2F=XX2 + YY1F=YY1 + YY2F=YY2 + CALL POLYG(AX,AY,4,NN) + ELSE +! +! There is a previous contour across 1-2 +! + AX(1)=XX1 + AX(2)=XX2 + AX(3)=X(2) + AX(4)=XX2F + AX(5)=XX1F + AY(1)=YY1 + AY(2)=YY2 + AY(3)=Y(2) + AY(4)=YY2F + AY(5)=YY1F + XX1F=XX1 + XX2F=XX2 + YY1F=YY1 + YY2F=YY2 + CALL POLYG(AX,AY,5,NN) + ENDIF + ELSE +! +! This is a second contour line on 2-3 +! + AX(1)=XX1 + AX(2)=XX2 + AX(3)=XX2F + AX(4)=XX1F + AY(1)=YY1 + AY(2)=YY2 + AY(3)=YY2F + AY(4)=YY1F + XX1F=XX1 + XX2F=XX2 + YY1F=YY1 + YY2F=YY2 + CALL POLYG(AX,AY,4,NN) + ENDIF + ENDIF + ELSE +! +! Complete drawing of contour checking to see where previous +! contour was +! + IF(IPAN23 .GT. 0) THEN +! +! It was on 2-3 +! + AX(1)=X(3) + AX(2)=XX2F + AX(3)=XX1F + AY(1)=Y(3) + AY(2)=YY2F + AY(3)=YY1F + CALL POLYG(AX,AY,3,NN) + ELSEIF(IPAN12 .GT. 0) THEN +! +! It was on 1-2 +! + AX(1)=X(3) + AX(2)=X(2) + AX(3)=XX2F + AX(4)=XX1F + AY(1)=Y(3) + AY(2)=Y(2) + AY(3)=YY2F + AY(4)=YY1F + CALL POLYG(AX,AY,4,NN) + ELSE + AX(1)=X(3) + AX(2)=X(2) + AX(3)=X(1) + AY(1)=Y(3) + AY(2)=Y(2) + AY(3)=Y(1) + CALL POLYG(AX,AY,3,NN) + ENDIF + GO TO 905 + ENDIF + ENDIF + 900 CONTINUE + 905 CONTINUE + RETURN + END + + SUBROUTINE EXPND(NCN,N) + + USE BLK1MOD + + INCLUDE 'TXFRM.COM' +! INCLUDE 'PARAM.COM' +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLKBRK.COM' +! INCLUDE 'BFILES.I90' +! WRITE(90,*) 'BEFORE',N,X(1),X(2),X(3),Y(1),Y(2),Y(3) + COMMON /BRK/ X(10),Y(10),VL(10),DL(10),VLM(10) +! expand + DSTRTN1=1.0 + N1=NOP(N,1) + N2=NOP(N,2) + N3=NOP(N,3) + x1= cord(n1,1) + x2= cord(n3,1) + y1= cord(n1,2) + y2= cord(n3,2) + eldir=atan2(y2-y1,x2-x1) + ALFAN1=eldir-1.5708 + ALFAN2=ALFAN1 + ALFAN3=ALFAN1 + NCN=8 + width(n2)=(width(n1)+width(n3))/2. + TX2=X(2) + TY2=Y(2) + TX3=X(3) + TY3=Y(3) + VL2=VL(2) + VL3=VL(3) + X(6)=X(3) + Y(6)=Y(3) + VL(6)=VL(3) + X(2)=X(1) + Y(2)=Y(1) + VL(2)=VL(1) + VL(3)=VL(1) + X(1)=X(2)-WIDTH(N1)*COS(ALFAN1)/(2.*TXSCAL)*DSTRTN1 + X(3)=X(2)+WIDTH(N1)*COS(ALFAN1)/(2.*TXSCAL)*DSTRTN1 + Y(1)=Y(2)-WIDTH(N1)*SIN(ALFAN1)/(2.*TXSCAL)*DSTRTN1 + Y(3)=Y(2)+WIDTH(N1)*SIN(ALFAN1)/(2.*TXSCAL)*DSTRTN1 + VL(4)=VL2 + VL(8)=VL2 + X(4)=TX2+WIDTH(N2)*COS(ALFAN2)/(2.*TXSCAL)*DSTRTN1 + X(8)=TX2-WIDTH(N2)*COS(ALFAN2)/(2.*TXSCAL)*DSTRTN1 + Y(4)=TY2+WIDTH(N2)*SIN(ALFAN2)/(2.*TXSCAL)*DSTRTN1 + Y(8)=TY2-WIDTH(N2)*SIN(ALFAN2)/(2.*TXSCAL)*DSTRTN1 + VL(5)=VL3 + VL(7)=VL3 + X(5)=TX3+WIDTH(N3)*COS(ALFAN3)/(2.*TXSCAL)*DSTRTN1 + X(7)=TX3-WIDTH(N3)*COS(ALFAN3)/(2.*TXSCAL)*DSTRTN1 + Y(5)=TY3+WIDTH(N3)*SIN(ALFAN3)/(2.*TXSCAL)*DSTRTN1 + Y(7)=TY3-WIDTH(N3)*SIN(ALFAN3)/(2.*TXSCAL)*DSTRTN1 +! check areas + + aj=x(3)-x(1) + bj=y(3)-y(1) + ak=x(5)-x(1) + bk=y(5)-y(1) + a1=aj*bk-ak*bj + if(a1 .lt. 0.) then + tx1=x(1) + ty1=y(1) + x(1)=x(3) + y(1)=y(3) + x(3)=tx1 + y(3)=ty1 + + endif + aj=x(5)-x(1) + bj=y(5)-y(1) + ak=x(7)-x(1) + bk=y(7)-y(1) + a2=aj*bk-ak*bj + if(a2 .lt. 0) then + tx1=x(5) + ty1=y(5) + x(5)=x(7) + y(5)=y(7) + x(7)=tx1 + y(7)=ty1 + endif + + aj=x(4)-x(1) + bj=y(4)-y(1) + ak=x(8)-x(1) + bk=y(8)-y(1) + a1=aj*bk-ak*bj + if(a1 .lt. 0.) then + tx1=x(4) + ty1=y(4) + x(4)=x(8) + y(4)=y(8) + x(8)=tx1 + y(8)=ty1 + endif + RETURN + END + diff --git a/src/src83e/BUTTON.ICO b/src/src83e/BUTTON.ICO new file mode 100644 index 0000000..90b9993 Binary files /dev/null and b/src/src83e/BUTTON.ICO differ diff --git a/src/src83e/CANCEL.ICO b/src/src83e/CANCEL.ICO new file mode 100644 index 0000000..b1028bf Binary files /dev/null and b/src/src83e/CANCEL.ICO differ diff --git a/src/src83e/CCLINE.F90 b/src/src83e/CCLINE.F90 new file mode 100644 index 0000000..cb883b8 --- /dev/null +++ b/src/src83e/CCLINE.F90 @@ -0,0 +1,496 @@ +! Last change: IPK 2 Mar 1999 12:58 pm +!IPK NEW ROUTINE OCT 23 1996 + SUBROUTINE CCLINE(ISW) +! +! Generate continuity lines +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + CHARACTER*1 IFLAG + DIMENSION XLIN(350),YLIN(350),INODE1(350) +! DIMENSION ICN(MAXP) + LOGICAL :: OPENED + DO J=1,MAXP + ICN(J)=0 + ENDDO + + IF(ISW .EQ. 1) THEN + call opencln(ipos) + if(ipos .eq. 0) return + ELSE + ipos=2 + ENDIF +! +! First sort out the potential midsides +! Note that transition elements caues a problem +! Find these first + DO N=1,NE + IF(NCORN(N) .EQ. 5 .AND. IMAT(N) .LT. 901) THEN +! +! We have a transition mark node number as if it were corner +! + ICN(NOP(N,3))=1 + ICN(NOP(N,1))=2 + ICN(NOP(N,4))=2 + ICN(NOP(N,5))=2 + ELSE +! +! Store ICN = 2 for corner nodes +! + NCN=NCORN(N) +!IPKOCT93 IF(IMAT(N) .GT. 900) THEN + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) THEN + MST=1 + ELSE + MST=2 + ENDIF + DO M=1,NCN,MST + ICN(NOP(N,M))=2 + ENDDO + ENDIF + ENDDO + +! +! Get connections +! + CALL NTONCON(ipos) + 100 CONTINUE + NHTP=0 + NMESS=26 + NBRR=8 + NTRACT=0 + + CALL HEDR + NCLL=0 +! +! Get first point +! + 110 CONTINUE + K=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE1(1),IFLAG,INSKP,IBOX) + if(inode1(1) .eq. 0) go to 110 + IF(IRMAIN .EQ. 1) THEN + NTRACT=0 + RETURN + ENDIF + IF(IFLAG .EQ. 'q') THEN + NTRACT=0 + GO TO 500 + ENDIF +!IPK JAN01 + IF(IBOX .EQ. 7 .OR. IFLAG .EQ. 'n' .or. & + IBOX .EQ. 5 .OR. IFLAG .EQ. 'd') THEN + ipos=ncll+1 + CALL GETCLN(ipos) +!IPK JAN02 + IF(ISW .EQ. 1) THEN + IF(IPOS .EQ. 0) THEN + DO NCLL=1,140 + DO KK=1,350 + ICCLN(NCLL,KK)=0 + ENDDO + ENDDO + NCLM=0 + ELSE + ncll=ipos + DO KK=1,350 + ICCLN(NCLL,KK)=0 + ENDDO + IF(NCLM .EQ. NCLL) NCLM=NCLM-1 + ENDIF + GO TO 100 + ENDIF + ENDIF + IF(ICN(INODE1(1)) .NE. 2) THEN + NMESS=28 + CALL HEDR + GO TO 110 + ENDIF + + NBRR=5 + NMESS=27 + CALL HEDR + fpn=inode1(1) + CALL NUMBR(0.5,7.2,0.2,FPN,0.0,-1) + call pltnod(inode1(1),0) +! +! Get second point +! + 150 CONTINUE + K=K+1 + 160 CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE1(K),IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) THEN + NTRACT=0 + RETURN + ENDIF + IF(IFLAG .EQ. 'q') THEN + NTRACT=0 + GO TO 500 + ENDIF + NMESS=26 + CALL HEDR + IF(IBOX .EQ. 6 .OR. IFLAG .EQ. 'b' ) THEN + K=K-2 + GO TO 150 + ELSEIF(IBOX .EQ. 7 .OR. IFLAG .EQ. 'n') THEN + KL=K-2 + + IF(ISW .EQ. 1) THEN + +!IPK Get continuity line number + ipos=ncll+1 + CALL GETCLN(ipos) + ncll=ipos + IF(NCLL .EQ. 0) GO TO 500 + ENDIF +! +! Trace along line +! + NTRACT=1 + IF(KL .GT. 0) THEN + DO LS=1,KL + CALL TRACE(INODE1(LS),INODE1(LS+1)) + ENDDO + ELSE + NTRACT=1 + ITRAC(1)=INODE1(1) + ENDIF +! +! Output line to file +! +! WRITE(90,6000) (ITRAC(KK),KK=1,NTRAC) +!ipk jan01 + INQUIRE(98, OPENED=OPENED) + if(opened) then + IF(IPOS .EQ. 1) THEN + DO KK=1,NTRACT + WRITE(98,6001) ITRAC(KK),XUSR(ITRAC(KK)),YUSR(ITRAC(KK)) +6001 FORMAT('NODE',I7,2F15.3) + ENDDO + ELSE + WRITE(98,6000) NCLL,(ITRAC(KK),KK=1,NTRACT) + ENDIF + endif +!IPK JAN01 + 6000 FORMAT('CC1',I5,9I8/('CC2',5X,9I8)) + DO KK=1,NTRACT + XLIN(KK)=CORD(ITRAC(KK),1) + YLIN(KK)=CORD(ITRAC(KK),2) + ENDDO + +!ipk jan01 +! Save to an array by line number +! + IF(ISW .EQ. 1) THEN + DO KK=1,NTRACT + ICCLN(NCLL,KK)=ITRAC(KK) + ENDDO + IF(NCLL .GT. NCLM) NCLM=NCLL + ENDIF + + CALL RRED +!ipk jan01 + CALL THICKL + CALL DASHLN(XLIN,YLIN,NTRACT,0) +!ipk jan01 + + CALL THINL +! +! Go to get another line +! + IF(ISW .EQ. 2) RETURN + GO TO 100 + ELSE + IF(ICN(INODE1(K)) .NE. 2) THEN + NMESS=27 + CALL HEDR + GO TO 160 + ENDIF + KL=K-1 +! +! Trace along line +! + call pltnod(inode1(1),0) + NTRACT=1 + DO LS=1,KL + CALL TRACE(INODE1(LS),INODE1(LS+1)) + call pltnod(inode1(ls+1),0) + ENDDO + if(ntracT .gt. 0) then + DO KK=1,NTRACT + if(itrac(kk) .eq. 0) go to 300 + XLIN(KK)=CORD(ITRAC(KK),1) + YLIN(KK)=CORD(ITRAC(KK),2) + ENDDO + CALL RRED +!ipk jan01 + CALL THICKL + CALL DASHLN(XLIN,YLIN,NTRACT,0) +!ipk jan01 + CALL THINL + endif + 300 CONTINUE + fpn=inode1(KL+1) + CALL NUMBR(0.5+KL*0.5,7.2,0.2,FPN,0.0,-1) +! +! Get another point +! + GO TO 150 + ENDIF +! +! Exit +! + 500 CONTINUE + END + SUBROUTINE NTONCON(ipos) +! +! Generate Connections +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! Initialize to zero +! + NCM=MAXECON + DO N=1,NP + DO L=1,NCM + NECON(N,L)=0 + ENDDO + ENDDO +! +! Loop on elements +! + DO N=1,NE +! +! Check to see that this element is active +! + IF(IMAT(N) .NE. 0) THEN + NCN=NCORN(N) +! +! Search to see if connection M and K made +! + +! DO M=1,NCN,2 + DO M=1,NCN,ipos + + +! IF(M .GT. NCN-1) GO TO 200 +! K=M+2 + K=M+ipos + IF(K .GT. NCN) K=1 + DO L=1,NCM + IF(NECON(NOP(N,M),L) .EQ. 0) THEN +! +! This is new connection +! + NECON(NOP(N,M),L)=NOP(N,K) + GO TO 150 + ELSEIF(NECON(NOP(N,M),L) .EQ. NOP(N,K)) THEN +! +! This is an old connection +! + GO TO 150 + ENDIF + ENDDO + 150 CONTINUE +! +! Now look in the revers direction +! + DO L=1,NCM + IF(NECON(NOP(N,K),L) .EQ. 0) THEN + NECON(NOP(N,K),L)=NOP(N,M) +! +! This is new connection +! + GO TO 175 + ELSEIF(NECON(NOP(N,K),L) .EQ. NOP(N,M)) THEN +! +! This is an old connection +! + GO TO 175 + ENDIF + ENDDO + 175 CONTINUE + ENDDO + ENDIF + 200 CONTINUE + ENDDO + +! + RETURN + END + SUBROUTINE TRACE(INODE1,INODE2) +! +! Generate continuity lines +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + DIST(N,M)=(cord(n,1)-cord(m,1))**2+(cord(n,2)-cord(m,2))**2 +! +! Start at INODE1 +! + ITRAC(NTRACT)=INODE1 + LAT=INODE1 + 100 CONTINUE +! +! Look for new nearer node to INODE2 +! + CURR=1.E30 + LAT1=0 + DO K=1,NCM + LATTMP=NECON(LAT,K) + IF(LATTMP .NE. 0) THEN + IF(DIST(INODE2,LATTMP) .LT. CURR) THEN + LAT1=LATTMP + CURR=DIST(INODE2,LATTMP) + ENDIF + ELSE + GO TO 150 + ENDIF + ENDDO + 150 CONTINUE + IF(LAT1 .EQ. 0) RETURN + NTRACT=NTRACT+1 + ITRAC(NTRACT)=LAT1 + IF(LAT1 .EQ. INODE2) RETURN + IF(NTRACT .GT. 350) RETURN + LAT=LAT1 + GO TO 100 + END + + subroutine opencln(ipos) + use winteracter + + implicit none + + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + LOGICAL :: OPENED + INTEGER :: IPOS,IERR + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INQUIRE(98, OPENED=OPENED) + if(.not. opened) then + CALL WSelectFile(ID_STRING8,SaveDialog+PromptOn,FNAME,'Save continuity line') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='cln' + CALL ADDSUB(FNAME,SUB) + open(98,file=fname, form='formatted', status='unknown') + ENDIF + endif + + call wdialogload(IDD_DIALOG08) + ierr=infoerror(1) + + + call wdialogputRadioButton(idf_radio1) + + + CALL WDialogSelect(IDD_DIALOG08) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ipos) + ipos=3-ipos + return + endif + ipos= 0 + RETURN + enddo + ipos= 2 + RETURN + END + + +!ipk jan01 + subroutine getcln(ipos) + use winteracter + + implicit none + + include 'd.inc' + + INTEGER :: IPOS,IERR + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + + call wdialogload(IDD_DIALOG010) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG010) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,IPOS) + + write(90,*) 'iposin',ipos + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,IPOS) + write(90,*) 'iposout',ipos + + return + endif + return + enddo + + RETURN + END + SUBROUTINE CHKLIN +! +! Generate continuity lines +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + IPOS=2 + CALL NTONCON(ipos) + + DO I=1,NCLM + NTRACT=1 + ITRAC(1)=ICCLN(I,1) + DO J=1,350 + INODE1=ICCLN(I,J) + INODE2=ICCLN(I,J+1) + IF(INODE2 .EQ. 0) GO TO 300 + CALL TRACE(INODE1,INODE2) + ENDDO + 300 DO J=1,NTRACT + ICCLN(I,J)=ITRAC(J) + ENDDO + ENDDO + + RETURN + END diff --git a/src/src83e/COMPACT.F90 b/src/src83e/COMPACT.F90 new file mode 100644 index 0000000..369a921 --- /dev/null +++ b/src/src83e/COMPACT.F90 @@ -0,0 +1,120 @@ +!IPK LAST UPDATE jAN 25 2001 CORRECT REFERENCE TO INEW + SUBROUTINE COMPACT(ISW) +! +! Compact nodes or element numbers +! ISW = 3 compact nodes +! ISW = 4 compact elements +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + DIMENSION ICREFN(MAXP),ICREFE(MAXE) +! +! + IF(ISW .EQ. 3) THEN +! +! First compact node list and create cross reference +! + JJ=1 + DO J=1,NP +!IPK JAN01 FIX TEST + IF(INEW(J) .NE. 0) THEN + INEW(JJ)= INEW(J) + CORD(JJ,1)=CORD(J,1) + CORD(JJ,2)=CORD(J,2) + XUSR(JJ)=XUSR(J) + YUSR(JJ)=YUSR(J) + WD(JJ)=WD(J) + LAY(JJ)=LAY(J) + WIDTH(JJ)=WIDTH(J) + SS1(JJ)=SS1(J) + SS2(JJ)=SS2(J) + WIDS(JJ)=WIDS(J) + WIDBS(JJ)=WIDBS(J) + SSO(JJ)=SSO(J) + INSKP(JJ)=INSKP(J) + LOCK(JJ)=LOCK(J) + ICREFN(J)=JJ + JJ=JJ+1 + ENDIF + ENDDO + DO J=JJ,NP + CORD(J,1)=-1.D20 + CORD(J,2)=-1.D20 + XUSR(J)=-1.D20 + YUSR(J)=-1.D20 + WD(J)=-9999. + LAY(J)=-9999 + WIDTH(J)=0. + SS1(J)=0 + SS2(J)=0. + WIDS(J)=0. + WIDBS(J)=0. + SSO(J)=0. + INSKP(J)=1 +!IPK JAN01 ADD INEW + INEW(J)=0 + LOCK(J)=0 + ENDDO + NP=JJ-1 +! +! Next renumber element connections +! + DO N=1,NE + DO M=1,8 + IF(NOP(N,M) .NE. 0) THEN + NOP(N,M)=ICREFN(NOP(N,M)) + ENDIF + ENDDO + ENDDO + +! Renumber continuity lines + + DO I=1,NCLM + DO J=1,350 + IF(ICCLN(I,J) .GT. 0) THEN + ICCLN(I,J)=ICREFN(ICCLN(I,J)) + ENDIF + ENDDO + ENDDO + + ELSEIF(ISW .EQ. 4) THEN +! +! Compact elements +! + JJ=1 + DO J=1,NE + IF(NOP(J,1) .NE. 0) THEN + DO M=1,8 + NOP(JJ,M)=NOP(J,M) + ENDDO + ICREFE(J)=JJ + XC(JJ)=XC(J) + YC(JJ)=YC(J) + IMAT(JJ)=IMAT(J) + THTA(JJ)=THTA(J) + IEM(JJ)=0 + NCORN(JJ)=NCORN(J) + IESKP(JJ)=IESKP(J) + JJ=JJ+1 + ENDIF + ENDDO + DO J=JJ,NE + DO M=1,8 + NOP(J,M)=0 + ENDDO + IMAT(J)=0 + THTA(J)=0 + IEM(J)=0 + NCORN(J)=0 + IESKP(JJ)=-1 + ENDDO + NE=JJ-1 + DO J=1,NLST + DO I=1,LLIST(J) + ILIST(J,I)=ICREFE(ILIST(J,I)) + ENDDO + ENDDO + ENDIF + RETURN + END diff --git a/src/src83e/COMPSCAL.F90 b/src/src83e/COMPSCAL.F90 new file mode 100644 index 0000000..4248ab6 --- /dev/null +++ b/src/src83e/COMPSCAL.F90 @@ -0,0 +1,147 @@ + SUBROUTINE COMPWGT + + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! COMMON/ICN1/ ICN(MAXP) + + DIST(X1,X2,Y1,Y2)=SQRT((X1-X2)**2+(Y1-Y2)**2) + + DO J=1,MAXP + ICN(J)=0 + END DO +! First sort out the potential midsides +! Note that transition elements caues a problem +! Find these first + DO 200 N=1,NE + if(NCORN(N) .GT. 5) GO TO 200 + IF(NCORN(N) .EQ. 5 .AND. IMAT(N) .LT. 901) THEN +! +! We have a transition mark node number as if it were corner +! + ICN(NOP(N,3))=-1 + ICN(NOP(N,1))=IMAT(N) + ICN(NOP(N,4))=IMAT(N) + ICN(NOP(N,5))=IMAT(N) + ELSE +! +! Store ICN = 2 for corner nodes +! + NCN=NCORN(N) +!IPKOCT93 IF(IMAT(N) .GT. 900) THEN + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) THEN + GO TO 185 + ELSE + MST=2 + ENDIF + + DO 180 M=1,NCN,MST + ICN(NOP(N,M))=IMAT(N) + 180 CONTINUE + 185 CONTINUE + ENDIF + 200 END DO + + DO N=1,NP + IF(ICN(N) .GT. 0) THEN + ADIST=1.E20 + DO J=1,NCRSEC + IF(ICN(N) .EQ. NOREACH(IVMIL(J))) THEN + A1=DIST(XUSR(N),XCRS(IVMIL(J)),YUSR(N),YCRS(IVMIL(J))) + IF(A1 .LT. ADIST) THEN + ADIST=A1 + NSEC1=IVMIL(J) + ENDIF + ENDIF + ENDDO +!IPK JUN04 + IF(ADIST .EQ. 1.E20) THEN + NRIVCR1(N)=0 + NRIVCR2(N)=0 + WTRIVCR1(N)=0 + WTRIVCR2(N)=0 + ELSE + BDIST=1.E20 + DO J=1,NCRSEC + IF(ICN(N) .EQ. NOREACH(IVMIL(J))) THEN + IF(IVMIL(J) .NE. NSEC1) THEN + A1=DIST(XUSR(N),XCRS(IVMIL(J)),YUSR(N),YCRS(IVMIL(J))) + A2=DIST(XCRS(NSEC1),XCRS(IVMIL(J)),YCRS(NSEC1),YCRS(IVMIL(J))) + +! A1 IS DISTANCE TO NODE +! A2 IS DISTANCE TO RECORDED POINT + + IF(A2 .GE. A1) THEN + IF(A1 .LT. BDIST) THEN + BDIST=A1 + NSEC2=IVMIL(J) + ENDIF + ENDIF + ENDIF + ENDIF + ENDDO + IF(BDIST .EQ. 1.E20) NSEC2=NSEC1 + NRIVCR1(N)=NSEC1 + NRIVCR2(N)=NSEC2 + WTRIVCR1(N)=BDIST/(ADIST+BDIST) + WTRIVCR2(N)=ADIST/(ADIST+BDIST) + ENDIF + ENDIF + ENDDO + RETURN + END + + SUBROUTINE GETCSLOC + use winteracter + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' +!- + + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: IERR,ISET,IBOX + REAL :: ASET + CHARACTER*1 :: IFLAG + + call wdialogload(IDD_CSLOC) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_CSLOC) + ierr=infoerror(1) + + ISET=1 + 100 continue + + + CALL WDialogPutINTEGER(IDF_INTEGER1,ISET) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + DO +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + CALL WDialogGetINTEGER(IDF_INTEGER1,ISET) + GO TO 200 + else + RETURN + endif + ENDDO + 200 CONTINUE + + CALL XYLOC(XX,YY,IFLAG,IBOX) + IF(IRMAIN .EQ. 1) RETURN + XCRS(ISET) = XX*TXSCAL - XS + YCRS(ISET) = YY*TXSCAL - YS + GO TO 100 + + RETURN + END \ No newline at end of file diff --git a/src/src83e/CONT.F90 b/src/src83e/CONT.F90 new file mode 100644 index 0000000..1b16844 --- /dev/null +++ b/src/src83e/CONT.F90 @@ -0,0 +1,300 @@ + SUBROUTINE CONOUT(MENUS) +! + USE WINTERACTER + USE BLK1MOD + SAVE +! INCLUDE 'BLK1.COM' +! + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL +! + DIMENSION VALUS(MAXP) + + CHARACTER*60 STRELS + + DATA STRELS/' You have tried to reorder before executing "FILL"'/ +! +! +! Test to make sure fill has been executed. +! + IF(MENUUS .EQ. 13) ifilltmp=0 + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + DO M=2,NCORN(N),2 +!ipkoct93 + if(imat(n) .LT. 900) THEN + IF(NOP(N,M) .EQ. 0) THEN + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'You have tried to plot contours before filling'//char(13)//& + 'Do you wish to temporarily fill and proceed?'//& + CHAR(13)//' ','PLOTTING CONTOURS WITHOUT A FILLED NETWORK?') +! +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) THEN + RETURN + ENDIF + CALL FILM(1) + ifilltmp=1 + call hedr + GO TO 300 + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO +! +300 CONTINUE + DO N=1,NP + VALUS(N)=WD(N) + ENDDO +! + CALL TOLMAX(VALUS,TTMIN,TTMAX) + + ISZ=0 + IF(MENUS .EQ. 13) THEN + ISZ=1 + CALL CSET(TTMIN,TTMAX,isz) + RETURN + ENDIF + + PSCL=1.0 + CALL ELCONT(VALUS,PSCL) + + if(ifilltmp .eq. 1) CALL DELETM(0) + + RETURN + END + SUBROUTINE ELCONT(VALUS,PSCL) +! +! Routine to draw element contours +! + USE BLK1MOD + +! INCLUDE 'BLK1.COM' +! + INCLUDE 'BFILES.I90' + COMMON /BRK/ X(10),Y(10),VL(10),DL(10),VLM(10) + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + LOGICAL SWITCH +! DIMENSION X(10),Y(10),VL(10),VALUS(*) + DIMENSION VALUS(*) + DATA PSCL1/1.0/ITIME/0/ + + IF(PSCL .eq. 0.) then + PSCL=PSCL1 + ELSE + PSCL1=PSCL + ENDIF + CALL RRed + + CALL GETXC + + IF(.NOT. ALLOCATED(NKEY1)) THEN + ALLOCATE (NKEY1(MAXE)) + ENDIF + CALL SORTDB(YC,NKEY1,NE) + + DO 500 NN=NE,1,-1 + N=NKEY1(NN) + IF(IESKP(N) .EQ. 1) GO TO 500 + NCN=NCORN(N) + IF(NCN .EQ. 9) NCN=8 + DO M=1,NCN,2 + if(nop(n,m) .eq. 0) go to 500 + IF(VALUS(NOP(N,M)) .LT. -9998.) GO TO 500 + ENDDO +! +! Copy values into work array +! + NCN=NCORN(N) +! if(ncn .lt. 6) go to 500 + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) GO TO 500 + IOK=0 + DO 300 M=1,NCN + IF(NOP(N,M) .EQ. 0) GO TO 500 + X(M)=CORD(NOP(N,M),1) + Y(M)=CORD(NOP(N,M),2) + IF(I3DVIEW .EQ. 1) THEN + IF(VRTSCAL .GT. 0.) THEN + Y(M)=Y(M)+(WD(NOP(N,M))-VRTORIG)*COS(VANG/57.29578)/VRTSCAL + ENDIF + ENDIF + + IF(X(M) .GT. 0. .AND. X(M) .LT. HSIZE) THEN + IF(Y(M) .GT. 0. .AND. Y(M) .LT. 7.) THEN + IOK=1 + ENDIF + ENDIF + VL(M)=VALUS(NOP(N,M))*PSCL + 300 CONTINUE + IF(IOK .EQ. 0) GO TO 500 +! CALL BRKDWN(X,Y,VL,NCN) + NELNO=N + CALL BRKDWN(NCN,NELNO) + +!ipkoct93 + if(ipsw(4) .eq. 1) then + NLINP=NCN+1 + X(NLINP)=X(1) + Y(NLINP)=Y(1) + CALL DASHLN(X,Y,NLINP,0) + endif + + 500 CONTINUE +! +! Print title +! + ncharr=lenstr(title) + call rblue + IF(NCHARR .GT. 1) CALL SYMBL(0.5,7.25,0.20,TITLE,0.0,ncharr) + + XLEG=8.8 + YLEG=7.4 + + CALL LEGND(XLEG,YLEG,CONTUR,NUMV,NUMCOL) + CALL RBlue + RETURN + END + + SUBROUTINE LEGND(XLEG,YLEG,CONTUR,NUMV,NUMCOL) + SAVE + DIMENSION CONTUR(99),X(10),Y(10) + DATA LDIGO/2/ + XLOC=XLEG+0.5 + YLOC=YLEG + csfact=1.0001 + DO 80 N=1,NUMV + IF(N .LT. NUMV) THEN +! +! Define polygon +! + X(1)=XLEG + X(2)=XLEG + X(3)=XLEG+0.4 + X(4)=XLEG+0.4 + Y(1)=YLOC + Y(2)=YLOC-0.3 + Y(3)=YLOC-0.3 + Y(4)=YLOC + nn=(n+1)*csfact + if(numv .le. 10) nn=nn+2 + CALL POLYG(X,Y,4,nn) + ENDIF +! +! Plot the value on the screen +! + if(contur(n) .ne. 0.) then + DIG = ALOG10(ABS(CONTUR(N))) + else + dig = -2. + endif + IF(DIG .GT. 2.999) THEN + LDIG=-DIG - 1 + ELSEIF (DIG .GT. 1.999) THEN + LDIG = 0 + ELSEIF (DIG .GT. 0.999) THEN + LDIG = 1 + ELSEIF (DIG .GT. 0) THEN + LDIG = 2 + ELSE + LDIG = DIG - 2. + .01 + LDIG = -LDIG + ENDIF + IF(LDIG .LT. 0) GO TO 70 + DO 60 KK=1,3 + ANUM=10.**(-LDIG) + IF(N .EQ. 1) THEN + IF(ABS(CONTUR(2)-CONTUR(1)) .LT. ANUM) THEN + LDIG = LDIG + 1 + ELSE + GO TO 70 + ENDIF + ELSE + IF(ABS(CONTUR(N)-CONTUR(N-1)) .LT. ANUM) THEN + LDIG = LDIG + 1 + ELSE + GO TO 70 + ENDIF + ENDIF + 60 CONTINUE + 70 CONTINUE + call rblue + CTMP=CONTUR(N) + IF(ABS(CTMP) .LT. 1.E-7) THEN + CTMP=0. + LDIG=LDIGO + ENDIF + + CALL rblack + CALL NUMBR(XLOC,YLOC-0.09,0.2,CTMP,0.0,LDIG) + LDIGO=LDIG + CALL rblack +! + CALL PLOTT(X(1),Y(1),3) + CALL PLOTT(X(2),Y(2),2) + CALL PLOTT(X(3),Y(3),2) + CALL PLOTT(X(4),Y(4),2) + CALL PLOTT(X(1),Y(1),2) +! + YLOC=YLOC-0.30 + 80 CONTINUE + CALL RBlue + RETURN + END + + + SUBROUTINE TOLMAX(VALUS,TTMIN,TTMAX) +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + DIMENSION VALUS(*) +! + TMAX = -1.E+20 + TMIN = 1.E+20 + DO 218 J=1,NP + IF (VALUS(J) .GT. TMAX) THEN + TMAX = VALUS(J) + ITMAX = J + ENDIF + IF (VALUS(J) .LT. TMIN) THEN + TMIN = VALUS(J) + ITMIN = J + ENDIF + 218 CONTINUE + WRITE(90,*) ' ' + WRITE(90,*) ' Max, Min for entire network ' + WRITE(90,*) ' MAX value = ', TMAX, ' at node ', ITMAX + WRITE(90,*) ' MIN value = ', TMIN, ' at node ', ITMIN + WRITE(90,*) ' ' +! +! Check for max and min values of elements in the plotting area +! + TTMAX = -1.E+20 + TTMIN = 1.E+20 + DO 228 N=1,NE + IF(IESKP(N) .EQ. 0) THEN + DO 220 M=1,NCORN(N) + J=NOP(N,M) +!ipk sep99 + if(j .eq. 0) go to 220 + IF (VALUS(J) .GT. TTMAX) THEN + TTMAX = VALUS(J) + ITTMAX = J + ENDIF + IF (VALUS(J) .LT. TTMIN) THEN + TTMIN = VALUS(J) + ITTMIN = J + ENDIF + 220 CONTINUE + ENDIF + 228 CONTINUE +! + WRITE(90,*) ' ' + WRITE(90,*) ' Max, Min for plot area ' + WRITE(90,*) ' MAX value = ', TTMAX, ' at node ', ITTMAX + WRITE(90,*) ' MIN value = ', TTMIN, ' at node ', ITTMIN +! + RETURN + END + + diff --git a/src/src83e/CREATGRID.f90 b/src/src83e/CREATGRID.f90 new file mode 100644 index 0000000..57b3a04 --- /dev/null +++ b/src/src83e/CREATGRID.f90 @@ -0,0 +1,193 @@ + PROGRAM creatgrid + dimension XL(100,2),YL(100,2),mappt(2),XL1(100),XL2(100) + REAL*8 GRIDX(100),GRIDY(100) +! +! define line numbers in map file +! + DIST(A,B,C,D)=SQRT((C-A)*2+(D-C)**2) + XL(1,1)=0. + XL(2,1)=320. + XL(3,1)=530. + YL(1,1)=0. + YL(2,1)=20. + YL(3,1)=50. + MAPPT(1)=3 + XL(1,2)=0. + XL(2,2)=600. + YL(1,2)=70. + YL(2,2)=90. + MAPPT(2)=2 + K1=1 + K2=2 + +! +! compute line length +! + XL1=0. + nlpts1=mappt(k1) + do n=2,nlpts1 + XL1(n)=XL1(n-1)+dist(XL(n-1,1),YL(n-1,1),XL(n,1),YL(n,1)) + enddo + XL2=0. + nlpts2=mappt(k2) + do n=2,nlpts2 + XL2(n)=XL2(n-1)+dist(XL(n-1,2),YL(n-1,2),XL(n,2),YL(n,2)) + enddo + xmean=(XL1(nlpts1)+XL2(nlpts2))/2. +! +! get size spacing +! +! read xsz,NY + XSZ=100. + NY=5 + along=xmean/xsz + NX=(along+0.99) + + NXP=NX+1 + NYP=NY+1 + NRL=NX*NYP+1 + NRT=NXP*NYP + +! DO N=1,NE +! DO M=1,8 +! NOPSV(N,M)=NOP(N,M) +! ENDDO +! IMATSV(N)=IMAT(N) +! ENDDO +! NESAV=NE +! NEFSAV=NENTRY +! NPUNDO=NRT +! +! Initialize GRIDX and GRIDY +! + DO N=1,NRT + GRIDX(N)=0. + GRIDY(N)=0. +! IGSKP(N)=0 + END DO +! +! calculate lengths +! + xalong1=XL1(nlpts1)/NX + xalong2=XL2(nlpts2)/NX +! +! compute cords along the edges +! + XALONG=0. + XXALONG=0. + GRIDX(1)=XL(1,1) + GRIDY(1)=YL(1,1) + GRIDX(NYP)=XL(1,2) + GRIDY(NYP)=YL(1,2) + NRT=NXP*NYP + DO N=NY+2,NRT,NYP + XALONG=XALONG+XALONG1 + NX1=2 + DO M=NX1,NLPTS1 + IF(XALONG .LT. XL1(M)) THEN + M1=M + GO TO 200 + ENDIF + ENDDO + 200 CONTINUE + FRAC1=(XALONG-XL1(M1-1))/(XL1(M1)-XL1(M1-1)) + GRIDX(N)=XL(m1-1,1)+FRAC1*(XL(m1,1)-XL(m1-1,1)) + GRIDY(N)=YL(m1-1,1)+FRAC1*(YL(m1,1)-YL(m1-1,1)) + NX1=M1 + XXALONG=XXALONG+XALONG2 + NX2=2 + DO M=NX2,NLPTS2 + IF(XXALONG .LT. XL2(M)) THEN + M2=M + GO TO 250 + ENDIF + ENDDO + 250 CONTINUE + FRAC1=(XXALONG-XL2(M2-1))/(XL2(M2)-XL2(M2-1)) + GRIDX(N+NY)=XL(m2-1,2)+FRAC1*(XL(m2,2)-XL(m2-1,2)) + GRIDY(N+NY)=YL(m2-1,2)+FRAC1*(YL(m2,2)-YL(m2-1,2)) + NX2=M2 + ENDDO +! +! +! check if points ok allow for move +! +! +! form elements and other coordinates +! +! +! Interpolate interior points +! + DO M=1,NRT,NYP + NFS=NRL+M-1 + CALL INTERP(GRIDX,GRIDY,M,M+NY,1,GRIDX(M),GRIDY(M),GRIDX(M+NY) & + & ,GRIDY(M+NY),NY,0) +! DO N=M,NFS +! XTEMP=GRIDX(N) +! YTEMP=GRIDY(N) +! GRIDXL(N) = GRIDX(N)*TXSCAL - XS +! GRIDYL(N) = GRIDY(N)*TXSCAL - YS +! CALL RRed +! call drawcr(xtemp,ytemp,siz) +! CALL RBlue +! ENDDO + END DO +! +! query for depths +! +! +! query for happY + STOP + end + SUBROUTINE INTERP(GRIDX,GRIDY,NL,NH,INT,ALX,ALY,ATX,ATY,NINT,ISWT) +! +! Routine to fill GRIDX and GRIDY by interpolation +! NL = START OF GENERATED +! NH = END OF GENERATED +! INT = INTERVAL +! ALX, ALY = START LOC +! ATX, ATY = END LOC +! NINT = NUMBER OF POINTS +! ISWT = 0 BASELINE = 1 APPLY CHANGES +!IPK MAY02 + REAL*8 GRIDX(NH),GRIDY(NH),ALX,ALY,ATX,ATY +! +! Compute intervals +! + XINT=(ATX-ALX)/FLOAT(NINT) + YINT=(ATY-ALY)/FLOAT(NINT) +! +! Generate points +! + IF(ISWT .EQ. 0) THEN + KP=0 + DO 200 K=NL,NH,INT + IF(KP .EQ. 0) THEN + GRIDX(K)=ALX + GRIDY(K)=ALY + ELSE + GRIDX(K)=GRIDX(KP)+XINT + GRIDY(K)=GRIDY(KP)+YINT + ENDIF + KP=K + 200 CONTINUE + ELSE + XAD=ALX + YAD=ALY + KP=0 + DO 220 K=NL,NH,INT + IF(KP .EQ. 0) THEN + GRIDX(K)=GRIDX(K)+XAD + GRIDY(K)=GRIDY(K)+YAD + ELSE + XAD=XAD+XINT + YAD=YAD+YINT + GRIDX(K)=GRIDX(K)+XAD + GRIDY(K)=GRIDY(K)+YAD + ENDIF + KP=K + 220 CONTINUE + ENDIF + RETURN + END + \ No newline at end of file diff --git a/src/src83e/CREATM.F90 b/src/src83e/CREATM.F90 new file mode 100644 index 0000000..dcfe928 --- /dev/null +++ b/src/src83e/CREATM.F90 @@ -0,0 +1,278 @@ + SUBROUTINE CREATM + + + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! Routine to create mesh from map contour lines + + COMMON /CRMAP/ NCONT,CVALUE(1000),MSTART(1000),MFIN(1000),CINTDIS(1000),IACTCV(1000) + +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + +! Search map data for contoour lines and setup values + + JS=1 + NCONT=0 +! + K=0 + DO 20 J=1,MAXPTS + MLEN=J-JS + IF(XMAP(J) .LE. VDX .or. j .eq. maxpts) THEN +! +! We have found a line end, is itmore than 1 point long? +! + K=K+1 + IF(MLEN .GT. 1) THEN + LTP=LINTYP(K) + + IF(LTP .NE. 2) THEN + IF(LTP .GT. 0) THEN + NCONT=NCONT+1 + CVALUE(NCONT)=VAL(JS) + MSTART(NCONT)=JS + IF(XMAP(J) .LE. VDX) THEN + MFIN(NCONT)=J-1 + ELSE + MFIN(NCONT)=J + ENDIF + ENDIF + ENDIF + ENDIF + IF(MLEN .EQ. 0 .AND. LINTYP(K) .EQ. -999) GO TO 30 + JS=J+1 + ENDIF + 20 CONTINUE + 30 CONTINUE + + +! Choose options and intervals + + CALL PANELCRT(NCONT,CVALUE,IACTCV,CINTDIS,ICAN) + IF(ICAN .EQ. 1) RETURN + +! First form list of nodes working along contour lines + + CALL CFORM + +! Now generate elements + + do n=1,np + list(n)=1 + enddo + + call deln2(np,0) + + call checkpoly + + RETURN + END + + SUBROUTINE PANELCRT(N1,R2,N3,R4,N5) + +! Choose options and intervals + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3(1000),IERR,ITIME,K,N5,NA,NB + real :: R2(1000),R4(1000) + data itime/0/ + + if(itime .eq. 0) then + n2=0 + na=1 + nb=1 + itime=1 + do k=1,1000 + r4(k)=500. + n3(k)=1 + enddo + endif + + call wdialogload(IDD_CREATM1) + ierr=infoerror(1) + + CALL WDialogPutCheckBox(idf_check1,na) + CALL WDialogPutCheckBox(idf_check2,nb) + CALL WDialogPutReal(idf_real1,r4(1)) + + CALL WDialogSelect(IDD_CREATM1) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetCheckBox(idf_check1,na) + CALL WDialogGetCheckBox(idf_check2,nb) + if(nb .eq. 1) then + CALL WDialogGetReal(idf_real1,r4(1)) + do k=1,1000 + r4(k)=r4(1) + enddo + endif + N5=0 + ELSE + N5=1 + RETURN + + ENDIF + + if(na .eq. 1 .and. nb .eq. 1) return + + call wdialogload(IDD_CREATM) + ierr=infoerror(1) + + CALL WGridPutCheckBox(idf_grid1,1,n3,n1) + CALL WGridPutReal(idf_grid1,2,r2,n1) + CALL WGridPutReal(idf_grid1,3,r4,n1) + + CALL WDialogSelect(IDD_CREATM) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WGridGetCheckBox(idf_grid1,1,n3,n1) + CALL WGridGetReal(idf_grid1,2,r2,n1) + CALL WGridGetReal(idf_grid1,3,r4,n1) + N5=0 + ELSE + N5=1 + RETURN + + ENDIF + RETURN + END + + SUBROUTINE CFORM + +! Form list of nodes working along contour lines + + USE BLKMAP + USE BLK1MOD + + COMMON /CRMAP/ NCONT,CVALUE(1000),MSTART(1000),MFIN(1000),CINTDIS(1000),IACTCV(1000) + +! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' + + DISTC(N1,N2)=SQRT((XMAP(N1)-XMAP(N2))**2 & + & +(YMAP(N1)-YMAP(N2))**2) + +! Loop through each active contour + + DO N=1,NCONT + IF(IACTCV(N) .EQ. 1) THEN + JS=MSTART(N) + JF=MFIN(N) + IF(XMAP(JS) .EQ. XMAP(JF) .AND. YMAP(JS) .EQ. YMAP(JF)) THEN + IF(JF .GT. JS) JF=JF-1 + ENDIF + IEND=0 + DO J=JS,JF + IF(J .EQ. JS) THEN + CDONE=0. + CNODE=0 + CALL GETNOD(JJ) + INSKP(JJ)=0 + INEW(JJ) = 1 +! + XUSR(JJ) = XMAP(J) + YUSR(JJ) = YMAP(J) + CORD(JJ,1)=(XUSR(JJ)+XS)/TXSCAL + CORD(JJ,2)=(YUSR(JJ)+YS)/TXSCAL + WD(JJ)=CVALUE(N) + WIDTH(JJ)=0. + SS1(JJ)=0. + SS2(JJ)=0. + WIDS(JJ)=0. + WIDBS(JJ)=0. + SSO(JJ)=0. + IF (JJ .GT. NP) NP = JJ + CALL PLTNOD(JJ,0) + ICHG=0 + ELSE + CNODEO=CNODE + CNODE=CNODE+DISTC(J,J-1) + 200 CONTINUE + CDIS=CDONE+CINTDIS(N) + IF(CDIS .LE. CNODE .OR. J .EQ. JF) THEN + IF(CDIS .LE. CNODE) THEN + FACT=(CDIS-CNODEO)/(DISTC(J,J-1)) + IF(J .EQ. JF .AND. FACT .GT. 0.999) IEND=1 + ELSE + FACT=1.0 + IEND=1 + ENDIF + CALL GETNOD(JJ) + INSKP(JJ)=0 + INEW(JJ) = 1 +! + XUSR(JJ) = (1.-FACT)*XMAP(J-1)+FACT*XMAP(J) + YUSR(JJ) = (1.-FACT)*YMAP(J-1)+FACT*YMAP(J) + CORD(JJ,1)=(XUSR(JJ)+XS)/TXSCAL + CORD(JJ,2)=(YUSR(JJ)+YS)/TXSCAL + WD(JJ)=CVALUE(N) + WIDTH(JJ)=0. + SS1(JJ)=0. + SS2(JJ)=0. + WIDS(JJ)=0. + WIDBS(JJ)=0. + SSO(JJ)=0. + IF (JJ .GT. NP) NP = JJ + CALL PLTNOD(JJ,0) + ICHG=0 + CDONE=CDIS + IF(IEND .NE. 1) GO TO 200 + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO + RETURN + END + + SUBROUTINE CHECKPOLY + +! CHECK IF ELEMENTS ARE OUTSIDE POLYGON BY LOOKING AT CENTROID + USE BLKOUT + USE BLK1MOD + + IF(NOUTLIN .EQ. 0) RETURN + + call FILM(1) + NETEMP=NE + DO N=1,NETEMP + IF(IMAT(N) .EQ. 0) CYCLE + XM=(XUSR(NOP(N,1))+XUSR(NOP(N,3))+XUSR(NOP(N,5)))/3. + YM=(YUSR(NOP(N,1))+YUSR(NOP(N,3))+YUSR(NOP(N,5)))/3. +! do k=2,6,2 +! xm=xusr(nop(n,k)) +! ym=yusr(nop(n,k)) + if( IGRInsidePolygon(xoutl,youtl,noutlin,xm,ym)) then + + else + CALL DELTEL(n) + go to 200 + endif +! enddo + +200 continue + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/src83e/CRGRID.f90 b/src/src83e/CRGRID.f90 new file mode 100644 index 0000000..59feea3 --- /dev/null +++ b/src/src83e/CRGRID.f90 @@ -0,0 +1,376 @@ + SUBROUTINE crgrid + USE BLK1MOD + USE BLKMAP + REAL*8 GRIDX,GRIDY,GRIDXL,GRIDYL,XL,YL,ANGD,GETANG1,A,B,C,D + INTEGER*2 IGSKP + dimension XL(1500,3),YL(1500,3),mappt(2),XL1(500),XL2(500) + INCLUDE 'TXFRM.COM' + COMMON /GBLK/ GRIDX(MAXPGEN),GRIDY(MAXPGEN),GRIDXL(MAXPGEN),GRIDYL(MAXPGEN)& + ,IGSKP(MAXPGEN),NRL,NRT,NYP,IGRIDE(MAXPGEN) +! +! define line numbers in map file +! + ITEST=1 + CALL PANELGENBLK(NY,XSZ,KL1,KL2,ISW1,ISW2,ITEST) + JS=1 +! + K=0 + KL=1 + CALL RCyan + DO 20 J=1,MAXPTS + MLEN=J-JS + IF(XMAP(J) .LE. VDX .or. j .eq. maxpts) THEN + IF(J .EQ. MAXPTS .AND. XMAP(J) .GT. VDX) MLEN=MLEN+1 +! +! + K=K+1 + IF(K .EQ. KL2) THEN + DO KK=1,MLEN + XL(KK,1)=XMAP(KK+JS-1) + YL(KK,1)=YMAP(KK+JS-1) + ENDDO + IF(ISW2 .EQ. 1) THEN + DO KK=MLEN,1,-1 + XL(KK,3)=XL(MLEN-KK+1,1) + YL(KK,3)=YL(MLEN-KK+1,1) + ENDDO + DO KK=1,MLEN + XL(KK,1)=XL(KK,3) + YL(KK,1)=YL(KK,3) + ENDDO + ENDIF + MAPPT(1)=MLEN + ENDIF + IF(K .EQ. KL1) THEN + DO KK=1,MLEN + XL(KK,2)=XMAP(KK+JS-1) + YL(KK,2)=YMAP(KK+JS-1) + ENDDO + IF(ISW1 .EQ. 1) THEN + DO KK=MLEN,1,-1 + XL(KK,3)=XL(MLEN-KK+1,2) + YL(KK,3)=YL(MLEN-KK+1,2) + ENDDO + DO KK=1,MLEN + XL(KK,2)=XL(KK,3) + YL(KK,2)=YL(KK,3) + ENDDO + ENDIF + MAPPT(2)=MLEN + ENDIF + JS=J+1 + KL=2 + ENDIF + 20 CONTINUE + K1=1 + K2=2 +! +! compute line length +! + XL1=0. + nlpts1=mappt(k1) + do n=2,nlpts1 + XL1(n)=XL1(n-1)+SQRT((XL(N,1)-XL(n-1,1))**2+(YL(n,1)-YL(n-1,1))**2) + enddo + XL2=0. + nlpts2=mappt(k2) + do n=2,nlpts2 + XL2(n)=XL2(n-1)+SQRT((XL(N,2)-XL(n-1,2))**2+(YL(n,2)-YL(n-1,2))**2) + enddo + xmean=(XL1(nlpts1)+XL2(nlpts2))/2. +! +! get size spacing +! + along=xmean/xsz + NX=(along+0.99) + + NXP=NX+1 + NYP=NY+1 + NRL=NX*NYP+1 + NRT=NXP*NYP + + DO N=1,NE + DO M=1,8 + NOPSV(N,M)=NOP(N,M) + ENDDO + IMATSV(N)=IMAT(N) + ENDDO + NESAV=NE + NEFSAV=NENTRY + NPUNDO=NRT + +! Initialize GRIDX and GRIDY + + DO N=1,NRT + GRIDX(N)=0. +! GRIDY(N)=0. + IGSKP(N)=0 + END DO +! +! calculate lengths +! + xalong1=XL1(nlpts1)/NX + xalong2=XL2(nlpts2)/NX +! +! compute cords along the edges +! + XALONG=0. + XXALONG=0. + GRIDX(1)=XL(1,1) + GRIDY(1)=YL(1,1) + GRIDX(NYP)=XL(1,2) + GRIDY(NYP)=YL(1,2) + NRT=NXP*NYP + NX1=2 + NX2=2 + NCR=1 + DO N=NY+2,NRT,NYP + NCR=NCR+1 + XALONG=XALONG+XALONG1 + DO M=NX1,NLPTS1 + IF(XALONG .LT. XL1(M)) THEN + M1=M + GO TO 200 + ENDIF + ENDDO + 200 CONTINUE + FRAC1=(XALONG-XL1(M1-1))/(XL1(M1)-XL1(M1-1)) + GRIDX(N)=XL(m1-1,1)+FRAC1*(XL(m1,1)-XL(m1-1,1)) + GRIDY(N)=YL(m1-1,1)+FRAC1*(YL(m1,1)-YL(m1-1,1)) + NX1=M1 + XXALONG=XXALONG+XALONG2 + DO M=NX2,NLPTS2 + IF(XXALONG .LT. XL2(M)) THEN + M2=M + GO TO 250 + ENDIF + ENDDO + 250 CONTINUE + FRAC1=(XXALONG-XL2(M2-1))/(XL2(M2)-XL2(M2-1)) + GRIDX(N+NY)=XL(m2-1,2)+FRAC1*(XL(m2,2)-XL(m2-1,2)) + GRIDY(N+NY)=YL(m2-1,2)+FRAC1*(YL(m2,2)-YL(m2-1,2)) + NX2=M2 + + ANGD1=GETANG1(GRIDX(N-NY-1),GRIDY(N-NY-1),GRIDX(N),GRIDY(N),GRIDX(N+NY),GRIDY(N+NY)) + ANGD2=GETANG1(GRIDX(N),GRIDY(N),GRIDX(N+NY),GRIDY(N+NY),GRIDX(N-1),GRIDY(N-1)) + ANGM1=(ANGD1+180-ANGD2)/2. +! WRITE(151,*) N,ANGD1,ANGD2,ANGM1 + IF(ITEST .EQ. 1) THEN + XALONGKP=XALONG + XXALONGKP=XXALONG +! write(151,*) 'b',xalong,xxalong + IF(ANGM1 .GT. 100. .OR. ANGM1 .LT. 80.) THEN + IF(ANGM1 .GT. 100) THEN + XALONG=XALONG+XALONG1/2. + XXALONG=XXALONG-XALONG2/2. + ELSE + XALONG=XALONG-XALONG1/2. + XXALONG=XXALONG+XALONG2/2. + ENDIF +! WRITE(151,*) 'a',XALONG,XXALONG + itag=0 + 275 CONTINUE + DO M=1,NLPTS1 + IF(XALONG .LT. XL1(M)) THEN + M1=M + GO TO 300 + ENDIF + ENDDO + 300 CONTINUE + FRAC1=(XALONG-XL1(M1-1))/(XL1(M1)-XL1(M1-1)) + GRIDX(N)=XL(m1-1,1)+FRAC1*(XL(m1,1)-XL(m1-1,1)) + GRIDY(N)=YL(m1-1,1)+FRAC1*(YL(m1,1)-YL(m1-1,1)) + NX1=M1 + DO M=1,NLPTS2 + IF(XXALONG .LT. XL2(M)) THEN + M2=M + GO TO 350 + ENDIF + ENDDO + 350 CONTINUE + FRAC1=(XXALONG-XL2(M2-1))/(XL2(M2)-XL2(M2-1)) + GRIDX(N+NY)=XL(m2-1,2)+FRAC1*(XL(m2,2)-XL(m2-1,2)) + GRIDY(N+NY)=YL(m2-1,2)+FRAC1*(YL(m2,2)-YL(m2-1,2)) + NX2=M2 + ANGD3=GETANG1(GRIDX(N-NY-1),GRIDY(N-NY-1),GRIDX(N),GRIDY(N),GRIDX(N+NY),GRIDY(N+NY)) + ANGD4=GETANG1(GRIDX(N),GRIDY(N),GRIDX(N+NY),GRIDY(N+NY),GRIDX(N-1),GRIDY(N-1)) + ANGM2=(ANGD3+180-ANGD4)/2. +! WRITE(151,*) N,ANGD3,ANGD4,ANGM2 + if(itag .eq. itest) go to 375 + IF(ANGM1 .LT. 80. .AND. ANGM2 .GT. 100.) THEN + FRAC=(ANGM2-90)/(ANGM2-ANGM1) + XALONG=XALONG+XALONG1/2.*FRAC + XXALONG=XXALONG-XALONG2/2.*FRAC + itag=1 +! WRITE(151,*) XALONG,XXALONG + GO TO 275 + ELSEIF(ANGM1 .GT. 100. .AND. ANGM2 .LT. 80.) THEN + FRAC=(90-ANGM2)/(ANGM1-ANGM2) + XALONG=XALONG-XALONG1/2.*FRAC + XXALONG=XXALONG+XALONG2/2.*FRAC + itag=1 +! WRITE(151,*) XALONG,XXALONG + GO TO 275 +! WRITE(151,*) XALONG,XXALONG + ENDIF + XALONG1=(XL1(nlpts1)-XALONG)/(NXP-NCR) + XALONG2=(XL2(nlpts2)-XXALONG)/(NXP-NCR) + 375 continue + ENDIF + ENDIF + ENDDO +! +! +! check if points ok allow for move +! +! +! form elements and other coordinates +! +! +! Interpolate interior points +! + DO M=1,NRT,NYP + NFS=NRL+M-1 + CALL INTERP(GRIDX,GRIDY,M,M+NY,1,GRIDX(M),GRIDY(M),GRIDX(M+NY) & + & ,GRIDY(M+NY),NY,0) + DO N=M,M+NY + GRIDXL(N)=GRIDX(N) + GRIDYL(N)=GRIDY(N) + GRIDX(N) =(GRIDXL(N)+XS)/TXSCAL + GRIDY(N) =(GRIDYL(N)+YS)/TXSCAL + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + SIZ=0.1 + CALL RRed + call drawcr(xtemp,ytemp,siz) + CALL RBlue + ENDDO + END DO +! +! query for depths +! +! +! query for happY + DO 500 N=1,NRT +! +! Find next blank node in CORD +! + CALL GETNOD(J) + NODDEL(N)=J +! +! Store GRIDX and GRIDY into it +! + CORD(J,1) = GRIDX(N) + CORD(J,2) = GRIDY(N) + IGRIDE(N) = J + INEW(J) = 1 + INSKP(J) = 0 + WD(J)=-9999. +! + XUSR(J) = GRIDX(N)*TXSCAL - XS + YUSR(J) = GRIDY(N)*TXSCAL - YS +! +! Display point +! + CALL PLTNOD(J,1) +! + 500 END DO +! +! Generate elements +! + CALL GETELM(K) + IECHG=0 +! + DO 600 I=1,NX + DO 590 J=1,NY + CALL GETELM(K) + NOP(K,1)=IGRIDE((I-1)*NYP+J) + NOP(K,2)=0 + NOP(K,3)=IGRIDE(I*NYP+J) + NOP(K,4)=0 + NOP(K,5)=IGRIDE(I*NYP+J+1) + NOP(K,6)=0 + NOP(K,7)=IGRIDE((I-1)*NYP+J+1) + NOP(K,8)=0 + IMAT(K)=1 +! IF(K .GT. NE) NE=K + NCORN(K)=8 + IESKP(K)=0 +!IPK JAN98 + IERC=0 + CALL PLTELM(K,IERC) + 590 CONTINUE + 600 END DO + CALL WRTOUT(0) + RETURN + end + + REAL*8 FUNCTION GETANG1(X1,Y1,X2,Y2,X3,Y3) + REAL*8 X1,Y1,X2,Y2,X3,Y3,CAN + C=SQRT((X2-X1)**2+(Y2-Y1)**2) + B=SQRT((X3-X2)**2+(Y3-Y2)**2) + A=SQRT((X1-X3)**2+(Y1-Y3)**2) + CAN=(B**2+C**2-A**2)/(2.*B*C) + GETANG1=DACOSD(CAN) + RETURN + END + + SUBROUTINE PANELgenblk(N1,XL,N2,N3,ISW1,ISW2,ITEST) + + use winteracter + + implicit none + + include 'D.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR,IFIRST,ISW1,ISW2,ITEST + real :: XL + character*3 :: sub + DATA IFIRST/0/ + + IF(IFIRST .EQ. 0) THEN + IFIRST=1 + N1=1 + N2=1 + N3=2 + XL=5. + isw1=0 + isw2=0 + ENDIF + call wdialogload(IDD_GENBLK) + ierr=infoerror(1) + + CALL WDialogPutInteger(idf_integer1,n1) + CALL WDialogPutInteger(idf_integer2,n2) + CALL WDialogPutInteger(idf_integer3,n3) + CALL WDialogPutInteger(idf_integer5,ITEST) + CALL WDialogPutReal(idf_real1,xl) + CALL WDialogPutCheckBox(idf_check1,isw1) + CALL WDialogPutCheckBox(idf_check2,isw2) + CALL WDialogSelect(IDD_GENBLK) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(idf_integer1,n1) + CALL WDialogGetInteger(idf_integer2,n2) + CALL WDialogGetInteger(idf_integer3,n3) + CALL WDialogGetReal(idf_real1,xl) + CALL WDialogGetInteger(idf_integer5,ITEST) + CALL WDialogGetCheckBox(idf_check1,isw1) + CALL WDialogGetCheckBox(idf_check2,isw2) + + + ENDIF + RETURN + END + \ No newline at end of file diff --git a/src/src83e/CRSECT.F90 b/src/src83e/CRSECT.F90 new file mode 100644 index 0000000..5e50547 --- /dev/null +++ b/src/src83e/CRSECT.F90 @@ -0,0 +1,158 @@ +!-----------------------------------------------------------------crsect + subroutine crsect +!----------------------------------------------------------------------c +! purpose: c +! To plot a selected cross section and calculate width and c +! slopes. c +! ycw mar97 c +!----------------------------------------------------------------------c + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! include 'BLK1.COM' +! include 'BLK2.COM' + + real XPL(5),YPL(5),ss0(50) + CHARACTER*1 ANS,ANSW(0:4),IFLAG + CHARACTER*6 DESCR + + INCLUDE 'TXFRM.COM' + + COMMON /XYGRPH/ XVALUES(10000,10),YVALUES(10000,10),TIMMIN,VALMIN,TIMMAX,VALMAX,NVALUES,NSETS,LINPROP(10) + + COMMON /HEDS1/ NWINDWS,IWNDWS(10),ISCRNS(10),DESCR(10),ICRSR(10) + DATA MAN/1/ + +! +!------get cross section number +! +! 100 NHTP=0 +! NMESS=29 +! NBRR=6 + call selcrs(man) + + if(man .eq. 2) then + call setlim(timmin,timmax,valmin,valmax) + else + +! +!......establish shape of curve +! + + timmin=1.e20 + valmin=1.e20 + timmax=-1.e20 + valmax=-1.e20 + endif + + DO J=1,5 + icr=icrsr(j) + if(icr .gt. 0) then + do i=nrivl(icr),1,-1 + + ii=nrivl(icr)-i+1 + xvalues(ii,j)=-crsdat(icr,i,3)/2. + yvalues(ii,j)=crsdat(icr,i,1) + ij=nrivl(icr)+i + xvalues(ij,j)=crsdat(icr,i,3)/2. + yvalues(ij,j)=crsdat(icr,i,1) + + enddo + nsets=j + + if(man .eq. 1) then + timmin=min(timmin,-crsdat(icr,nrivl(icr),3)/2.) + valmin=min(valmin,crsdat(icr,1,1)) + timmax=max(timmax,crsdat(icr,nrivl(icr),3)/2.) + valmax=max(valmax,crsdat(icr,nrivl(icr),1)) + endif + + NVALUES=2*nrivl(icr) + write(DESCR(j),'(i6)') ICR + endif + enddo + call dograph(2,icurwin) + iscrns(icurwin)=3 + + return + END + + subroutine selcrs(MAN) + + USE WINTERACTER + INCLUDE 'D.INC' + CHARACTER*6 DESCR + + COMMON /HEDS1/ NWINDWS,IWNDWS(10),ISCRNS(10),DESCR(10),ICRSR(10) + + call wdialogload(IDD_SELCRSEC) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_SECCRSEC) + ierr=infoerror(1) + + do i=1,5 + CALL WGridPutCellInteger(IDF_GRID1,i,1,icrsr(i)) + enddo + + if(man .eq. 1) then + CALL WDialogPutRadioButton(IDF_RADIO1) + else + CALL WDialogPutRadioButton(IDF_RADIO2) + endif + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + do i=1,5 + CALL WGridGetCellInteger(IDF_GRID1,i,1,icrsr(i)) + enddo + CALL WDialogGetRadioButton(IDF_RADIO1,man) + return + else + return + endif + + enddo + return + + end + + subroutine setlim(timmin,timmax,valmin,valmax) + + USE WINTERACTER + INCLUDE 'D.INC' + CHARACTER*6 DESCR + + call wdialogload(IDD_LIMITS) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_LIMITS) + ierr=infoerror(1) + + + CALL WDialogPutReal(IDF_REAL1,TIMMIN) + CALL WDialogPutReal(IDF_REAL2,TIMMAX) + CALL WDialogPutReal(IDF_REAL3,VALMIN) + CALL WDialogPutReal(IDF_REAL4,VALMAX) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetReal(IDF_REAL1,TIMMIN) + CALL WDialogGetReal(IDF_REAL2,TIMMAX) + CALL WDialogGetReal(IDF_REAL3,VALMIN) + CALL WDialogGetReal(IDF_REAL4,VALMAX) + return + else + return + endif + + enddo + return + + end \ No newline at end of file diff --git a/src/src83e/CSETNEW.F90 b/src/src83e/CSETNEW.F90 new file mode 100644 index 0000000..d31ff3a --- /dev/null +++ b/src/src83e/CSETNEW.F90 @@ -0,0 +1,407 @@ + SUBROUTINE CSET(TTMIN,TTMAX,isz) + + USE WINTERACTER + SAVE + INTEGER ICK5 +! + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL +!IPK APR94 + COMMON /RECOD/ IRECD,TSPC + DIMENSION NKEY(99) + CHARACTER*80 ILIND + LOGICAL SWITCH + DATA ITIM,VDM /0,-1.E15/ +! + call setd(24) + IF(ITIM .EQ. 0) THEN + OMAX=VDM + OMIN=VDM + ick5=0 + DO 200 N=1,99 + CONTUR(N)=VDM + 200 CONTINUE + ITIM=ITIM+1 + ELSE + ITIM=ITIM+1 + ENDIF +! +! + 13 continue +! +! isz = 0 means no choice for data +! = 1 means data selectd +! + IF(TTMAX .EQ. TTMIN) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,& + 'There are no contours for this case MAX=MIN'//CHAR(13)//'The model will return ','CONTOUR ERROR') + 5010 FORMAT(F5.2) + RETURN +!ipk apr94 + ENDIF + IF(ICK5 .EQ. 1) GO TO 250 +! +! get an estimate of contour values +! + AT=ALOG10(TTMAX-TTMIN) + IF(AT .LT. 0.) THEN + CINTER = 10. ** (IFIX(AT - .5) - 1) + ELSE + CINTER = 10. ** (IFIX(AT + .5) - 1) + ENDIF +! CINTER = 10. ** (IFIX(ALOG10(TTMAX-TTMIN) + .5) - 1) + 235 FINTER = CINTER +! write(*,*) cinter,numv + IF(TTMIN .GT. 0.) THEN + CONTUR(1)=IFIX(TTMIN/CINTER)*CINTER+0.001*cinter + ELSE + CONTUR(1)=IFIX((TTMIN-CINTER)/CINTER)*CINTER+0.001*cinter + ENDIF + NUMV=1 + DO 240 N=2,99 + CONTUR(N)=CONTUR(N-1)+FINTER + IF(CONTUR(N) .GT. TTMAX) THEN + NUMV=N + GO TO 245 + ENDIF + 240 END DO + NUMV=99 + 245 IF(NUMV .GT. 16) THEN + CINTER=CINTER*2. + GO TO 235 + ENDIF + DO 247 N=NUMV+1,99 + CONTUR(N)=VDM + 247 END DO + 250 CONTINUE +! +! print options when no startup data available +! + if(isz .eq. 1) then + call conpanel(icsp,ttmin,ttmax,numv,contur,omax,omin,ick5) + if(icsp .lt. 0) then + GO TO 405 + elseif(icsp .eq. 0) then + go to 405 + endif + + + IF(ABS(ICSP) .EQ. 1) THEN + icsp=0 +! +! this is log spacing +! + IF(TTMAX .GT. 0.) THEN + ALMAX=ALOG10(TTMAX) + ELSE + call clscrn + call symbl (0.1,7.0,0.25, & + & 'Maximum contour value is negative',0.0,33) + call symbl (0.1,6.5,0.25, & + & 'Reconsider your choice',0.0,22) + GO TO 250 + ENDIF + IF(TTMIN .GT. 0.) THEN + ALMIN=ALOG10(TTMIN) +!ipk oct94 add a switch + IMINSW=0 + ELSE + call clscrn + call symbl (0.1,7.0,0.25, & + & 'Minimum contour value is negative',0.0,33) + call symbl (0.1,6.5,0.25, & + & 'Value set to 10**10 less than max value',0.0,39) + ALMIN=ALMAX-10. +!ipk oct 94 add a switch + IMINSW=1 + ENDIF +! + ALMIN=ALMAX-4. +! + IF(ALMAX .GT. 0.) THEN + LMAX=ALMAX + ELSE + LMAX=ALMAX-1. + ENDIF + IF(ALMIN .GT. 0.) THEN + LMIN=ALMIN+1. + ELSE + LMIN=ALMIN + ENDIF +!ipk oct94 NUMV=LMAX-LMIN+1 + NUMV=LMAX-LMIN+1+IMINSW + IF(NUMV .LT. 8) THEN + NUMV=NUMV*2 + IDB=2 + ELSE + IDB=1 + ENDIF +!ipk oct94 + IF(IMINSW .EQ. 1) THEN + CONTUR(1)=0. + CONTUR(2)=10.**LMIN + K=2 + ELSE + CONTUR(1)=10.**LMIN + K=1 + ENDIF + IPW=LMIN + DO 350 N=IMINSW+2,NUMV,IDB + IF(IDB .EQ. 2) THEN + K=K+1 + CONTUR(K)=CONTUR(K-1)*3. + ENDIF + IPW=IPW+1 + K=K+1 + CONTUR(K)=10.**IPW + 350 CONTINUE + numv=k +! +! this is for entry of chosen contours +! + ELSEIF(abs(ICSP) .EQ. 2) THEN + icsp=0 + CALL SORT(CONTUR,NKEY,NUMV) + ELSEIF(abs(ICSP) .EQ. 3) THEN + icsp=0 + cinter=omax-omin + if(cinter .gt. 0.) then + cinter=cinter/(numv-1) + else + cinter=1.0 + endif + contur(1)=omin + do i=2,numv + contur(i)=contur(i-1)+cinter + enddo + ENDIF + GO TO 250 +!ipk july 1995 add this line + 405 CONTINUE + ENDIF + call setd(2) + RETURN + END + + + + subroutine conpanel(icsp,ttmin,ttmax,numv,contur,omax,omin,ick5) + + use winteracter + implicit none + + save + + include 'D.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: icsp,numv,nlim,ict,ictx,ick1,ick2,ick3,ick4,ick5,ierr,idf,ipos,numvold + real :: ttmin,ttmax,contur(99),omax,omin,VDX + character*80 labmax,labmin,labnum,labcon(30),labomax,labomin + VDX=-1.E14 + write(labmax,'(f10.3)') ttmax + write(labmin,'(f10.3)') ttmin + + if(omax .lt. vdx) then + labomax=labmax + else + write(labomax,'(f10.3)') omax + endif + + if(omin .lt. vdx) then + labomin=labmin + else + write(labomin,'(f10.3)') omin + endif + write(labnum,'(i10)') numv + nlim=numv + if(nlim .gt. 30) nlim=numv + do ict=1,nlim + write(labcon(ict),'(f10.3)') contur(ict) + enddo + if(numv .lt. 30) then + do ict=numv+1,30 + labcon(ict)=' ' + enddo + endif + + 90 continue + numvold=numv + + call wdialogload(IDD_DIALOG02) + ierr=infoerror(1) + + CALL WDialogPutString(idf_string1,labmax) + CALL WDialogPutString(idf_string2,labmin) + CALL WDialogPutString(idf_string3,labomax) + CALL WDialogPutString(idf_string22,labomin) + CALL WDialogPutString(idf_string23,labnum) + + ictx=0 + do ict=idf_string4,idf_string4+18-1 + ictx=ictx+1 + CALL WDialogPutString(ict,labcon(ictx)) + enddo + ictx=ictx+1 + ICT=idf_string24 + CALL WDialogPutString(ict,labcon(ictx)) + + DO ict=idf_string25,idf_string25+9 + ictx=ictx+1 + CALL WDialogPutString(ict,labcon(ictx)) + enddo + ictx=ictx+1 + ICT=idf_string35 + CALL WDialogPutString(ict,labcon(ictx)) + +! call wdialogputcheckbox(idf_check1,0) +! call wdialogputcheckbox(idf_check2,0) +! call wdialogputcheckbox(idf_check3,0) +! call wdialogputcheckbox(idf_check4,0) + call wdialogputcheckbox(idf_check5,ick5) +! if(icsp .eq. 0) then + call wdialogputRadioButton(idf_check1) +! endif + + + CALL WDialogSelect(IDD_DIALOG02) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + +! call wdialoggetcheckbox(idf_check1,ick1) +! call wdialoggetcheckbox(idf_check2,ick2) +! call wdialoggetcheckbox(idf_check3,ick3) +! call wdialoggetcheckbox(idf_check4,ick4) + call wdialoggetcheckbox(idf_check5,ick5) + CALL WDialoggetString(idf_string1,labmax) + CALL WDialoggetString(idf_string2,labmin) + CALL WDialoggetString(idf_string3,labomax) + CALL WDialoggetString(idf_string22,labomin) + CALL WDialoggetString(idf_string23,labnum) + call wdialoggetradiobutton(idf_check1,ipos) + call IStringToInteger(labnum,numv) + write(90,*) 'numvold',numvold,numv,ipos + if(numvold .ne. numv .and. ipos .ne. 4) ipos=3 +!C if(ick1 .eq. 1) then +!C icsp=0 +!C else + icsp=0 + if(ipos .eq. 2) then + icsp=1 + elseif(ipos .eq. 3) then + icsp=3 + write(90,'(a)') 'numv',labnum + call IStringToInteger(labnum,numv) + if(infoError(1) .gt. 0) then + call wdialogload(IDD_DIALOG04) + CALL WDialogSelect(IDD_DIALOG04) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + 120 continue + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + go to 90 + endif + go to 120 + endif + call IStringToReal(labomax,omax) + if(infoError(1) .gt. 0) then + call wdialogload(IDD_DIALOG04) + CALL WDialogSelect(IDD_DIALOG04) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + 130 continue + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + go to 90 + endif + go to 130 + endif + call IStringToReal(labomin,omin) + if(infoError(1) .gt. 0) then + call wdialogload(IDD_DIALOG04) + CALL WDialogSelect(IDD_DIALOG04) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + 140 continue + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + go to 90 + endif + go to 140 + endif + elseif(ipos .eq. 4) then + icsp=2 + write(90,'(a)') 'numv-4',labnum +! read(labnum,*) numv + call IStringToInteger(labnum,numv) + if(infoError(1) .gt. 0) then + call wdialogload(IDD_DIALOG04) + CALL WDialogSelect(IDD_DIALOG04) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + 150 continue + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + go to 90 + endif + go to 150 + endif + write(90,*) numv + ictx=0 + do ict=idf_string4,idf_string4+18-1 + ictx=ictx+1 + CALL WDialogGetString(ict,labcon(ictx)) + enddo + ictx=ictx+1 + ICT=idf_string24 + CALL WDialogGetString(ict,labcon(ictx)) + do ict=idf_string25,idf_string25+9 + ictx=ictx+1 + CALL WDialogGetString(ict,labcon(ictx)) + enddo + ictx=ictx+1 + ICT=idf_string35 + CALL WDialogGetString(ict,labcon(ictx)) + do ict=1,numv +! read(labcon(ict),*) contur(ict) + call IStringToReal(labcon(ict),contur(ict)) + if(infoError(1) .gt. 0) then + call wdialogload(IDD_DIALOG04) + CALL WDialogSelect(IDD_DIALOG04) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + 160 continue + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + go to 90 + endif + go to 160 + endif + write(90,*) 'con',ict,contur(ict) + enddo + endif + + if(ipos .eq. 5) then + icsp=-5 +! abs(icsp) + endif + write(90,*) 'icsp',icsp,omax,omin,numv,ipos +! write(90,*) 'ick',ick1,ick2,ick3,ick4,ick5 + return + + endif + return + enddo + return + end diff --git a/src/src83e/D.INC b/src/src83e/D.INC new file mode 100644 index 0000000..70b1d42 --- /dev/null +++ b/src/src83e/D.INC @@ -0,0 +1,367 @@ +! Winteracter resource identifiers. Created : 13/Feb/2017 12:04:28 +! +! This file is generated by the Winteracter resource editor. +! It should not be edited manually. It is also not advisable to load this +! file in a text editor, while working on the associated resource file, +! since this may prevent the resource identifiers file from being updated. +! To view the names and values of resource identifiers, use the +! "Identifier Names and Values" or "Used Identifiers" options on the +! resource editor's "View" menu. Both dialogs also include a "Copy id" +! button which allows identifier names to be copied via the clipboard. +! Opening this file in an editor should therefore not be necessary. +! + INTEGER, PARAMETER :: IDR_MENU1 = 30001 + INTEGER, PARAMETER :: ID_FILE = 40001 + INTEGER, PARAMETER :: ID_EXIT = 40002 + INTEGER, PARAMETER :: ID_NODE = 40003 + INTEGER, PARAMETER :: ID_ELTS = 40004 + INTEGER, PARAMETER :: ID_ORDRT = 40005 + INTEGER, PARAMETER :: ID_CCLNA = 40006 + INTEGER, PARAMETER :: ID_CSEC1 = 40007 + INTEGER, PARAMETER :: ID_ZOOM = 40008 + INTEGER, PARAMETER :: ID_DRAW = 40009 + INTEGER, PARAMETER :: ID_HELP = 40010 + INTEGER, PARAMETER :: ID_STRING1 = 50001 + INTEGER, PARAMETER :: ID_STRING2 = 50002 + INTEGER, PARAMETER :: ID_STRING3 = 50003 + INTEGER, PARAMETER :: ID_STRING4 = 50004 + INTEGER, PARAMETER :: ID_STRING5 = 50005 + INTEGER, PARAMETER :: ID_STRING6 = 50006 + INTEGER, PARAMETER :: ID_STRING7 = 50007 + INTEGER, PARAMETER :: ID_STRING8 = 50008 + INTEGER, PARAMETER :: ID_STRING9 = 50009 + INTEGER, PARAMETER :: ID_STRING10 = 50010 + INTEGER, PARAMETER :: ID_STRING11 = 50011 + INTEGER, PARAMETER :: ID_ITEM11 = 40011 + INTEGER, PARAMETER :: ID_ITEM12 = 40012 + INTEGER, PARAMETER :: ID_ITEM13 = 40013 + INTEGER, PARAMETER :: ID_ITEM14 = 40014 + INTEGER, PARAMETER :: ID_ITEM15 = 40015 + INTEGER, PARAMETER :: ID_ITEM16 = 40016 + INTEGER, PARAMETER :: ID_ITEM17 = 40017 + INTEGER, PARAMETER :: ID_ITEM18 = 40018 + INTEGER, PARAMETER :: ID_ITEM19 = 40019 + INTEGER, PARAMETER :: IDF_STRING24 = 1041 + INTEGER, PARAMETER :: IDD_DIALOG1 = 101 + INTEGER, PARAMETER :: IDF_LABEL5 = 1042 + INTEGER, PARAMETER :: IDC_BUTTON2 = 20001 + INTEGER, PARAMETER :: ID_ITEM20 = 40021 + INTEGER, PARAMETER :: ID_ITEM73 = 40022 + INTEGER, PARAMETER :: ID_ITEM23 = 40023 + INTEGER, PARAMETER :: ID_ITEM24 = 40024 + INTEGER, PARAMETER :: ID_TOOLBAR1 = 30101 + INTEGER, PARAMETER :: ID_ZIN = 40025 + INTEGER, PARAMETER :: ID_ZOUT = 40026 + INTEGER, PARAMETER :: ID_OUT2 = 40027 + INTEGER, PARAMETER :: ID_OUT4 = 40028 + INTEGER, PARAMETER :: ID_RSET = 40029 + INTEGER, PARAMETER :: ID_PLEFT = 40031 + INTEGER, PARAMETER :: ID_PRIGHT = 40032 + INTEGER, PARAMETER :: ID_PUP = 40033 + INTEGER, PARAMETER :: ID_PDOWN = 40034 + INTEGER, PARAMETER :: ID_IDRWT = 40035 + INTEGER, PARAMETER :: ID_TYPD = 40039 + INTEGER, PARAMETER :: ID_DRAWD = 40041 + INTEGER, PARAMETER :: ID_MAPOPD = 40042 + INTEGER, PARAMETER :: ID_CONTR = 40060 + INTEGER, PARAMETER :: IDF_LABEL1 = 1001 + INTEGER, PARAMETER :: IDF_LABEL2 = 1002 + INTEGER, PARAMETER :: IDF_LABEL3 = 1003 + INTEGER, PARAMETER :: IDF_LABEL4 = 1004 + INTEGER, PARAMETER :: IDF_STRING1 = 1013 + INTEGER, PARAMETER :: IDF_STRING2 = 1014 + INTEGER, PARAMETER :: IDF_STRING3 = 1015 + INTEGER, PARAMETER :: IDF_STRING4 = 1016 + INTEGER, PARAMETER :: IDF_STRING5 = 1017 + INTEGER, PARAMETER :: IDF_STRING6 = 1018 + INTEGER, PARAMETER :: IDF_STRING7 = 1019 + INTEGER, PARAMETER :: IDF_STRING8 = 1020 + INTEGER, PARAMETER :: IDF_STRING9 = 1021 + INTEGER, PARAMETER :: IDF_STRING10 = 1022 + INTEGER, PARAMETER :: IDF_STRING11 = 1023 + INTEGER, PARAMETER :: IDF_STRING12 = 1024 + INTEGER, PARAMETER :: IDD_DIALOG02 = 102 + INTEGER, PARAMETER :: IDF_STRING13 = 1025 + INTEGER, PARAMETER :: IDF_STRING14 = 1026 + INTEGER, PARAMETER :: IDF_STRING15 = 1027 + INTEGER, PARAMETER :: IDF_STRING16 = 1028 + INTEGER, PARAMETER :: IDF_STRING17 = 1029 + INTEGER, PARAMETER :: IDF_STRING18 = 1030 + INTEGER, PARAMETER :: IDF_STRING19 = 1031 + INTEGER, PARAMETER :: IDF_STRING20 = 1032 + INTEGER, PARAMETER :: IDF_STRING21 = 1033 + INTEGER, PARAMETER :: IDF_STRING22 = 1034 + INTEGER, PARAMETER :: IDF_STRING23 = 1035 + INTEGER, PARAMETER :: IDF_CHECK1 = 1036 + INTEGER, PARAMETER :: IDF_CHECK2 = 1037 + INTEGER, PARAMETER :: IDF_CHECK3 = 1038 + INTEGER, PARAMETER :: IDF_CHECK4 = 1039 + INTEGER, PARAMETER :: IDF_CHECK5 = 1040 + INTEGER, PARAMETER :: ID_DCONTR = 40056 + INTEGER, PARAMETER :: ID_CONTOPT = 40061 + INTEGER, PARAMETER :: ID_ITYPN = 40064 + INTEGER, PARAMETER :: ID_ITYPC = 40065 + INTEGER, PARAMETER :: ID_ICOPY = 40067 + INTEGER, PARAMETER :: IDD_DIALOG04 = 104 + INTEGER, PARAMETER :: ID_BACGD = 40050 + INTEGER, PARAMETER :: ID_ITEM26 = 40071 + INTEGER, PARAMETER :: IDD_DIALOG05 = 103 + INTEGER, PARAMETER :: IDF_CMAP8 = 1005 + INTEGER, PARAMETER :: IDF_CMAP9 = 1006 + INTEGER, PARAMETER :: IDF_CMAP0 = 1007 + INTEGER, PARAMETER :: IDF_CMAP1 = 1008 + INTEGER, PARAMETER :: IDF_CMAP2 = 1009 + INTEGER, PARAMETER :: IDF_CMAP10 = 1010 + INTEGER, PARAMETER :: IDF_CMAP11 = 1011 + INTEGER, PARAMETER :: IDF_CMAP3 = 1012 + INTEGER, PARAMETER :: IDF_CMAP4 = 1043 + INTEGER, PARAMETER :: IDF_CMAP5 = 1044 + INTEGER, PARAMETER :: IDF_CMAP6 = 1045 + INTEGER, PARAMETER :: IDF_CMAP7 = 1046 + INTEGER, PARAMETER :: IDD_DIALOG006 = 105 + INTEGER, PARAMETER :: IDF_RADIO1 = 1047 + INTEGER, PARAMETER :: IDF_RADIO2 = 1048 + INTEGER, PARAMETER :: IDF_RADIO3 = 1049 + INTEGER, PARAMETER :: IDF_RADIO4 = 1050 + INTEGER, PARAMETER :: IDF_RADIO5 = 1051 + INTEGER, PARAMETER :: IDF_RADIO6 = 1052 + INTEGER, PARAMETER :: IDF_RADIO7 = 1053 + INTEGER, PARAMETER :: IDF_RADIO8 = 1054 + INTEGER, PARAMETER :: IDF_RADIO9 = 1055 + INTEGER, PARAMETER :: ID_MMAP = 40043 + INTEGER, PARAMETER :: IDD_DIALOG07 = 106 + INTEGER, PARAMETER :: IDD_DIALOG08 = 107 + INTEGER, PARAMETER :: ID_Help1 = 40040 + INTEGER, PARAMETER :: ID_Help2 = 40044 + INTEGER, PARAMETER :: IDD_DIALOG09 = 108 + INTEGER, PARAMETER :: IDF_LABEL7 = 1056 + INTEGER, PARAMETER :: IDD_DIALOG10 = 109 + INTEGER, PARAMETER :: IDF_INTEGER1 = 1057 + INTEGER, PARAMETER :: IDF_INTEGER2 = 1058 + INTEGER, PARAMETER :: ID_LAYFL = 40046 + INTEGER, PARAMETER :: IDF_RADIO10 = 1056 + INTEGER, PARAMETER :: IDD_DIALOG010 = 110 + INTEGER, PARAMETER :: IDD_DIALOG001 = 111 + INTEGER, PARAMETER :: ID_BKF = 40047 + INTEGER, PARAMETER :: IDD_DIALOG012 = 113 + INTEGER, PARAMETER :: IDF_CHECK6 = 1041 + INTEGER, PARAMETER :: IDF_CHECK7 = 1042 + INTEGER, PARAMETER :: IDF_CHECK8 = 1043 + INTEGER, PARAMETER :: IDF_CHECK9 = 1044 + INTEGER, PARAMETER :: IDF_CHECK10 = 1045 + INTEGER, PARAMETER :: IDF_CHECK11 = 1059 + INTEGER, PARAMETER :: ID_Clip = 40020 + INTEGER, PARAMETER :: ID_UNDOM = 40030 + INTEGER, PARAMETER :: ID_BSEL = 40036 + INTEGER, PARAMETER :: ID_REGST = 40037 + INTEGER, PARAMETER :: IDD_REGST = 112 + INTEGER, PARAMETER :: IDF_LABEL6 = 1005 + INTEGER, PARAMETER :: IDF_REAL1 = 1060 + INTEGER, PARAMETER :: IDF_REAL2 = 1061 + INTEGER, PARAMETER :: IDF_REAL3 = 1062 + INTEGER, PARAMETER :: IDF_REAL4 = 1063 + INTEGER, PARAMETER :: IDF_LABEL8 = 1006 + INTEGER, PARAMETER :: IDF_LABEL9 = 1007 + INTEGER, PARAMETER :: IDF_LABEL10 = 1008 + INTEGER, PARAMETER :: IDF_LABEL11 = 1043 + INTEGER, PARAMETER :: IDF_REAL5 = 1064 + INTEGER, PARAMETER :: IDF_REAL6 = 1065 + INTEGER, PARAMETER :: IDF_REAL7 = 1066 + INTEGER, PARAMETER :: IDF_REAL8 = 1067 + INTEGER, PARAMETER :: IDF_LABEL12 = 1009 + INTEGER, PARAMETER :: IDADJUST = 1068 + INTEGER, PARAMETER :: IDFSWITCH = 1069 + INTEGER, PARAMETER :: IDD_SLRGNO = 114 + INTEGER, PARAMETER :: IDD_CONFIRM = 115 + INTEGER, PARAMETER :: ID_network = 40038 + INTEGER, PARAMETER :: ID_NMAP = 40045 + INTEGER, PARAMETER :: ID_ITEM56 = 40048 + INTEGER, PARAMETER :: ID_Nodedata = 40049 + INTEGER, PARAMETER :: ID_Eltdata = 40051 + INTEGER, PARAMETER :: IDD_nodedata = 116 + INTEGER, PARAMETER :: IDF_REAL9 = 1068 + INTEGER, PARAMETER :: IDF_REAL10 = 1069 + INTEGER, PARAMETER :: IDD_eltdata = 117 + INTEGER, PARAMETER :: IDF_INTEGER3 = 1059 + INTEGER, PARAMETER :: IDF_INTEGER4 = 1060 + INTEGER, PARAMETER :: IDF_INTEGER5 = 1061 + INTEGER, PARAMETER :: IDF_INTEGER6 = 1062 + INTEGER, PARAMETER :: IDF_INTEGER7 = 1063 + INTEGER, PARAMETER :: IDF_INTEGER8 = 1064 + INTEGER, PARAMETER :: IDF_INTEGER9 = 1070 + INTEGER, PARAMETER :: IDF_INTEGER10 = 1071 + INTEGER, PARAMETER :: IDD_SELNODE = 118 + INTEGER, PARAMETER :: IDNEXT = 1072 + INTEGER, PARAMETER :: IDD_SELELT = 119 + INTEGER, PARAMETER :: IDD_ELTERR = 120 + INTEGER, PARAMETER :: ID_DRAG = 40052 + INTEGER, PARAMETER :: ID_DELM = 40103 + INTEGER, PARAMETER :: ID_FILL = 40102 + INTEGER, PARAMETER :: IDF_Delete = 1073 + INTEGER, PARAMETER :: IDFROTATE = 1074 + INTEGER, PARAMETER :: IDF_RADIO11 = 1057 + INTEGER, PARAMETER :: ID_GETELM = 40053 + INTEGER, PARAMETER :: ID_mapm = 40054 + INTEGER, PARAMETER :: ID_map = 40055 + INTEGER, PARAMETER :: IDD_GETINTP = 160 + INTEGER, PARAMETER :: ID_SBIN = 40057 + INTEGER, PARAMETER :: IDD_headertp = 121 + INTEGER, PARAMETER :: ID_TRIAN = 40058 + INTEGER, PARAMETER :: ID_SWMAP = 40059 + INTEGER, PARAMETER :: ID_SWRM1 = 40062 + INTEGER, PARAMETER :: IDD_TRIAN = 122 + INTEGER, PARAMETER :: IDD_NODERR = 123 + INTEGER, PARAMETER :: IDF_STRING25 = 1106 + INTEGER, PARAMETER :: IDF_STRING26 = 1107 + INTEGER, PARAMETER :: IDF_STRING27 = 1108 + INTEGER, PARAMETER :: IDF_STRING28 = 1109 + INTEGER, PARAMETER :: IDF_STRING29 = 1110 + INTEGER, PARAMETER :: IDF_STRING30 = 1111 + INTEGER, PARAMETER :: IDF_STRING31 = 1112 + INTEGER, PARAMETER :: IDF_STRING32 = 1113 + INTEGER, PARAMETER :: IDF_STRING33 = 1114 + INTEGER, PARAMETER :: IDF_STRING34 = 1115 + INTEGER, PARAMETER :: IDD_SELTFL2 = 148 + INTEGER, PARAMETER :: ID_LOADRM1 = 40063 + INTEGER, PARAMETER :: ID_cdata = 40066 + INTEGER, PARAMETER :: ID_SELRM1 = 40068 + INTEGER, PARAMETER :: ID_addmesh = 40069 + INTEGER, PARAMETER :: ID_MRGMESH = 40070 + INTEGER, PARAMETER :: ID_ITEM22 = 40072 + INTEGER, PARAMETER :: ID_ALLNODES = 40073 + INTEGER, PARAMETER :: ID_UNUSNODES = 40074 + INTEGER, PARAMETER :: ID_TRIANG = 40075 + INTEGER, PARAMETER :: IDD_TRIANG = 124 + INTEGER, PARAMETER :: IDD_QUAD = 125 + INTEGER, PARAMETER :: ID_QUAD = 40076 + INTEGER, PARAMETER :: ID_JOIN = 40104 + INTEGER, PARAMETER :: ID_CSEC = 40077 + INTEGER, PARAMETER :: ID_CRSCAL = 40078 + INTEGER, PARAMETER :: ID_SAVCRS = 40079 + INTEGER, PARAMETER :: ID_crsf = 40080 + INTEGER, PARAMETER :: IDD_DIALOG06 = 126 + INTEGER, PARAMETER :: IDF_RADIO13 = 1076 + INTEGER, PARAMETER :: IDF_RADIO12 = 1058 + INTEGER, PARAMETER :: IDD_GETFPN = 154 + INTEGER, PARAMETER :: IDD_GETINT = 153 + INTEGER, PARAMETER :: ID_CSLOC = 40081 + INTEGER, PARAMETER :: IDD_CSLOC = 127 + INTEGER, PARAMETER :: ID_UNDO = 40082 + INTEGER, PARAMETER :: ID_UNDOS = 40083 + INTEGER, PARAMETER :: ID_CREATM = 40084 + INTEGER, PARAMETER :: IDD_CREATM = 128 + INTEGER, PARAMETER :: IDD_TEMPLATE001 = 129 + INTEGER, PARAMETER :: IDF_GRID1 = 1075 + INTEGER, PARAMETER :: ISS1 = 1077 + INTEGER, PARAMETER :: ISS2 = 1078 + INTEGER, PARAMETER :: ISS3 = 1079 + INTEGER, PARAMETER :: IDD_CREATM1 = 130 + INTEGER, PARAMETER :: ID_CGEN = 40085 + INTEGER, PARAMETER :: IDF_STRING35 = 1042 + INTEGER, PARAMETER :: IDD_ORDEROUT = 131 + INTEGER, PARAMETER :: IDD_TEMPLATE002 = 132 + INTEGER, PARAMETER :: IDF_RADIO14 = 1080 + INTEGER, PARAMETER :: IDF_RADIO15 = 1081 + INTEGER, PARAMETER :: IDF_RADIO16 = 1082 + INTEGER, PARAMETER :: ID_selarea = 40086 + INTEGER, PARAMETER :: ID_crsect = 40087 + INTEGER, PARAMETER :: IDD_selcrsec = 133 + INTEGER, PARAMETER :: IDD_TEMPLATE003 = 134 + INTEGER, PARAMETER :: ISS4 = 1083 + INTEGER, PARAMETER :: ISS5 = 1084 + INTEGER, PARAMETER :: IDD_LIMITS = 135 + INTEGER, PARAMETER :: IDF_RADIO17 = 1059 + INTEGER, PARAMETER :: IDD_lAY = 136 + INTEGER, PARAMETER :: IDD_TEMPLATE004 = 137 + INTEGER, PARAMETER :: ISS6 = 1085 + INTEGER, PARAMETER :: ISS7 = 1086 + INTEGER, PARAMETER :: ID_EDLAY = 40088 + INTEGER, PARAMETER :: IDF_RADIO18 = 1062 + INTEGER, PARAMETER :: ID_ORDR = 40089 + INTEGER, PARAMETER :: ID_ORDR1 = 40090 + INTEGER, PARAMETER :: id_chk = 2002 + INTEGER, PARAMETER :: id_chck = 2001 + INTEGER, PARAMETER :: idchk = 2003 + INTEGER, PARAMETER :: ID_SPLITN = 40091 + INTEGER, PARAMETER :: IDD_DISPLIT = 138 + INTEGER, PARAMETER :: IDD_DIRSPLIT = 139 + INTEGER, PARAMETER :: ID_OUTLAY = 40093 + INTEGER, PARAMETER :: ID_FORM999 = 40092 + INTEGER, PARAMETER :: ID_g1d = 40094 + INTEGER, PARAMETER :: IDD_SETOPT = 140 + INTEGER, PARAMETER :: ID_CCLN = 40095 + INTEGER, PARAMETER :: ID_CHKCCLN = 40096 + INTEGER, PARAMETER :: ID_GOUTLIN = 40097 + INTEGER, PARAMETER :: ID_XOUTLIN = 40098 + INTEGER, PARAMETER :: IDD_SETMAXMAP = 141 + INTEGER, PARAMETER :: ID_RESETLIM = 40099 + INTEGER, PARAMETER :: IDD_MLIMITS = 143 + INTEGER, PARAMETER :: IDD_VIEWANG = 174 + INTEGER, PARAMETER :: ID_3DVIEW = 40100 + INTEGER, PARAMETER :: ID_VIEWANGLE = 40101 + INTEGER, PARAMETER :: ID_ROTATE = 40106 + INTEGER, PARAMETER :: ID_RESETRG = 40105 + INTEGER, PARAMETER :: IDD_CHKOPT = 142 + INTEGER, PARAMETER :: ID_ITEM103 = 40107 + INTEGER, PARAMETER :: ID_SECGRP = 40108 + INTEGER, PARAMETER :: IDD_SETSEL = 144 + INTEGER, PARAMETER :: ID_SELPR = 40109 + INTEGER, PARAMETER :: IDD_CHK1DOPT = 145 + INTEGER, PARAMETER :: ID_VROTATE = 40110 + INTEGER, PARAMETER :: id_mchck = 40111 + INTEGER, PARAMETER :: ID_MOVMESH = 40112 + INTEGER, PARAMETER :: IDD_DIALOG047 = 146 + INTEGER, PARAMETER :: IDD_DIALOG048 = 147 + INTEGER, PARAMETER :: ID_SELELTYP = 40113 + INTEGER, PARAMETER :: IDD_SELELTYP = 149 + INTEGER, PARAMETER :: ID_OPENGP = 40114 + INTEGER, PARAMETER :: ID_SAVGP = 40115 + INTEGER, PARAMETER :: IDF_RADIO19 = 1063 + INTEGER, PARAMETER :: ID_IGPN = 40116 + INTEGER, PARAMETER :: ID_IGPC = 40117 + INTEGER, PARAMETER :: ID_DISPTYP = 40118 + INTEGER, PARAMETER :: ID_TRANSFORM = 40119 + INTEGER, PARAMETER :: IDD_TRANSFORM = 151 + INTEGER, PARAMETER :: ID_deletelm = 40120 + INTEGER, PARAMETER :: IDD_ELTERR2 = 152 + INTEGER, PARAMETER :: ID_FORM2D = 40121 + INTEGER, PARAMETER :: ID_JOINALL = 40122 + INTEGER, PARAMETER :: ID_MOVGRP = 40123 + INTEGER, PARAMETER :: ID_CRGRID = 40124 + INTEGER, PARAMETER :: IDD_GENBLK = 155 + INTEGER, PARAMETER :: ID_SETUPLEV = 40125 + INTEGER, PARAMETER :: IDD_SETWRS = 156 + INTEGER, PARAMETER :: ID_findnode = 40126 + INTEGER, PARAMETER :: ID_findelem = 40127 + INTEGER, PARAMETER :: IDD_FORMLINE = 157 + INTEGER, PARAMETER :: ID_FILLAGAP = 40129 + INTEGER, PARAMETER :: IDD_MATTYP = 158 + INTEGER, PARAMETER :: ID_ITEM126 = 40130 + INTEGER, PARAMETER :: ID_SETTYPLEV = 40131 + INTEGER, PARAMETER :: IDD_LEVSETTYP = 159 + INTEGER, PARAMETER :: ID_Complex = 40132 + INTEGER, PARAMETER :: ID_attach = 40133 + INTEGER, PARAMETER :: IDD_CHSTYP = 161 + INTEGER, PARAMETER :: ID_SAVSHP = 40128 + INTEGER, PARAMETER :: ID_ADDMAP = 40134 + INTEGER, PARAMETER :: ID_OUTLINFL = 40135 + INTEGER, PARAMETER :: ID_GETSTRESSFIL = 40136 + INTEGER, PARAMETER :: IDD_FBED = 162 + INTEGER, PARAMETER :: IDD_SETYRDT = 163 + INTEGER, PARAMETER :: ID_SMOOTHMAP = 40137 + INTEGER, PARAMETER :: IDD_GETINTR = 164 + INTEGER, PARAMETER :: ID_RVSDIAG = 40138 + INTEGER, PARAMETER :: ID_TESTOUT = 40139 + INTEGER, PARAMETER :: ID_LOADELTLD = 40140 + INTEGER, PARAMETER :: ID_SHOWELTLD = 40141 + INTEGER, PARAMETER :: IDD_CHOOSEMODEL = 165 + INTEGER, PARAMETER :: IDD_SETUPELDISP = 166 + INTEGER, PARAMETER :: ID_SAVELTLD = 40142 + INTEGER, PARAMETER :: ID_RESHOWELTLD = 40143 + INTEGER, PARAMETER :: ID_ASSIGNELTLD = 40144 + INTEGER, PARAMETER :: ID_FILLTR = 40145 + INTEGER, PARAMETER :: IDD_FTRIAN = 167 + INTEGER, PARAMETER :: ID_addmeshtr = 40146 + INTEGER, PARAMETER :: ID_UNDOGEN = 40147 + INTEGER, PARAMETER :: IDD_GETFL = 168 + INTEGER, PARAMETER :: ID_DDRAW = 40148 diff --git a/src/src83e/DELAN2.F90 b/src/src83e/DELAN2.F90 new file mode 100644 index 0000000..64d9341 --- /dev/null +++ b/src/src83e/DELAN2.F90 @@ -0,0 +1,451 @@ + SUBROUTINE SUPERT(XPT,YPT,NVERT) + + USE BLKMAP +! INCLUDE 'BLK1.COM' + REAL*8 XPT(*),YPT(*) + + REAL*8 XMINM,YMINM,X45 + DATA VDX9/-9.E9/ +! Find minimum x and y + xminm=1.e20 + yminm=1.e20 + x45=-1.e20 + DO J=1,NVERT + IF(XPT(J) .GT. VDX9) THEN + if(xminm .GT. XPT(j) ) then + xminm=XPT(j) + end if + IF(yminm .GT. YPT(j)) then + yminm=YPT(j) + endif + ENDIF + ENDDO +! Find max at 45 degrees + DO J=1,NVERT + IF(XPT(J) .GT. VDX9) THEN + X45T=((XPT(J)-XMINM)+(YPT(J)-YMINM))/1.414 + IF(x45 .LT. X45T) THEN + X45=X45T + ENDIF + ENDIF + END DO + XPT(NVERT+1)=XMINM-5 + YPT(NVERT+1)=YMINM-5. + XPT(NVERT+2)=XMINM+1.414*X45+10. + YPT(NVERT+2)=YMINM-5. + XPT(NVERT+3)=XMINM-5. + YPT(NVERT+3)=YMINM+1.414*X45+10. + NELT=1 + NOPEL(1,1)=NVERT+1 + NOPEL(1,2)=NVERT+2 + NOPEL(1,3)=NVERT+3 + NVERT=NVERT+3 + CALL CCENTRE(XPT(NOPEL(1,1)),XPT(NOPEL(1,2)),XPT(NOPEL(1,3)) & + &,YPT(NOPEL(1,1)),YPT(NOPEL(1,2)),YPT(NOPEL(1,3)) & + &,XCEN(1),YCEN(1),RADS(1)) + RETURN + END SUBROUTINE + + SUBROUTINE INSIDCIRC(XPT,YPT,J,N,ISWT) + +! Test for point inside circumcircle + + USE BLKMAP +! INCLUDE 'BLK1.COM' + + REAL*8 XPT(*),YPT(*) + REAL*8 DISQ + +! Get the distance for this element + + DISQ=(XCEN(J)-XPT(N))**2+(YCEN(J)-YPT(N))**2 + +! Test against the radius + + IF(DISQ .GT. RADS(J)*RADS(J)) THEN + ISWT=0 + ELSE + ISWT=1 + ENDIF + RETURN + END SUBROUTINE + + SUBROUTINE PROCESS(J,NEDGE,NGAP) + +! Drop triangle and form edge buffers + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + NEDGE=NEDGE+3 + IEDGE(NEDGE-2,1)=NOPEL(J,1) + IEDGE(NEDGE-1,1)=NOPEL(J,2) + IEDGE(NEDGE,1) =NOPEL(J,3) + IEDGE(NEDGE-2,2)=NOPEL(J,2) + IEDGE(NEDGE-1,2)=NOPEL(J,3) + IEDGE(NEDGE,2) =NOPEL(J,1) + NOPEL(J,1)=0 + NOPEL(J,2)=0 + NOPEL(J,3)=0 + NGAP=NGAP+1 + IGAP(NGAP)=J + RETURN + END SUBROUTINE + + SUBROUTINE FORMT(XPT,YPT,J,N,NGAP,K,WD) + +! Form the triangle + + USE BLKMAP + + REAL*8 XPT(*),YPT(*) + REAL WD(*) +! INCLUDE 'BLK1.COM' + + IF(NGAP .GT. 0) THEN + K=IGAP(NGAP) + NGAP=NGAP-1 + ELSE + NELTS=NELTS+1 + K=NELTS + ENDIF + NOPEL(K,1)=IEDGE(J,1) + NOPEL(K,2)=IEDGE(J,2) + NOPEL(K,3)=N + + CALL TESTANG(XPT,YPT,K,WD) + +! Now get circumcircle data + + CALL CCENTRE(XPT(NOPEL(K,1)),XPT(NOPEL(K,2)),XPT(NOPEL(K,3)) & + &,YPT(NOPEL(K,1)),YPT(NOPEL(K,2)),YPT(NOPEL(K,3)) & + &,XCEN(K),YCEN(K),RADS(K)) + RETURN + END SUBROUTINE + + SUBROUTINE CCENTRE(X1,X2,X3,Y1,Y2,Y3,XC,YC,RC) + +! get circumcentre and radius + + REAL*8 X1,Y1,X2,Y2,X3,Y3,A,B,C,D,AF,R1,R2,RC,XC,YC + A=X2-X1 + B=Y2-Y1 + C=X3-X1 + D=Y3-Y1 + AF=2.*(B*C-A*D) + R1=(-D*(A**2+B**2) + B*(C**2+D**2))/AF + R2=( C*(A**2+B**2) - A*(C**2+D**2))/AF + RC=SQRT(R1**2+R2**2) + XC=X1+R1 + YC=Y1+R2 + RETURN + END SUBROUTINE + + SUBROUTINE RIDPOINT(NVERT) + + USE BLKMAP + + NCOUNT=0 + DO N=1,NELTS + DO K=1,3 + IF(NOPEL(N,K) .GT. NVERT-3) THEN + DO L=1,3 + NOPEL(N,L)=0 + ENDDO + GO TO 500 + ENDIF + ENDDO + NCOUNT=NCOUNT+1 + DO K=1,3 + NOPEL(NCOUNT,K)=NOPEL(N,K) + ENDDO + XCEN(NCOUNT)=XCEN(N) + YCEN(NCOUNT)=YCEN(N) + RADS(NCOUNT)=RADS(N) + 500 CONTINUE + ENDDO + NELTS=NCOUNT + RETURN + END + + SUBROUTINE SORTDB(A,NKEY,N) +!*********************************** .....SORT..... +!- +!......SORT IS A SIMPLE SHELL SORT ROUTINE IN DOUBLE PRECISION +!- +! SHELL SORT + SAVE +! +!IPK JAN94 INTEGER*2 NKEY + REAL*8 A(*) + INTEGER NKEY(*) + + IF(N.LT.2) RETURN + DO 90 J=1,N + NKEY(J)=J + 90 END DO + ID = N + 100 ID = ID / 2 + 110 IB = 1 + 120 GO TO 200 + 130 IB = IB + 1 + IF( IB .LE. ID ) GO TO 200 + IF( ID .GT. 1 ) GO TO 100 + RETURN + 200 I = IB + 210 K = I + ID + 220 IF( A(NKEY(I)) .LE. A(NKEY(K)) ) GO TO 250 + NKT = NKEY(K) + NKEY(K) = NKEY(I) + J = I + 230 K = J - ID + IF( K .LT. 1 ) GO TO 240 + IF( A(NKT) .GT. A(NKEY(K)) ) GO TO 240 + NKEY(J) = NKEY(K) + J = K + GO TO 230 + 240 NKEY(J) = NKT + 250 I = I + ID + IF( I + ID .LE. N ) GO TO 210 + GO TO 130 + END + + SUBROUTINE SETEDG(NEDGE) + + USE BLKMAP + +! Setup to form new triangles + + DO J=1,NEDGE + IF(J .LT. NEDGE) THEN + DO K=J+1,NEDGE + IF(IEDGE(K,1) .EQ. IEDGE(J,1)) THEN + IF(IEDGE(K,2) .EQ. IEDGE(J,2)) THEN + IEDGE(J,1)=0 + IEDGE(J,2)=0 + IEDGE(K,1)=0 + IEDGE(K,2)=0 + ENDIF + ELSEIF(IEDGE(K,1) .EQ. IEDGE(J,2)) THEN + IF(IEDGE(K,2) .EQ. IEDGE(J,1)) THEN + IEDGE(J,1)=0 + IEDGE(J,2)=0 + IEDGE(K,1)=0 + IEDGE(K,2)=0 + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO + + RETURN + END + + SUBROUTINE TESTANG(XPT,YPT,K,WD) + + USE BLKMAP + REAL*8 XPT(*),YPT(*) + REAL WD(*) + DATA PI/3.14159/ + + ! IF(WD(NOPEL(K,1)) .EQ. WD(NOPEL(K,2)) .and. wd(nopel(k,1)) .gt. -9990. ) THEN + ! RETURN + ! ENDIF + ! + IFD=0 + DO N=1,NELTS + IF(N .NE. K) THEN + DO J=1,3 + IF(NOPEL(K,1) .EQ. NOPEL(N,J)) THEN + IF(J .GT. 1) THEN + IF(NOPEL(K,2) .EQ. NOPEL(N,J-1)) THEN + IFD=N + ISIDE=J + GO TO 400 + ENDIF + ELSE + IF(NOPEL(K,2) .EQ. NOPEL(N,3)) THEN + IFD=N + ISIDE=J + GO TO 400 + ENDIF + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO + RETURN + 400 CONTINUE + + J1=ISIDE+1 + IF(J1 .GT. 3) J1=1 + ! + ! IF(WD(NOPEL(K,3)) .EQ. WD(NOPEL(IFD,J1)) .and. wd(nopel(k,1)) .gt. -9990. ) THEN + ! WRITE(148,'(12I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + ! IF(NELTS .GT. 20) WRITE(148,'(12I8)') NOPEL(21,1),NOPEL(21,2),NOPEL(21,3) + ! NOPEL(IFD,1)=NOPEL(K,3) + ! NOPEL(IFD,2)=NOPEL(K,1) + ! NOPEL(IFD,3)=NOPEL(IFD,J1) + ! NOPEL(K,1)=NOPEL(IFD,3) + ! + ! WRITE(148,'(12I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + ! IF(NELTS .GT. 20) WRITE(148,'(12I8)') NOPEL(21,1),NOPEL(21,2),NOPEL(21,3) + ! + ! CALL CCENTRE(XPT(NOPEL(IFD,1)),XPT(NOPEL(IFD,2)),XPT(NOPEL(IFD,3)) & + !& ,YPT(NOPEL(IFD,1)),YPT(NOPEL(IFD,2)),YPT(NOPEL(IFD,3)) & + !& ,XCEN(IFD),YCEN(IFD),RADS(K)) + ! CALL CCENTRE(XPT(NOPEL(K,1)),XPT(NOPEL(K,2)),XPT(NOPEL(K,3)) & + !& ,YPT(NOPEL(K,1)),YPT(NOPEL(K,2)),YPT(NOPEL(K,3)) & + !& ,XCEN(K),YCEN(K),RADS(K)) + ! + ! RETURN + ! ENDIF + A1=ATAN2(YPT(NOPEL(K,1))-YPT(NOPEL(K,3)),XPT(NOPEL(K,1))-XPT(NOPEL(K,3))) + A2=ATAN2(YPT(NOPEL(K,2))-YPT(NOPEL(K,3)),XPT(NOPEL(K,2))-XPT(NOPEL(K,3))) + IF(A1 .LT. 0) A1=A1+2.*PI + IF(A2 .LT. 0) A2=A2+2.*PI + DIFFA=A2-A1 +! WRITE(148,*) 'DIFFA',K,DIFFA,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3) + IF(DIFFA .LT. 0) DIFFA=DIFFA+PI*2. + IF(DIFFA .LT. 2./3.*PI) RETURN + +! WRITE(148,'(9I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + + B1=ATAN2(YPT(NOPEL(IFD,J1))-YPT(NOPEL(K,2)),XPT(NOPEL(IFD,J1))-XPT(NOPEL(K,2))) + B2=ATAN2(YPT(NOPEL(K, 3))-YPT(NOPEL(K,2)),XPT(NOPEL(K, 3))-XPT(NOPEL(K,2))) + IF(B1 .LT. 0) B1=B1+2.*PI + IF(B2 .LT. 0) B2=B2+2.*PI + + DIFFB=B2-B1 + +! WRITE(148,*) 'DIFFB',DIFFB,B2,B1 + IF(DIFFB .LT. 0) DIFFB=DIFFB+2.*PI + IF(DIFFB .GT. DIFFA) RETURN + + C1=ATAN2(YPT(NOPEL(K, 3))-YPT(NOPEL(K,1)),XPT(NOPEL(K, 3))-XPT(NOPEL(K,1))) + C2=ATAN2(YPT(NOPEL(IFD,J1))-YPT(NOPEL(K,1)),XPT(NOPEL(IFD,J1))-XPT(NOPEL(K,1))) + IF(C1 .LT. 0) C1=C1+2.*PI + IF(C2 .LT. 0) C2=C2+2.*PI + + DIFFC=C2-C1 +! WRITE(148,*) 'DIFFC',DIFFC,C2,C1 + IF(DIFFC .LT. 0) DIFFC=DIFFC+2.*PI + IF(DIFFC .GT. DIFFA) RETURN + + NOPEL(IFD,1)=NOPEL(K,3) + NOPEL(IFD,2)=NOPEL(K,1) + NOPEL(IFD,3)=NOPEL(IFD,J1) + NOPEL(K,1)=NOPEL(IFD,3) + +! WRITE(148,'(9I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + + CALL CCENTRE(XPT(NOPEL(IFD,1)),XPT(NOPEL(IFD,2)),XPT(NOPEL(IFD,3)) & + &,YPT(NOPEL(IFD,1)),YPT(NOPEL(IFD,2)),YPT(NOPEL(IFD,3)) & + &,XCEN(IFD),YCEN(IFD),RADS(IFD)) + + RETURN + END + + + SUBROUTINE TESTTR(XPT,YPT,K,WD) + + USE BLKMAP + REAL WD(*) + REAL*8 XPT(*),YPT(*) + DATA PI/3.14159/ + + IF(WD(NOPEL(K,1)) .EQ. WD(NOPEL(K,2)) .and. wd(nopel(k,1)) .gt. -9990. ) THEN + RETURN + ENDIF + + + IFD=0 + DO N=1,NELTS + IF(N .NE. K) THEN + DO J=1,3 + IF(NOPEL(K,2) .EQ. NOPEL(N,J)) THEN + IF(J .GT. 1) THEN + IF(NOPEL(K,3) .EQ. NOPEL(N,J-1)) THEN + IFD=N + ISIDE=J + GO TO 400 + ENDIF + ELSE + IF(NOPEL(K,3) .EQ. NOPEL(N,3)) THEN + IFD=N + ISIDE=J + GO TO 400 + ENDIF + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO + RETURN + 400 CONTINUE + + WRITE(148,'(9I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + write(148,'(9x,6f8.0)')wd(NOPEL(K,1)),wd(NOPEL(K,2)),wd(NOPEL(K,3)),wd(NOPEL(IFD,1)),wd(NOPEL(IFD,2)),wd(NOPEL(IFD,3)) + J1=ISIDE+1 + IF(J1 .GT. 3) J1=1 + WRITE(148,*) J1 + + IF(WD(NOPEL(K,1)) .EQ. WD(NOPEL(IFD,J1)) .and. wd(nopel(k,1)) .gt. -9990. ) THEN + ITEMP=NOPEL(IFD,J1) + NOPEL(IFD,1)=NOPEL(K,3) + NOPEL(IFD,2)=NOPEL(K,1) + NOPEL(IFD,3)=ITEMP + NOPEL(K,1)=NOPEL(IFD,3) + + WRITE(148,'(9I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + + CALL CCENTRE(XPT(NOPEL(IFD,1)),XPT(NOPEL(IFD,2)),XPT(NOPEL(IFD,3)) & + & ,YPT(NOPEL(IFD,1)),YPT(NOPEL(IFD,2)),YPT(NOPEL(IFD,3)) & + & ,XCEN(IFD),YCEN(IFD),RADS(IFD)) + + RETURN + ENDIF + A1=ATAN2(YPT(NOPEL(K,2))-YPT(NOPEL(K,1)),XPT(NOPEL(K,2))-XPT(NOPEL(K,1))) + A2=ATAN2(YPT(NOPEL(K,3))-YPT(NOPEL(K,1)),XPT(NOPEL(K,3))-XPT(NOPEL(K,1))) + IF(A1 .LT. 0) A1=A1+2.*PI + IF(A2 .LT. 0) A2=A2+2.*PI + DIFFA=A2-A1 +! WRITE(148,*) 'DIFFA',K,DIFFA,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3) + IF(DIFFA .LT. 0) DIFFA=DIFFA+PI*2. + IF(DIFFA .LT. 2./3.*PI) RETURN + + B1=ATAN2(YPT(NOPEL(IFD,J1))-YPT(NOPEL(K,3)),XPT(NOPEL(IFD,J1))-XPT(NOPEL(K,3))) + B2=ATAN2(YPT(NOPEL(K, 1))-YPT(NOPEL(K,3)),XPT(NOPEL(K, 1))-XPT(NOPEL(K,3))) + IF(B1 .LT. 0) B1=B1+2.*PI + IF(B2 .LT. 0) B2=B2+2.*PI + + DIFFB=B2-B1 + +! WRITE(148,*) 'DIFFB',DIFFB,B2,B1 + IF(DIFFB .LT. 0) DIFFB=DIFFB+2.*PI + IF(DIFFB .GT. DIFFA) RETURN + + C1=ATAN2(YPT(NOPEL(K, 1))-YPT(NOPEL(K,2)),XPT(NOPEL(K, 1))-XPT(NOPEL(K,2))) + C2=ATAN2(YPT(NOPEL(IFD,J1))-YPT(NOPEL(K,2)),XPT(NOPEL(IFD,J1))-XPT(NOPEL(K,2))) + IF(C1 .LT. 0) C1=C1+2.*PI + IF(C2 .LT. 0) C2=C2+2.*PI + + DIFFC=C2-C1 +! WRITE(148,*) 'DIFFC',DIFFC,C2,C1 + IF(DIFFC .LT. 0) DIFFC=DIFFC+2.*PI + IF(DIFFC .GT. DIFFA) RETURN + ITEMP=NOPEL(IFD,J1) + NOPEL(IFD,1)=NOPEL(K,1) + NOPEL(IFD,2)=NOPEL(K,2) + NOPEL(IFD,3)=ITEMP + NOPEL(K,2)=NOPEL(IFD,3) + +! WRITE(148,'(9I8)') K,J,IFD,NOPEL(K,1),NOPEL(K,2),NOPEL(K,3),NOPEL(IFD,1),NOPEL(IFD,2),NOPEL(IFD,3) + + CALL CCENTRE(XPT(NOPEL(IFD,1)),XPT(NOPEL(IFD,2)),XPT(NOPEL(IFD,3)) & + &,YPT(NOPEL(IFD,1)),YPT(NOPEL(IFD,2)),YPT(NOPEL(IFD,3)) & + &,XCEN(IFD),YCEN(IFD),RADS(IFD)) + + RETURN + END diff --git a/src/src83e/DELAUNAY.F90 b/src/src83e/DELAUNAY.F90 new file mode 100644 index 0000000..a443ab9 --- /dev/null +++ b/src/src83e/DELAUNAY.F90 @@ -0,0 +1,264 @@ + SUBROUTINE TRIANG + + USE WINTERACTER + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + DATA VOID10/-1.E10/,SPAC/0.0/ + + NELTS=0 + NVERT=MAXPTS + NINTV=1 + CALL TRIANOPT(NINTV,SPAC) + + +! FIRST WRITE EXISTING MAP TO SCRATCH + OPEN(99,FORM='BINARY',STATUS='SCRATCH') + + CALL WRTMAP(99) + REWIND 99 + + DO N=1,NVERT + IF(MOD(N-1,NINTV) .EQ. 0) THEN + IMAP(N)=1 + ELSE + IMAP(N)=0 + ENDIF + ENDDO + + IF(SPAC .GT. 0.) THEN + DO N=1,NVERT + IF(IMAP(N) .EQ. 1) THEN + IF(N .LT. NVERT) THEN + DO M=N+1,NVERT + DISQ=(XMAP(M)-XMAP(N))**2+(YMAP(M)-YMAP(N))**2 + IF(DISQ .LT. SPAC**2) THEN + IMAP(M)=0 + ENDIF + ENDDO + ENDIF + ENDIF + ENDDO + ENDIF + NN=0 + DO N=1,NVERT + IF(IMAP(N) .GT. 0) THEN + NN=NN+1 + XMAP(NN)=XMAP(N) + YMAP(NN)=YMAP(N) + IMAP(NN)=IMAP(N) + ENDIF + ENDDO + NVERT=NN +! WRITE(185,*) 'NEW NVERT',NVERT + + + call WcursorShape(CurHourGlass) + CALL DELAUNAY(NVERT) + call WcursorShape(CurArrow) + + + RETURN + END + + + +! Last change: IPK 2 Feb 2003 6:25 pm + SUBROUTINE DELAUNAY(NVERT) + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*80 LIND + CHARACTER*1 ANS + DATA VDX9/-9.E9/,NEDGE/0/ + +! Get location of supertriangle + + iprt=0 + ngap=0 + YLV=7.5 + + + + call supert(XMAP,YMAP,NVERT) + + NELTS=1 + + NVERTM=NVERT-3 + IF(NVERT .GT. MAXP) THEN + DEALLOCATE (NKEY) + ALLOCATE (NKEY(NVERT)) + NKEY=0 + ENDIF + +! Sort points into ascending x order + + CALL SORTDB(XMAP,NKEY,NVERTM) + +! Loop on the vertices + + DO NN=1,NVERT-3 + +! IF(MOD(NN,5) .EQ. 0) WRITE(185,*) 'LOOP',NN + if(mod(NN,2500) .eq. 0) then + WRITE(90,*) NN,' points processed' + ylv=ylv-0.3 + if(ylv .lt. 0.1) then + ylv=7.9 + call clscrn + endif + write(lind,6010) NN + 6010 format(i8,' points processed') + call symbl & + & (1.1,ylv,0.20,LIND,0.0,80) + endif + +! process next point + + N=NKEY(NN) + +! Skip out if inactive point + IF(N .EQ. 0) GO TO 500 + IF(IMAP(N) .EQ. 0) GO TO 500 + IF(XMAP(N) .LT. VDX9) GO TO 500 + IF(VAL(N) .LT. -9000.) GO TO 500 +! IF(NN .GT. 1700. .AND. MOD(NN,5) .EQ. 0) WRITE(185,*) 'N',N,IMAP(N),XMAP(N),VAL(N) + +! WRITE(45,*) NN,N,NVERT,XMAP(N),YMAP(N) + IF(NN .LT. NVERTM) THEN + DO KK=NN+1,NVERTM + K=NKEY(KK) +! IF(NN .GT. 1700) WRITE(185,*) 'NKEY',K,KK + + IF(K .NE. 0) THEN + IF(XMAP(N) .EQ. XMAP(K)) THEN + IF(YMAP(N) .EQ. YMAP(K)) THEN + WRITE(45,*) 'IDENT',N,K + NKEY(KK)=0 + ENDIF + ELSE + GO TO 200 + ENDIF + ENDIF + 200 CONTINUE + ENDDO + ENDIF + +! Set edge buffers to zero +! IF(NN .GT. 1700 .AND. MOD(NN,5) .EQ. 0) WRITE(185,*) 'AFTER 200 NEDGE',NEDGE + + IF(NEDGE .GT. 0) THEN + DO J=1,NEDGE + IEDGE(J,1)=0 + IEDGE(J,2)=0 + END DO + ELSE + DO J=1,100 + IEDGE(J,1)=0 + IEDGE(J,2)=0 + END DO + ENDIF + NEDGE=0 + +! test for point in circumcircle + + DO J=1,NELTS + CALL INSIDCIRC(XMAP,YMAP,J,N,ISWT) + +! If inside process edges + + IF(ISWT .EQ. 1) THEN + CALL PROCESS(J,NEDGE,NGAP) + ENDIF + END DO + +! Setup to form new triangles + + CALL SETEDG(NEDGE) + +! Now form triangles as needed + + DO J=1,NEDGE + IF(IEDGE(J,1) .NE. 0) THEN + CALL FORMT(XMAP,YMAP,J,N,NGAP,KK,WD) + ENDIF + END DO + + NEDGE=0 + if(iprt .eq. 0) go to 500 + DO J=1,NELTS + IF(NOPEL(J,1) .GT. 0) THEN + WRITE(3,'(2i5,2i10,19x,''1'')') J,(NOPEL(J,K),K=1,3) + ENDIF + END DO + + + IF(NN .EQ. 1) THEN + write(41,'('' 9999'')') + do j=1,nvert + write(41,'(i10,2f20.4,F10.3)') j,XMAP(j),YMAP(j),VAL(J) + enddo + write(41,'('' 9999'')') + write(41,'('' 9999'')') + write(41,'('' 0 NENTRY'')') + write(41,'('' 0 NCLM'')') + WRITE(41,'(''ENDDATA'')') + ENDIF + 500 continue + END DO + +! Get rid of elements from super point + + CALL RIDPOINT(NVERT) + + RETURN + END SUBROUTINE + + SUBROUTINE TRIANOPT(NINTV,SPAC) + + USE WINTERACTER + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: NINTV + INTEGER :: IERR + REAL :: SPAC + CHARACTER*1 :: IFLAG + + call wdialogload(IDD_TRIAN) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_TRIAN) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,NINTV) + CALL WDialogPutReal(IDF_REAL1,SPAC) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + CALL WDialogGetINTEGER(IDF_INTEGER1,NINTV) + IF(NINTV .EQ. 0) NINTV=1 + CALL WDialogGetREAL(IDF_REAL1,SPAC) + ELSE + SPAC=0.0 + NINTV=1 + ENDIF + RETURN + enddo + RETURN + END + \ No newline at end of file diff --git a/src/src83e/DEMOS.F90 b/src/src83e/DEMOS.F90 new file mode 100644 index 0000000..9e4f93e --- /dev/null +++ b/src/src83e/DEMOS.F90 @@ -0,0 +1,45 @@ + SUBROUTINE DEMOS + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + COMMON /RECOD/ IRECD,TSPC + COMMON /PAGE/ XL,XH,YL,YH + common /cols/ ibakk,icolr,iblkk + + CHARACTER*255 FNAME + CHARACTER*40 LIND,dlin + + xl=0. + yl=0. + xh=HSIZE + yh=8.0 + ibakk=8 + icolr=11 + iblkk=14 + OPEN(75,FILE='DINFO.OUT',FORM='FORMATTED',STATUS='UNKNOWN') + + WRITE(75,*) 'IN DEMOS' + FNAME='RECORD.REC' + OPEN(9,FILE='PALMIS.MAP',STATUS='OLD', FORM='FORMATTED') + IMP=9 + IIN=0 + + OPEN(91,FILE=FNAME,STATUS='OLD') + CALL RBLUE + nmess=45 + call getfpn(tspc) +! WRITE(LIND,6005) +! 6005 FORMAT('Enter time interval between events') +! call symbl(1.1,3.5,0.25,LIND,0.0,80) +! ndig=32 +! CALL GTFPNX(TSPC,NDEC,NDIG,5.0,6.0) +! write(75,'(a)') 'demos-lind',lind +! call get_label(lind,dlin) +! write(75,'(a)') 'label',dlin +! read(dlin,'(f20.2)') tspc + IRECD=2 + WRITE(75,*) 'tspc', tspc + + RETURN + END diff --git a/src/src83e/DOGRAPH.F90 b/src/src83e/DOGRAPH.F90 new file mode 100644 index 0000000..3b4e231 --- /dev/null +++ b/src/src83e/DOGRAPH.F90 @@ -0,0 +1,306 @@ + SUBROUTINE dograph(noptt,icurrwin) +!!!!!! (XVALUES,YVALUES,NVALUES,XMIN,XMAX,VALMIN,YMAX) +! +! Graph plotting code generated by GraphEd at 21:20 on 11 Apr 1999. +! +! XVALUES = Array of X values to plot +! YVALUES = Array of Y values to plot +! NVALUES = Number of values +! TIMMIN = Min X +! TIMMAX = Max X +! VALMIN = Min Y +! VALMAX = Max Y +! +! +! USE module containing routine definitions and symbolic names. +! + USE WINTERACTER +! +! +! Common arguments. +! + CHARACTER*6 DESCR + CHARACTER*48 XLABEL, YYLABEL + CHARACTER*48 PTITL + CHARACTER*4 AXTYPE, YAXTYPE + COMMON /XYGRPH/ XVALUES(10000,10),YVALUES(10000,10),TIMMIN,VALMIN,TIMMAX,VALMAX,NVALUES,NSETS,LINPROP(10) + COMMON /PAXC/ PTITL,AXTYPE,XLABEL,YAXTYPE,YYLABEL + + COMMON /HEDS1/ NWINDWS,IWNDWS(10),ISCRNS(10),DESCR(10) + + + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + CHARACTER*80 TITLE + CHARACTER*24 HLABL + character*40 mpnam + CHARACTER*1 ALABL(10) + COMMON /BLKA1/ TITLE,HLABL,ALABL,MPNAM + + character*8 labl + character*72 data + CHARACTER*20 TITL1,TITL4 + CHARACTER*64 TITL2,TITL3 + COMMON /BLKA11/ TITL1,TITL2,TITL3,TITL4& + , labl(400),data(400) + +!IPK JAN03 + + INTEGER IHANDLE1 + +! REAL, INTENT(IN), DIMENSION(NVALUES) :: XVALUES +! REAL, INTENT(IN), DIMENSION(NVALUES) :: YVALUES +! REAL TIMMIN,TIMMAX,VALMIN,VALMAX +! INTEGER NVALUES + + + nopt=abs(noptt) + WRITE(90,*) 'IN DOGRAPH',NOPT,icurrwin + +! nopt = 999 skip to draw current page +! nopt = -2 skip to draw current page +! nopt = 2 draw time plots +! nopt = 4 from brkarea + + if(nopt .eq. 999) go to 300 + IF(NOPTT .EQ. -2) GO TO 300 + if(nopt .ne. 3) then + +! do this only for nopt = 4 or nopt = 2 first search for empty window + + do n=1,nwindws + if(iwndws(n) .eq. 0) then + icurrwin=n + go to 290 + endif + enddo + +! or increase window count + + + nwindws=nwindws+1 + if(nwindws .eq. 10) then + call WMessageBox(0,3,1,'Warning 10 windows now open','WARNING') + IF(WInfoDialog(4) .eq. 1) then + ENDIF + endif + icurrwin=nwindws + 290 continue + else + +! do this for nopt = 3 ie +! draw the bitmap in icurrwin and return + + call backp(2,icurrwin) + return + endif +!ipk jan03 + +! if no window defined yet open a child window for it and give it a handle + + IF(Iwndws(icurrwin) .EQ. 0) THEN + CALL WindowOpenChild(IHANDLE1,FLAGS=SysMenuOn+MinButton+MaxButton, & + TITLE='Cross-Section') + Iwndws(icurrwin)=ihandle1 + ENDIF + +! setup to draw bitmap in icurrwin + + CALL BACKP(1,icurrwin) + 300 continue +! +! Start new presentation graphics plot +! +! CALL IPgNewGraph(NSETS,NVALUES,' ',' ','X') + CALL IPgNewPlot(6,nsets,nvalues) +! +! Set Clipping Rectangle +! + CALL IPgClipRectangle('G') +! +! Set style for each data set +! +! CALL IPgStyle( 1, 0, 0, 0,223, 96) +! CALL IPgStyle( 2, 1, 0, 0, 31,128) +! CALL IPgStyle( 3, 2, 0, 0,159,160) +! CALL IPgStyle( 4, 3, 0, 0, 95,192) +! CALL IPgStyle( 5, 5, 0, 0,223,224) + + ICL=255+256*255+256*256*255 + IF(LINPROP(1) .EQ. 0) THEN + CALL IPgStyle( 1, 0, 0, 0,223,195) + ELSE + CALL IPgStyle( 1, 0, 3, 0,ICL,195) + ENDIF + IF(LINPROP(2) .EQ. 0) THEN + CALL IPgStyle( 2, 1, 0, 0,33405,33405) + ELSE + CALL IPgStyle( 2, 1, 3, 0,ICL,33405) + ENDIF + IF(LINPROP(3) .EQ. 0) THEN + CALL IPgStyle( 3, 2, 0, 0,8551680,8551680) + ELSE + CALL IPgStyle( 3, 2, 3, 0,ICL,8551680) + ENDIF + IF(LINPROP(4) .EQ. 0) THEN + CALL IPgStyle( 4, 3, 0, 0,65415,65415) + ELSE + CALL IPgStyle( 4, 3, 3, 0,ICL,65415) + ENDIF + IF(LINPROP(5) .EQ. 0) THEN + CALL IPgStyle( 5, 5, 0, 0,0,0) + ELSE + CALL IPgStyle( 5, 5, 3, 0,ICL,0) + ENDIF +! +! Set marker number for data sets not using default marker +! + CALL IPgMarker( 1, 1) + CALL IPgMarker( 2, 2) + CALL IPgMarker( 3, 2) + CALL IPgMarker( 4, 2) + CALL IPgMarker( 5, 2) +! +! Set units for plot +! + CALL IPgUnits( TIMMIN, VALMIN, TIMMAX, VALMAX) +! +! Set presentation graphics area +! + CALL IPgArea( .150, .100, .900, .800) +! +! Draw main title +! + CALL IGrCharSet('H') + CALL IGrCharFont( 1) + CALL IGrCharSpacing('F') + CALL IGrCharSize( 0.67, 0.67) + CALL IGrColourN( 208) + + CALL IPgTitle('CROSS-SECTION','C') +! +! Label bottom X axis +! + CALL IPgXLabelPos( .70) + CALL IPgXLabel('Section Dimension','C') + +! +! Label left Y axis +! + CALL IPgYLabelPos( .80) + + CALL IPgYLabelLeft('Elevation','C9') +! +! Draw axes +! + CALL IGrColourN( 208) + CALL IPgAxes(TIMMIN,VALMIN) +! +! Adjust tick position for X Axes +! + CALL IPgXTickPos(VALMIN,VALMAX) +!DEC09 CALL IPgXTickPos(1,TIMMIN) +! +! Scale for bottom X Axis +! + CALL IPgXUserScale((/0.0/),0) + CALL IPgXScaleAngle( .00, .00) + CALL IPgXScalePos( .38) + CALL IPgXScale('NT') +! +! Adjust tick position for Y Axes +! + CALL IPgYTickPos( TIMMIN , TIMMAX ) +!DEC09 CALL IPgYTickPos( 1,VALMIN) +!DEC09 ISIDE=1 +!DEC09 CALL IPgYTickPos( ISIDE,TIMMAX) +! Scale for left Y Axis +! + CALL IPgYUserScale((/0.0/),0) + CALL IPgYScaleAngle( .00, .00) + CALL IPgYScalePos( 1.50) + CALL IPgYScaleLeft('NT') +! +! Draw graph. +! + DO ISET = 1,NSETS + + CALL IPgXYPairs(XVALUES(1,iset),YVALUES(1,ISET)) + + END DO + + call IPgKeyAll(DESCR,' ') + +! CALL SYMBL(0.1,7.60,0.18,TITL2,0.0,+64) + + + if(nopt .ne. 999 .and. NOPTT .NE. -2) CALL BACKP(2,icurrwin) + + RETURN + END SUBROUTINE dograph + + + SUBROUTINE BACKP(IENT,icurrwin) + +! ient = 1 means either set to draw bitmap or create window for plotting ihandle(icurrwin) +! then select to draw bitmap +! ient = 2 means select drawing of window and putting the bitmap into it, folloed by return +! to main window +! ient = 3 means destroy slected window + + + use winteracter + + implicit none + + include 'D.INC' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: iw,ih,ihandle,ient,icurrwin,ihandlem + common /handP/ ihandle(10) +! write(128,*) 'ient',ient,icurrwin,ihandle(icurrwin) + if(ient .eq. 1) then + iw=WinfoWindow(WindowWidth) + ih=WinfoWindow(WindowHeight) + IF(IHANDLE(icurrwin) .EQ. 0) THEN + call WBitmapCreate(ihandle(icurrwin),iw,ih) + call IGrSelect(DrawBitmap,ihandle(icurrwin)) + ELSE + call IGrSelect(DrawBitmap,ihandle(icurrwin)) + ENDIF + return + elseif(ient .eq. 2) then + call IGrSelect(DrawWin) + call WBitmapPut(ihandle(icurrwin),0,1) +!!! call WBitmapDestroy(ihandle) + ihandlem=0 + call WindowSelect(ihandlem) + else + CALL WBitmapDestroy(ihandle(icurrwin)) + + endif + return + end + + SUBROUTINE DOPLOT(IMZ) + + + COMMON /HEDS1/ NWINDWS,IWNDWS(10),ISCRNS(10) + + if(nwindws .gt. 0) then + do n=1,nwindws + if(iscrns(n) .eq. 3) then + call WindowSelect(iwndws(n)) + call clscrn + call dograph(3,n) + endif + enddo + call WindowSelect(0) + endif + + RETURN + END diff --git a/src/src83e/DUMMY.F90 b/src/src83e/DUMMY.F90 new file mode 100644 index 0000000..eb13a5d --- /dev/null +++ b/src/src83e/DUMMY.F90 @@ -0,0 +1,12 @@ + + SUBROUTINE PLOTSV(I) + RETURN + END + + SUBROUTINE NDPLSV + RETURN + END + + SUBROUTINE SETD(I) + RETURN + END \ No newline at end of file diff --git a/src/src83e/EGEN.F90 b/src/src83e/EGEN.F90 new file mode 100644 index 0000000..98bb2ac --- /dev/null +++ b/src/src83e/EGEN.F90 @@ -0,0 +1,1163 @@ + +! Last change: IPK 12 Jan 98 1:44 pm +! + SUBROUTINE GNODE(ITYPC) +! +! Routine to create a series of nodes along a line +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + REAL*8 GRIDX(150),GRIDY(150),ALX,ALY,ATX,ATY,CURRENTX,CURRENTY,X11,Y11 + INTEGER IREF(2000),JREF(2000) +! + CHARACTER*1 IFLAG + data itime/0/ + if(itime .eq. 0) then + ALLOCATE(ALXX(2000),ALYY(2000),ALWD(2000),BLXX(2000),BLYY(2000),BLWD(2000)& + ,CNX(2000,4),CNY(2000,4),ITYPBC(2000),XBRLEN(2000),HLEFT(2000),HMID(2000),HRIGHT(2000)& + ,HSET(MAXP,3),IRTYP(2000),WIDTHD(2000)) + nh=1 + itime=1 + endif +4 CONTINUE + IF(ITYPC .EQ. 1) THEN + NHTP = 0 + NMESS = 6 + NBRR = 3 + CALL HEDR +! +! Get screen coordinates of each end of line +! + 7 CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ALX=XTEMP + ALY=YTEMP + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + CALL WRTOUT(0) + RETURN + ENDIF +! +! Exit input +! + 9 CONTINUE + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + CALL HEDR +! + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ATX=XTEMP + ATY=YTEMP + IF(IRMAIN .EQ. 1) RETURN +! + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) +! +! Define number of nodes in a line +! + NBRR = 0 + NMESS=45 + CALL HEDR + NMESS = 7 + call getint(nh) +! READ(*,*) NH + NINT=NH-1 +! +! zero GRIDX and GRIDY to hold generated coordinates +! + DO N=1,NH + GRIDX(N)=0. + GRIDY(N)=0. + END DO +! +! Interpolate points onto line +! + CALL INTERP(GRIDX,GRIDY,1,NH,1,ALX,ALY,ATX,ATY,NINT,0) +! +! Copy points into the coordinate array +! + DO N=1,NH +! +! Find next blank node in CORD +! + CALL GETNOD(J) +! +! Store GRIDX and GRIDY into it +! + CORD(J,1) = GRIDX(N) + CORD(J,2) = GRIDY(N) + INEW(J) = 1 + INSKP(J) = 0 +! + XUSR(J) = GRIDX(N)*TXSCAL - XS + YUSR(J) = GRIDY(N)*TXSCAL - YS +! +! Display point +! + CALL PLTNOD(J,1) +! + END DO + ELSE + KID=0 + ITYP=2 + CALL FORMLINEMENU(ITYP,I1D,I2D,IFIN,XLENGTH,ITYPIN,NELC,NBRID) + IF(I1D .EQ. -999) RETURN + IF(IFIN .EQ. 0) THEN + NHTP = 0 + NMESS = 6 + NBRR = 3 + CALL HEDR +! +! Get screen coordinates of each end of line +! + DO J=1,2000 + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + IF(IFLAG .EQ. 'q' .or. ibox .eq. 10) go to 300 + ALXX(J)=XTEMP + ALYY(J)=YTEMP + JPTS=J + ENDDO +300 CONTINUE + ELSE + CALL FILEDAT(JPTS,NBRID) + ENDIF +! SORT OUT A NEW ORDER + + IREF=1 + CURRENTX=ALXX(1) + CURRENTY=ALYY(1) + KS=2 + KSP=1 + DO J=2,JPTS + IF(JPTSB .GT. 0) THEN + IF(KSP .LE. JPTSB) THEN + DO K=KSP,JPTSB + TOTLEN=SQRT((ALXX(J)-CURRENTX)**2+(ALYY(J)-CURRENTY)**2) + TOTLENB=SQRT((BLXX(K)-CURRENTX)**2+(BLYY(K)-CURRENTY)**2) + IF(ABS(TOTLENB - TOTLEN) .LT. 1.0) THEN +! THIS IS A BREAKPOINT + IREF(KS)=-K + KS=KS+1 + KSP=KSP+1 + CURRENTX=BLXX(K) + CURRENTY=BLYY(K) + GO TO 320 + ENDIF + IF(TOTLENB .LT. TOTLEN) THEN +! THIS IS A BREAKPOINT + IREF(KS)=-K + KS=KS+1 + KSP=KSP+1 + CURRENTX=BLXX(K) + CURRENTY=BLYY(K) + GO TO 310 + ELSE + IREF(KS)=J + KS=KS+1 + CURRENTX=ALXX(J) + CURRENTY=ALYY(J) + GO TO 320 + ENDIF +310 CONTINUE + ENDDO + ELSE +315 CONTINUE + IREF(KS)=J + KS=KS+1 + CURRENTX=ALXX(J) + CURRENTY=ALYY(J) + ENDIF +320 CONTINUE + ELSE + IREF(KS)=J + IF(KS .LT. JPTS)KS=KS+1 + CURRENTX=ALXX(J) + CURRENTY=ALYY(J) + ENDIF + + ENDDO +! IREF(KS)=JPTS + IF(IFIN .GT. 0) THEN + IREF(KS)=JPTS + DO K=KS,1,-1 + IF(IREF(K) .LT. 0) THEN + ALXX(K)=BLXX(-IREF(K)) + ALYY(K)=BLYY(-IREF(K)) + ALWD(K)=BLWD(-IREF(K)) + HMID(K)=BLWD(-IREF(K)) + HLEFT(K)=HMID(K) + HRIGHT(K)=HMID(K) + ELSE + ALXX(K)=ALXX(IREF(K)) + ALYY(K)=ALYY(IREF(K)) + ALWD(K)=ALWD(IREF(K)) + HMID(K)=HMID(IREF(K)) + HLEFT(K)=HLEFT(IREF(K)) + HRIGHT(K)=HRIGHT(IREF(K)) + ENDIF + ENDDO + DO J=1,KS + ALXX(J)=(ALXX(J)+XS)/TXSCAL + ALYY(J)=(ALYY(J)+YS)/TXSCAL + ENDDO + DO J=1,KS + BLXX(J)=(BLXX(J)+XS)/TXSCAL + BLYY(J)=(BLYY(J)+YS)/TXSCAL + ENDDO +! KS=KS-1 + ENDIF + JST=1 + JKP=0 + K=2 + 321 IF(IREF(K) .LT. 0) THEN + 323 IF(IREF(K+1) .GT. 0) THEN + IREF(K+1)=0 + K=K+1 + GO TO 323 + ELSE + K=K+2 + IF(K .GE. KS) GO TO 325 + GO TO 321 + ENDIF + ELSE + K=K+1 + IF(K .GE. KS) GO TO 325 + GO TO 321 + ENDIF +325 CONTINUE + KC=0 + DO K=1,KS + IF(IREF(K) .EQ. 0) CYCLE + KC=KC+1 + JREF(KC)=IREF(K) + ALXX(KC)=ALXX(K) + ALYY(KC)=ALYY(K) + ALWD(KC)=ALWD(K) + HLEFT(KC)=HLEFT(K) + HMID(KC)=HMID(K) + HRIGHT(KC)=HRIGHT(K) + ENDDO + IREF=JREF + KS=KC + ICTYP=NBRID + KFS=1 + DO K=1,KS + III=K + X11=ALXX(III)*TXSCAL - XS + Y11=ALYY(III)*TXSCAL - XS + ENDDO + DO K=2,KS + IF(IREF(K) .LT. 0 .OR. K .EQ. KS) THEN + ! IF(K .LT. KS) THEN + ! IF(IREF(K) .LT. 0 .AND. IREF(K+1) .GT. 0) THEN + ! ITYPB=ICTYP+1 + ! ICTYP=ICTYP+1 + ! ELSE + ! ITYPB=ITYPIN + ! ENDIF + ! ELSE + ! ITYPB=ITYPIN + ! ENDIF + IF(KFS .EQ. 2 .OR. JPTSB .EQ. 0) THEN + ITYPB=ICTYP + ICTYP=ICTYP+1 + KFS=1 + ELSE + KFS=KFS+1 + ITYPB=ITYPIN + ENDIF + IF(ITYPB .GT. NBRID-1) THEN + ICTT=(ITYPB-NBRID+1)*2 + ICTT=ITYPBC(ICTT) + IRTYP(ITYPB)=ICTT + ELSE + ICTT=0 + IRTYP(ITYPB)=0 + ENDIF + JEND=K + XLENGTHP=XLENGTH +! GO AND FORM A LINE +! IF(ICTT .EQ. 2) XLENGTHP=XBRLEN((ITYPB-39)*2) + CALL FORMLINEL(I1D,I2D,JST,JEND,JKP,XLENGTHP,ITYPB,ICTT) + JST=JEND + ENDIF + ENDDO + IF(I2D .EQ. 1) CALL FORM999(1,1,NELC) + ENDIF + + +! GO TO 4 +! + END + SUBROUTINE INTERP(GRIDX,GRIDY,NL,NH,INT,ALX,ALY,ATX,ATY,NINT,ISWT) +! +! Routine to fill GRIDX and GRIDY by interpolation +! NL = START OF GENERATED +! NH = END OF GENERATED +! INT = INTERVAL +! ALX, ALY = START LOC +! ATX, ATY = END LOC +! NINT = NUMBER OF POINTS +! ISWT = 0 BASELINE = 1 APPLY CHANGES +!IPK MAY02 + REAL*8 GRIDX(NH),GRIDY(NH),ALX,ALY,ATX,ATY +! +! Compute intervals +! + XINT=(ATX-ALX)/FLOAT(NINT) + YINT=(ATY-ALY)/FLOAT(NINT) +! +! Generate points +! + IF(ISWT .EQ. 0) THEN + KP=0 + DO 200 K=NL,NH,INT + IF(KP .EQ. 0) THEN + GRIDX(K)=ALX + GRIDY(K)=ALY + ELSE + GRIDX(K)=GRIDX(KP)+XINT + GRIDY(K)=GRIDY(KP)+YINT + ENDIF + KP=K + 200 CONTINUE + ELSE + XAD=ALX + YAD=ALY + KP=0 + DO 220 K=NL,NH,INT + IF(KP .EQ. 0) THEN + GRIDX(K)=GRIDX(K)+XAD + GRIDY(K)=GRIDY(K)+YAD + ELSE + XAD=XAD+XINT + YAD=YAD+YINT + GRIDX(K)=GRIDX(K)+XAD + GRIDY(K)=GRIDY(K)+YAD + ENDIF + KP=K + 220 CONTINUE + ENDIF + RETURN + END + SUBROUTINE GEL +! +! Routine to create a block of elements +! + + USE WINTERACTER + USE BLK1MOD + INCLUDE 'BFILES.I90' +! INCLUDE 'BLK1.COM' + + include 'd.inc' + + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + REAL*8 GRIDX,GRIDY,ALX,ALY,BLX,BLY,ARX,ARY,BRX,BRY,GRIDXL,GRIDYL + INTEGER*2 IGSKP + COMMON /GBLK/ GRIDX(MAXPGEN),GRIDY(MAXPGEN),GRIDXL(MAXPGEN),GRIDYL(MAXPGEN)& + ,IGSKP(MAXPGEN),NRL,NRT,NYP,IGRIDE(MAXPGEN) +! + CHARACTER*1 IFLAG + data itime/0/ + + if(itime .eq. 0) then + nx=0 + ny=0 + itime=1 + endif + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to use'//& + CHAR(13)//'existing nodes?' ,& + 'ELEMENT CREATION OPTION') +! +! If answer 'No', point to location +! + IF (WInfoDialog(4) .EQ. 2) then + noptcr=0 + GO TO 4 + else + noptcr=1 + go to 1100 + END IF + + 4 CONTINUE + NHTP=0 + NMESS=8 + NBRR = 3 + CALL HEDR +! +! Get screen coordinates of each end of line +! + 7 CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ALX=XTEMP + ALY=YTEMP + IF(IRMAIN .EQ. 1) RETURN +! + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + CALL WRTOUT(0) + RETURN + elseif(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + ENDIF +! +! Exit input +! + 9 CONTINUE +! CALL PLOTT(XTEMP,YTEMP,3) +! CALL PLOTT(XTEMP,YTEMP,2) + siz=0.1 + call drawcr(xtemp,ytemp,siz) + NBRR=0 + CALL HEDR + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + ARX=XTEMP + ARY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! +12 CONTINUE +! CALL PLOTT(XTEMP,YTEMP,3) +! CALL PLOTT(XTEMP,YTEMP,2) + call drawcr(xtemp,ytemp,siz) + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + BRX=XTEMP + BRY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! + 16 CONTINUE +! CALL PLOTT(XTEMP,YTEMP,3) +! CALL PLOTT(XTEMP,YTEMP,2) + call drawcr(xtemp,ytemp,siz) + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + BLX=XTEMP + BLY=YTEMP + if(iflag .eq. 'n') then + call getfpna(XTEMP) + call getfpna(YTEMP) + endif + IF(IRMAIN .EQ. 1) RETURN +! + 20 CONTINUE +! CALL PLOTT(XTEMP,YTEMP,3) +! CALL PLOTT(XTEMP,YTEMP,2) + call drawcr(xtemp,ytemp,siz) + go to 25 + +1100 continue + CALL PROX(CORD(1,1),CORD(1,2),NP,xx,yy,INODE1,IFLAG,INSKP,IBOX) + ALX=CORD(INODE1,1) + ALY=CORD(INODE1,2) + CALL PROX(CORD(1,1),CORD(1,2),NP,xx,yy,INODE2,IFLAG,INSKP,IBOX) + ARX=CORD(INODE2,1) + ARY=CORD(INODE2,2) + CALL PROX(CORD(1,1),CORD(1,2),NP,xx,yy,INODE3,IFLAG,INSKP,IBOX) + BRX=CORD(INODE3,1) + BRY=CORD(INODE3,2) + CALL PROX(CORD(1,1),CORD(1,2),NP,xx,yy,INODE4,IFLAG,INSKP,IBOX) + BLX=CORD(INODE4,1) + BLY=CORD(INODE4,2) + +! +! Define number of elements along x and y sides +! + 25 CONTINUE + NMESS=45 + CALL HEDR + NMESS = 9 + call getint(nx) +! READ(*,*) NX + NMESS=45 + CALL HEDR + NMESS = 10 + call getint(ny) +! READ(*,*) NY + NXP=NX+1 + NYP=NY+1 + NRL=NX*NYP+1 + NRT=NXP*NYP + +! ipk jul01 test for limit exceeded + if(nrt .gt. maxpgen) then + call panelegn + go to 25 + endif + + DO N=1,NE + DO M=1,8 + NOPSV(N,M)=NOP(N,M) + ENDDO + IMATSV(N)=IMAT(N) + ENDDO + NESAV=NE + NEFSAV=NENTRY + NPUNDO=NRT +! +! Initialize GRIDX and GRIDY +! + DO 100 N=1,NRT + GRIDX(N)=0. + GRIDY(N)=0. + IGSKP(N)=0 + 100 END DO +! +! Interpolate left and right side +! + CALL INTERP(GRIDX,GRIDY,1,NYP,1,ALX,ALY,BLX,BLY,NY,0) + CALL INTERP(GRIDX,GRIDY,NRL,NRT,1,ARX,ARY,BRX,BRY,NY,0) +! +! plot points +! + DO 200 N=1,NYP +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + GRIDXL(N) = GRIDX(N)*TXSCAL - XS + GRIDYL(N) = GRIDY(N)*TXSCAL - YS + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + siz=0.1 + call drawcr(xtemp,ytemp,siz) + CALL RBlue + 200 END DO + DO 220 N=NRL,NRT +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + GRIDXL(N) = GRIDX(N)*TXSCAL - XS + GRIDYL(N) = GRIDY(N)*TXSCAL - YS + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + call drawcr(xtemp,ytemp,siz) + CALL RBlue + 220 END DO +! +! Interpolate bottom and top sides +! + CALL INTERP(GRIDX,GRIDY,1,NRL,NYP,ALX,ALY,ARX,ARY,NX,0) + CALL INTERP(GRIDX,GRIDY,NYP,NRT,NYP,BLX,BLY,BRX,BRY,NX,0) +! +! plot points +! + DO 240 N=1,NRL,NYP +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + GRIDXL(N) = GRIDX(N)*TXSCAL - XS + GRIDYL(N) = GRIDY(N)*TXSCAL - YS + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + call drawcr(xtemp,ytemp,siz) + CALL RBlue + 240 END DO + DO 260 N=NYP,NRT,NYP +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + GRIDXL(N) = GRIDX(N)*TXSCAL - XS + GRIDYL(N) = GRIDY(N)*TXSCAL - YS + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + call drawcr(xtemp,ytemp,siz) + CALL RBlue + 260 END DO +! +! Interpolate interior points +! + DO 300 M=2,NYP + NFS=NRL+M-1 + CALL INTERP(GRIDX,GRIDY,M,NFS,NYP,GRIDX(M),GRIDY(M),GRIDX(NFS) & + & ,GRIDY(NFS),NX,0) + DO N=M,NFS + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + GRIDXL(N) = GRIDX(N)*TXSCAL - XS + GRIDYL(N) = GRIDY(N)*TXSCAL - YS + CALL RRed + call drawcr(xtemp,ytemp,siz) + CALL RBlue + ENDDO + 300 END DO + 305 CONTINUE + NMESS=11 + NBRR=10 + CALL HEDR +310 IBOX=1 + ip=0 + CALL PROX(GRIDX(1),GRIDY(1),NRT,XX,YY,IP,IFLAG,IGSKP,IBOX) + IF(IBOX .NE. 6 .and. (ip .gt. 0 .and. ip .le. nrt)) THEN + XKP=GRIDX(IP) + YKP=GRIDY(IP) + IPK=IP + ENDIF + IF(IRMAIN .EQ. 1 .OR. IBOX .EQ. 7) RETURN + IF(IFLAG .EQ. 'q') THEN + GO TO 400 + ENDIF + DO N=1,NRT + GRIDX(N)=(GRIDXL(N)+XS)/TXSCAL + GRIDY(N)=(GRIDYL(N)+YS)/TXSCAL + ENDDO + IF(IBOX .EQ. 6) THEN + XX=XKP + YY=YKP + IP=IPK + GO TO 315 + ENDIF + write(90,*) 'back prox irdisp',IRDISP + IF(IRDISP .EQ. 1) THEN + CALL PLTPT + ENDIF +! +! Get screen coordinate of new node location +! + CALL XYLOC(XX,YY,IFLAG,IBOX) + write(90,*) 'back xyloc irdisp',IRDISP + IF(IRMAIN .EQ. 1 .OR. IBOX .EQ. 7) RETURN + 315 IF(IRDISP .EQ. 1) THEN + DO N=1,NRT + GRIDX(N)=(GRIDXL(N)+XS)/TXSCAL + GRIDY(N)=(GRIDYL(N)+YS)/TXSCAL + ENDDO + CALL PLTPT + ENDIF +! +! Establish difference from movement +! + ALX=XX-GRIDX(IP) + ALY=YY-GRIDY(IP) + CALL PLOTT(XX,YY,3) + CALL PLOTT(XX,YY,2) + FPN = IP +! CALL RRed +! CALL NUMBR(XX,YY,0.20,FPN,0.0,-1) +! CALL RBlue +! +! Find location on boundary +! + IF(IP .LE. NYP) THEN +! Left boundary + NLW=IP + NUP=NRL+IP-1 + NSTP=NYP + BLX=0. + BLY=0. + NS=NX + ELSEIF(IP .GE. NRL) THEN +! Right boundary + NLW=IP-NX*NYP + NUP=IP + NSTP=NYP + BLX=ALX + BLY=ALY + ALX=0. + ALY=0. + NS=NX + ELSE + LINENO=(IP-1)/NYP + IF(IP-LINENO*NYP .EQ. 1) THEN +! Lower boundary + NLW=IP + NUP=IP+NY + NSTP=1 + BLX=0. + BLY=0. + NS=NY + ELSEIF(IP-LINENO*NYP .EQ. NYP) THEN +! Upper boundary + NLW=IP-NY + NUP=IP + NSTP=1 + BLX=ALX + BLY=ALY + ALX=0. + ALY=0. + NS=NY + ELSE + GO TO 305 + ENDIF + ENDIF +! +! Interpolate change along x line +! 14935011 + IF(IRGB .EQ. 14935011) THEN + call rgrey + ELSE + CALL RWHITEB + ENDIF + do n=1,nrt + XTEMP=gridx(n) + YTEMP=gridy(n) + call drawcr(xtemp,ytemp,siz) + enddo + CALL RRed + CALL INTERP(GRIDX,GRIDY,NLW,NUP,NSTP,ALX,ALY,BLX,BLY,NS,1) + do n=1,nrt + XTEMP=gridx(n) + YTEMP=gridy(n) + call drawcr(xtemp,ytemp,siz) + GRIDXL(N) = GRIDX(N)*TXSCAL - XS + GRIDYL(N) = GRIDY(N)*TXSCAL - YS + enddo + call Rblue + GO TO 310 +! +! Copy points into cord array +! + 400 CONTINUE + DO 500 N=1,NRT +! +! Find next blank node in CORD +! + IF(NOPTCR .EQ. 1) THEN + IF(N .EQ. 1) THEN + NODDEL(N)=0 + GO TO 500 + ELSEIF(N .EQ. NYP) THEN + NODDEL(N)=0 + GO TO 500 + ELSEIF(N .EQ. 1+NYP*NX) THEN + NODDEL(N)=0 + GO TO 500 + ELSEIF(N .EQ. NRT) THEN + NODDEL(N)=0 + GO TO 500 + ENDIF + ENDIF + CALL GETNOD(J) + NODDEL(N)=J +! +! Store GRIDX and GRIDY into it +! + CORD(J,1) = GRIDX(N) + CORD(J,2) = GRIDY(N) + IGRIDE(N) = J + INEW(J) = 1 + INSKP(J) = 0 +! + XUSR(J) = GRIDX(N)*TXSCAL - XS + YUSR(J) = GRIDY(N)*TXSCAL - YS +! +! Display point +! + CALL PLTNOD(J,1) +! + 500 END DO +! +! Generate elements +! + CALL GETELM(K) + IECHG=0 +! + DO 600 I=1,NX + DO 590 J=1,NY + CALL GETELM(K) + IF(I .EQ. 1 .AND. J .EQ. 1 .AND. NOPTCR .EQ. 1) THEN + NOP(K,1)=INODE1 + ELSE + NOP(K,1)=IGRIDE((I-1)*NYP+J) + ENDIF + NOP(K,2)=0 + IF(I .EQ. NX .AND. J .EQ. 1 .AND. NOPTCR .EQ. 1) THEN + NOP(K,3)=INODE2 + ELSE + NOP(K,3)=IGRIDE(I*NYP+J) + ENDIF + NOP(K,4)=0 + IF(I .EQ. NX .AND. J .EQ. NY .AND. NOPTCR .EQ. 1) THEN + NOP(K,5)=INODE3 + ELSE + NOP(K,5)=IGRIDE(I*NYP+J+1) + ENDIF + NOP(K,6)=0 + IF(I .EQ. 1 .AND. J .EQ. NY .AND. NOPTCR .EQ. 1) THEN + NOP(K,7)=INODE4 + ELSE + NOP(K,7)=IGRIDE((I-1)*NYP+J+1) + ENDIF + NOP(K,8)=0 + IMAT(K)=1 +! IF(K .GT. NE) NE=K + NCORN(K)=8 + IESKP(K)=0 +!IPK JAN98 + IERC=0 + IRDONE=0 + CALL PLTELM(K,IERC) + 590 CONTINUE + 600 END DO +! CALL UNDO(IYES) +! IF(IYES .EQ. 1) THEN +! DO N=1,NEUNDO +! J=IELDEL(N) +! CALL DELTEL(J) +! ENDDO +! DO N=1,NPUNDO +! J=NODDEL(N) +! CALL DELETN(J) +! ENDDO +! ENDIF + CALL WRTOUT(0) + RETURN + END + + SUBROUTINE PLTPT + + USE BLK1MOD + INCLUDE 'TXFRM.COM' +! INCLUDE 'BLK1.COM' + +!IPK MAY02 + REAL*8 GRIDX,GRIDY,GRIDXL,GRIDYL + INTEGER*2 IGSKP + + COMMON /GBLK/ GRIDX(MAXPGEN),GRIDY(MAXPGEN),GRIDXL(MAXPGEN),GRIDYL(MAXPGEN)& + ,IGSKP(MAXPGEN),NRL,NRT,NYP,IGRIDE(MAXPGEN) + + DO N=1,NRT + GRIDX(N)=(GRIDXL(N)+XS)/TXSCAL + GRIDY(N)=(GRIDYL(N)+YS)/TXSCAL + ENDDO + +! +! plot points +! + DO N=1,NYP +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + siz=0.1 + call drawcr(xtemp,ytemp,siz) + CALL RBlue + END DO + DO N=NRL,NRT +!IP MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + call drawcr(xtemp,ytemp,siz) + CALL RBlue + END DO +! +! plot points +! + DO N=1,NRL,NYP +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + call drawcr(xtemp,ytemp,siz) + CALL RBlue + END DO + DO N=NYP,NRT,NYP +!IPK MAY02 + XTEMP=GRIDX(N) + YTEMP=GRIDY(N) + CALL PLOTT(XTEMP,YTEMP,3) + CALL PLOTT(XTEMP,YTEMP,2) + FPN = N + CALL RRed +! CALL NUMBR(XTEMP,YTEMP,0.20,FPN,0.0,-1) + call drawcr(xtemp,ytemp,siz) + CALL RBlue + END DO + RETURN + END + + subroutine panelegn + + USE WINTERACTER + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'You have requested '//& + ' more than the allowable number of nodes.'//CHAR(13)//'The model will return '// & + 'to allow new numbers to be input','Limit error') +! +! If answer 'Yes', execute +! + IF (WInfoDialog(4) .EQ. 1) then + return + ENDIF + return + end + SUBROUTINE FORMLINEMENU(ITYP,I1D,I2D,IFIN,XLENGTH,ITYPIN,NELC,NBRID) + + + use winteracter + + implicit none + SAVE + + include 'D.inc' + INCLUDE 'BFILES.I90' + DATA ITIME/0/ + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: ITYP,I1D,IERR,ITIME,I2D,IFIN,ITYPIN,NELC,NBRID + real :: XLENGTH +! character*3 :: sub +! DATA ITIME/0/ +! IF(ITIME .EQ. 0) THEN + XLENGTH=250. + ITIME=1 + I1D=0 + I2D=1 + IFIN=1 + ITYPIN=30 + NELC=2 + NBRID=40 +! idf_radio1=2 + ! ENDIF + + + + call wdialogload(IDD_FORMLINE) + ierr=infoerror(1) + + call wdialogputRadioButton(idf_radio2) + call wdialogputRadioButton(idf_radio3) + CALL WDialogPutREAL(idf_REAL1,XLENGTH) + CALL WDialogPutInteger(idf_INTEGER1,ITYPIN) + call wdialogPutCheckBox(idf_check3,IFIN) + CALL WDialogPutInteger(idf_INTEGER2,NELC) + CALL WDialogPutInteger(idf_INTEGER3,NBRID) + + + CALL WDialogSelect(IDD_FORMLINE) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + call wdialogGetRadioButton(idf_radio1,ITYP) + call wdialogGetRadioButton(idf_radio3,I1D) + call wdialogGetCheckBox(idf_check3,IFIN) + CALL WDialogGetREAL(idf_REAL1,XLENGTH) + CALL WDialogGetInteger(idf_INTEGER1,ITYPIN) + CALL WDialogGetInteger(idf_INTEGER2,NELC) + CALL WDialogGetInteger(idf_INTEGER3,NBRID) + if(I1D .eq. 1) then + I1D=0 + I2D=0 + ELSEIF(I1D .EQ. 2) THEN + I1D=1 + I2D=0 + ELSEIF(I1D .EQ. 3) THEN + I1D=0 + I2D=1 + ENDIF + RETURN + ELSEIF(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + I1D=-999 + RETURN + ENDIF + ENDDO + RETURN + END + + SUBROUTINE FILEDAT(JPTS,NBRID) + USE WINTERACTER + USE DFLIB + USE BLK1MOD +! +! +! Define some parameters to match those in the resource file +! + include 'd.inc' + REAL*8 ATMPAR + CHARACTER(LEN=255) :: FNAME,FILTER + CHARACTER(LEN=3) :: SUB + CHARACTER ID*8,DLIN*72 + IINALN=45 + Filter='ALIGNMENT file -- *.dat|' + + CALL WSelectFile(Filter,PromptOn,FNAME,'Open Alignment File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(IINALN,FILE=FNAME,STATUS='OLD',action='read') + ELSE + RETURN + ENDIF + DO K=1,2000 + CALL GINPT(IINALN,ID,DLIN) + IF(ID(1:3) .EQ. 'XYW') THEN + READ(DLIN,*) ALXX(K),ALYY(K),ALWD(K),HLEFT(K),HMID(K),HRIGHT(K) + ELSEIF(ID(1:3) .EQ. 'XY ') THEN + READ(DLIN,*) ALXX(K),ALYY(K) + ALWD(K)=0. + ELSE + JPTS=K-1 + BACKSPACE(IINALN) + GOTO 200 + ENDIF + ENDDO +200 CONTINUE + READ(IINALN,'(A8)') ID + IF(ID(1:7) .EQ. 'ENDFILE') RETURN + + CALL GETBRIDCUL(IINALN,NBRID) +! K=(JPTSB-2)/2+2 +! ALXX(K)=ALXX(2) +! ALYY(K)=ALYY(2) +! JPTS=K +! DO K=2,JPTSB-2,2 +! ALXX(K+1)=(BLXX(K)+BLXX(K+1))/2. +! ALYY(K+1)=(BLYY(K)+BLYY(K+1))/2. +! ALWD(K+1)=(BLWD(K)+BLWD(K+1))/2. +! ENDDO + +! DO K=1,1000 +! ATMPAR=BLXX(K) +! BLXX(K)=ALXX(K) +! ALXX(K)=ATMPAR +! ATMPAR=BLYY(K) +! BLYY(K)=ALYY(K) +! ALYY(K)=ATMPAR +! ENDDO +! NTEMP=JPTSB +! JPTSB=JPTS +! NPTS=NTEMP + RETURN + END + SUBROUTINE GETBRIDCUL(IINALN,NBRID) + USE BLK1MOD + INCLUDE 'TXFRM.COM' + CHARACTER(LEN=140) :: DLINLARGE + CHARACTER(LEN=8) :: IDN,ID + REAL*8 TEMP(9),CPX,CPY,XCEN,YCEN,CW + KID=0 + PI=3.14159 + KK=1 + DO K=1,2000 + CALL GINPT1(IINALN,DLINLARGE) + IF(DLINLARGE(1:7) .EQ. 'CULVERT') THEN + READ(DLINLARGE(9:140),*) idn,(TEMP(J),J=2,9) + ITYPBC(KK)=1 + ITYPBC(KK+1)=1 + XCEN=(TEMP(2)+TEMP(4))/2. + YCEN=(TEMP(3)+TEMP(5))/2. + CW=TEMP(9)*TEMP(8)/2. + IF(KK .EQ. 1) THEN + CPX=ALXX(1) + CPY=ALYY(1) + ELSE + CPX=BLXX(KK-1) + CPY=BLYY(KK-1) + ENDIF + DNORM=ATAN2(YCEN-CPY,XCEN-CPX) + IF(DNORM .LT. 0.) DNORM=DNORM+PI + IF(DNORM .GT. PI) DNORM=DNORM-PI + BLXX(KK)=XCEN-CW*COS(DNORM) + BLYY(KK)=YCEN-CW*SIN(DNORM) + BLWD(KK)=TEMP(7) + CNX(KK,1)=BLXX(KK)-TEMP(6)/2.*COS(DNORM-PI/2.) + CNX(KK,2)=BLXX(KK)+TEMP(6)/2.*COS(DNORM-PI/2.) + CNY(KK,1)=BLYY(KK)-TEMP(6)/2.*SIN(DNORM-PI/2.) + CNY(KK,2)=BLYY(KK)+TEMP(6)/2.*SIN(DNORM-PI/2.) + KPT=NBRID+KK/2 + KID(KPT,1)=KK + DO KLM=1,2 + CALL GETNOD(J) + KID(KPT,KLM+1)=J + INEW(J) = 1 + INSKP(J) =0 + XUSR(J)=CNX(KK,KLM) + YUSR(J)=CNY(KK,KLM) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + ENDDO + + KK=KK+1 + BLXX(KK)=XCEN+CW*COS(DNORM) + BLYY(KK)=YCEN+CW*SIN(DNORM) + BLWD(KK)=TEMP(7) + CNX(KK-1,3)=BLXX(KK)-TEMP(6)/2.*COS(DNORM-PI/2.) + CNX(KK-1,4)=BLXX(KK)+TEMP(6)/2.*COS(DNORM-PI/2.) + CNY(KK-1,3)=BLYY(KK)-TEMP(6)/2.*SIN(DNORM-PI/2.) + CNY(KK-1,4)=BLYY(KK)+TEMP(6)/2.*SIN(DNORM-PI/2.) + + DO KLM=3,4 + CALL GETNOD(J) + KID(KPT,KLM+1)=J + INEW(J) = 1 + INSKP(J) =0 + XUSR(J)=CNX(KK-1,KLM) + YUSR(J)=CNY(KK-1,KLM) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + ENDDO + KK=KK+1 + ELSEIF(DLINLARGE(1:6) .EQ. 'BRIDGE') THEN + READ(DLINLARGE(7:140),*) IDN,(TEMP(J),J=1,7) + ITYPBC(KK)=2 + ITYPBC(KK+1)=2 + BLXX(KK)=TEMP(1) + BLYY(KK)=TEMP(2) + BLWD(KK)=TEMP(3) + KK=KK+1 + BLXX(KK)=TEMP(4) + BLYY(KK)=TEMP(5) + BLWD(KK)=TEMP(6) + XBRLEN(KK)=SQRT((BLXX(KK)-BLXX(KK-1))**2+(BLYY(KK)-BLYY(KK-1))**2) + KK=KK+1 +! READ(DLINLARGE(8:140),*) ID,(TEMP(J),J=1,6) + ELSEIF(DLINLARGE(1:7) .EQ. 'ENDFILE') THEN + JPTSB=KK-1 + GO TO 200 + ENDIF + ENDDO +200 CONTINUE + RETURN + END + + + \ No newline at end of file diff --git a/src/src83e/ELEVINT.F90 b/src/src83e/ELEVINT.F90 new file mode 100644 index 0000000..fbc222b --- /dev/null +++ b/src/src83e/ELEVINT.F90 @@ -0,0 +1,245 @@ +!----------------------------------------------------------------elevint + subroutine elevint(XX,YY,soln) +!----------------------------------------------------------------------c +! purpose: c +! To interpolate elevation from map data. c +!----------------------------------------------------------------------c +! Input data: c +! (XX, YY) -- a coordinate +!----------------------------------------------------------------------c +! Output data: c +! soln -- elevation value c +!----------------------------------------------------------------------c + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + INTEGER LISTM,NLIST + DIMENSION NLIST(200),ADIST(200) + DIMENSION LISTM(1000),listt(60,4),nlf(4),icomp(4),xnear(4) +! common /mapc/imap(maxpl) +! +! Establish size for range +! + JS=1 + K=0 + KPT=0 + DO 120 J=1,MAXPTS +! +! Determine how long each line is +! + MLEN=J-JS +! print *,XMAP(J),VDX,MAXPTS,MLEN,J,JS + IF(CMAP(J,1) .LT. VDX) THEN +! +! Now check it. +! + K=K+1 + IF(MLEN .GT. 1) THEN +! LTP=LINTYP(K) + DO 110 M=1,MLEN + IF(VAL(JS+M-1) .GT. -9000.) THEN + KPT=KPT+1 + ENDIF + 110 CONTINUE + ENDIF + NMAP=J + IF(MLEN .EQ. 0) GO TO 130 + JS=J+1 + go to 120 + ENDIF + cxcur=xmap(j) + cycur=ymap(j) + 120 END DO + 130 CONTINUE +! +! Estimate areal density to get 100 points +! + ADEN=AMAP*40./(FLOAT(KPT)*TXSCAL**2) +! +! Find square coverage +! + XNEARS=SQRT(ADEN) + xnearo=xnears +! +! initialize range +! + ict=0 + xnears=xnearo + do nang=1,4 + XNEAR(nang)=XNEARO + icomp(nang)=0 + enddo +! +! set imap to zero to start or -1 if no value +! + 220 continue + do n=1,nmap + if(cmap(n,1) .lt. vdx) then + imap(n)=-1 + elseif(val(n) .lt. -9000.) then + imap(n)=-1 + else + imap(n)=0 + endif + enddo +! +! initialize list and completeness test +! + do nang=1,4 + icomp(nang)=0 + do n=1,50 + listt(n,nang)=0 + enddo + enddo +! +! start processing +! + 280 continue +! +! check for completeness intialize counter +! + do nang=1,4 + if(icomp(nang) .eq. 0) then + nlf(nang)=0 + else + ict=ict+1 + endif + enddo +! +! if ict = 4 we are done +! + if(ict .lt. 4) then +! +! loop through map points +! + DO 300 N=1,NMAP +! +! skip if no useful value +! + if(imap(n) .eq. -1) go to 300 +! +! use nang if we have been through before +! + if(imap(n) .gt. 0) then + nang=imap(n) +! +! skip to end if done +! + if(icomp(nang) .eq. 1) then + go to 300 + endif +! +! otherwise check range skipping out if out of range +! + d1=cmap(n,1)-XX + d2=cmap(n,2)-YY + IF(ABS(D1) .GT. XNEAR(NANG)) THEN + IMAP(N)=-1 + GO TO 300 + ELSEIF(ABS(D2) .GT. XNEAR(NANG)) THEN + IMAP(N)=-1 + GO TO 300 + ENDIF +! +! process new point checking range and setting direction +! + else + d1=cmap(n,1)-XX + d2=cmap(n,2)-YY + IF(ABS(D1) .LT. XNEAR(1)) THEN + IF(ABS(D2) .LT. XNEAR(1)) THEN + if(d1 .lt. 0) then + if(d2 .lt. 0) then + imap(n)=3 + nang=3 + else + imap(n)=2 + nang=2 + endif + elseif(d2 .lt. 0) then + imap(n)=4 + nang=4 + else + imap(n)=1 + nang=1 + endif +! +! set to skip out if out of range +! + ELSE + imap(n)=-1 + go to 300 + ENDIF + ELSE + imap(n)=-1 + go to 300 + ENDIF + endif +! +! save value if total less then 50 +! + NLF(NANG)=NLF(NANG)+1 + IF(NLF(NANG) .LT. 51) THEN + LISTT(NLF(NANG),NANG)=N + ENDIF + 300 CONTINUE +! +! now reset range if we need to +! + ictz=0 + do nang=1,4 + if(nlf(nang) .gt. 50) then + rat=sqrt(45./nlf(nang)) + if(rat .lt. 0.2) rat=0.2 + xnear(nang)=xnear(nang)*rat + elseif(nlf(nang) .eq. 0) then + if(xnear(nang) .eq. xnears) then + ictz=ictz+1 + else + icomp(nang)=1 + endif + else + icomp(nang)=1 + endif + enddo + if(ictz .gt. 1) then + do nang=1,4 + xnear(nang)=xnear(nang)*2. + xnears=xnears*2. + enddo + if(xnear(1) .lt. 4.) then + go to 220 + endif + endif +! +! go back and try again +! + go to 280 + endif +! +! finished now compact list +! + nlg=0 + do nang=1,4 + nlim=nlf(nang) + if(nlim .eq. 0) then + nlim=50 + endif + do nlgg=1,nlim + if(listt(nlgg,nang) .gt. 0) then + nlg=nlg+1 + listm(nlg)=listt(nlgg,nang) + endif + enddo + enddo +! +!-----perform interpolation +! + SOLN=-9999.0 + CALL GRIDIN(XX,YY,SOLN,LISTM,NLG) + return + END diff --git a/src/src83e/ELTDISP.F90 b/src/src83e/ELTDISP.F90 new file mode 100644 index 0000000..7bdc9e5 --- /dev/null +++ b/src/src83e/ELTDISP.F90 @@ -0,0 +1,426 @@ + Subroutine EltDisp(nsw) + + USE WINTERACTER + USE BLK1MOD +! + include 'd.inc' +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: N,IBOX,NN,NOOP(16),NEAC(8) + INTEGER :: IERR + CHARACTER*1 :: IFLAG + + DATA N/1/ + ims=0 + 100 continue + call wdialogload(IDD_ELTDATA) + ierr=infoerror(1) + IF(NSW .NE. 0) N=ABS(NSW) + CALL WDialogPutInteger(IDF_INTEGER1,N) + NN=N + DO N1=1,8 + NOOP(N1)=NOP(N,N1) + NOOP(N1+8)=NOP(N,N1) + ENDDO + IMAAT=IMAT(N) + 120 CONTINUE + CALL WDialogPutInteger(IDF_INTEGER1,N) + CALL WDialogPutInteger(IDF_INTEGER2,NOOP(1)) + CALL WDialogPutInteger(IDF_INTEGER3,NOOP(2)) + CALL WDialogPutInteger(IDF_INTEGER4,NOOP(3)) + CALL WDialogPutInteger(IDF_INTEGER5,NOOP(4)) + CALL WDialogPutInteger(IDF_INTEGER6,NOOP(5)) + CALL WDialogPutInteger(IDF_INTEGER7,NOOP(6)) + CALL WDialogPutInteger(IDF_INTEGER8,NOOP(7)) + CALL WDialogPutInteger(IDF_INTEGER9,NOOP(8)) + CALL WDialogPutInteger(IDF_INTEGER10,IMAAT) + CALL WDialogSelect(IDD_ELTDATA) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modeless) + ierr=infoerror(1) + + if(ims .eq. 1) go to 200 + 150 CONTINUE + IF(NSW .LE. 0) THEN + call wdialogload(IDD_SELELT) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,N) + + CALL WDialogSelect(IDD_SELELT) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,ModaL) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + ims=1 + go to 100 + endif +!ipksep02 + ims=1 + go to 100 + enddo + ELSE + call wdialogload(IDD_ELTERR) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,N) + + CALL WDialogSelect(IDD_ELTERR) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,ModaL) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + ims=1 + go to 100 + endif +!ipk sep02 + ims=1 + go to 100 + enddo + ENDIF + + 200 continue + + DO + CALL WMessage(ITYPE,MESSAGE) + SELECT CASE (ITYPE) + CASE (PushButton) + IF(MESSAGE%VALUE1.EQ.IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL WDialogGetInteger(IDF_INTEGER2,NOOP(1)) + CALL WDialogGetInteger(IDF_INTEGER3,NOOP(2)) + CALL WDialogGetInteger(IDF_INTEGER4,NOOP(3)) + CALL WDialogGetInteger(IDF_INTEGER5,NOOP(4)) + CALL WDialogGetInteger(IDF_INTEGER6,NOOP(5)) + CALL WDialogGetInteger(IDF_INTEGER7,NOOP(6)) + CALL WDialogGetInteger(IDF_INTEGER8,NOOP(7)) + CALL WDialogGetInteger(IDF_INTEGER9,NOOP(8)) + CALL WDialogGetInteger(IDF_INTEGER10,IMAAT) + ISUM=0 + DO N1=1,8 + NOP(N,N1)=NOOP(N1) + ISUM=ISUM+NOOP(N1) + ENDDO + IMAT(N)=IMAAT + IF(ISUM .EQ. 0) THEN + XC(N)=VOID + YC(N)=VOID + IF(N .LT. NELAST) NELAST=N + IESKP(N)=1 + NCORN(N)=0 + IMAT(N)=0 + ENDIF + call WDialogHide() + call wdialogUNload() + RETURN + ELSEIF(MESSAGE%VALUE1.EQ.IDNEXT) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL WDialogGetInteger(IDF_INTEGER2,NOOP(1)) + CALL WDialogGetInteger(IDF_INTEGER3,NOOP(2)) + CALL WDialogGetInteger(IDF_INTEGER4,NOOP(3)) + CALL WDialogGetInteger(IDF_INTEGER5,NOOP(4)) + CALL WDialogGetInteger(IDF_INTEGER6,NOOP(5)) + CALL WDialogGetInteger(IDF_INTEGER7,NOOP(6)) + CALL WDialogGetInteger(IDF_INTEGER8,NOOP(7)) + CALL WDialogGetInteger(IDF_INTEGER9,NOOP(8)) + CALL WDialogGetInteger(IDF_INTEGER10,IMAAT) + ISUM=0 + DO N1=1,8 + NOP(N,N1)=NOOP(N1) + ISUM=ISUM+NOOP(N1) + ENDDO + IMAT(N)=IMAAT + IF(ISUM .EQ. 0) THEN + XC(N)=VOID + YC(N)=VOID + IF(N .LT. NELAST) NELAST=N + IESKP(N)=1 + NCORN(N)=0 + IMAT(N)=0 + ENDIF + GO TO 150 + ELSEIF(MESSAGE%VALUE1.EQ.IDF_delete) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL DELTEL(N) + call WDialogHide() + call wdialogUNload() + RETURN + ELSEIF(MESSAGE%VALUE1.EQ.IDCANCEL) THEN + call WDialogHide() + call wdialogUNload() + RETURN + ELSEIF(MESSAGE%VALUE1.EQ.IDFROTATE) THEN + call WDialogHide() + call wdialogUNload() + call plotot(1) + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select starting node','CHOOSE NODE') + IBOX=1 + DO K=1,8 + NEAC(K)=NOP(N,K) + ENDDO + CALL PROXEL(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX,NEAC) + DO K=1,NCORN(N) + IF(NOOP(K) .EQ. INODE) THEN + LL=K-1 + DO L=1,NCORN(N) + LL=LL+1 + IF(NCORN(N) .EQ. 6 .AND. LL .EQ. 7) LL=LL+2 + NOOP(L)=NOOP(LL) + ENDDO + IF(NCORN(N) .EQ. 6) THEN + NOOP(7)=0 + NOOP(8)=0 + ENDIF + call wdialogload(IDD_ELTDATA) + GO TO 120 + ENDIF + enddo + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Selected node not within element','CHOOSE NODE') + call wdialogload(IDD_ELTDATA) + GO TO 120 + + ENDIF + END SELECT + END DO + + RETURN + END + + SUBROUTINE GETELMNO + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 IFLAG + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select element','CHOOSE ELEMENT') + IBOX=1 + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + INEG=-IELEM + CALL ELTDISP1(INEG) + RETURN + END + + + Subroutine EltDisp1(nsw) + + USE WINTERACTER + USE BLK1MOD +! + include 'd.inc' +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: N,IBOX,NN,NOOP(16),NEAC(8) + INTEGER :: IERR + CHARACTER*1 :: IFLAG + + DATA N/1/ + ims=0 + 100 continue + call wdialogload(IDD_ELTDATA) + ierr=infoerror(1) + IF(NSW .NE. 0) N=ABS(NSW) + CALL WDialogPutInteger(IDF_INTEGER1,N) + NN=N + DO N1=1,8 + NOOP(N1)=NOP(N,N1) + NOOP(N1+8)=NOP(N,N1) + ENDDO + IMAAT=IMAT(N) + 120 CONTINUE + CALL WDialogPutInteger(IDF_INTEGER1,N) + CALL WDialogPutInteger(IDF_INTEGER2,NOOP(1)) + CALL WDialogPutInteger(IDF_INTEGER3,NOOP(2)) + CALL WDialogPutInteger(IDF_INTEGER4,NOOP(3)) + CALL WDialogPutInteger(IDF_INTEGER5,NOOP(4)) + CALL WDialogPutInteger(IDF_INTEGER6,NOOP(5)) + CALL WDialogPutInteger(IDF_INTEGER7,NOOP(6)) + CALL WDialogPutInteger(IDF_INTEGER8,NOOP(7)) + CALL WDialogPutInteger(IDF_INTEGER9,NOOP(8)) + CALL WDialogPutInteger(IDF_INTEGER10,IMAAT) + CALL WDialogSelect(IDD_ELTDATA) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + 150 CONTINUE + + DO +! Branch depending on type of message. +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL WDialogGetInteger(IDF_INTEGER2,NOOP(1)) + CALL WDialogGetInteger(IDF_INTEGER3,NOOP(2)) + CALL WDialogGetInteger(IDF_INTEGER4,NOOP(3)) + CALL WDialogGetInteger(IDF_INTEGER5,NOOP(4)) + CALL WDialogGetInteger(IDF_INTEGER6,NOOP(5)) + CALL WDialogGetInteger(IDF_INTEGER7,NOOP(6)) + CALL WDialogGetInteger(IDF_INTEGER8,NOOP(7)) + CALL WDialogGetInteger(IDF_INTEGER9,NOOP(8)) + CALL WDialogGetInteger(IDF_INTEGER10,IMAAT) + ISUM=0 + DO N1=1,8 + NOP(N,N1)=NOOP(N1) + ISUM=ISUM+NOOP(N1) + ENDDO + IMAT(N)=IMAAT + IF(ISUM .EQ. 0) THEN + XC(N)=VOID + YC(N)=VOID + IF(N .LT. NELAST) NELAST=N + IESKP(N)=1 + NCORN(N)=0 + IMAT(N)=0 + ENDIF + CALL HEDR + RETURN + ELSEIF (WInfoDialog(ExitButton) .EQ. IDNEXT) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL WDialogGetInteger(IDF_INTEGER2,NOOP(1)) + CALL WDialogGetInteger(IDF_INTEGER3,NOOP(2)) + CALL WDialogGetInteger(IDF_INTEGER4,NOOP(3)) + CALL WDialogGetInteger(IDF_INTEGER5,NOOP(4)) + CALL WDialogGetInteger(IDF_INTEGER6,NOOP(5)) + CALL WDialogGetInteger(IDF_INTEGER7,NOOP(6)) + CALL WDialogGetInteger(IDF_INTEGER8,NOOP(7)) + CALL WDialogGetInteger(IDF_INTEGER9,NOOP(8)) + CALL WDialogGetInteger(IDF_INTEGER10,IMAAT) + ISUM=0 + DO N1=1,8 + NOP(N,N1)=NOOP(N1) + ISUM=ISUM+NOOP(N1) + ENDDO + IMAT(N)=IMAAT + IF(ISUM .EQ. 0) THEN + XC(N)=VOID + YC(N)=VOID + IF(N .LT. NELAST) NELAST=N + IESKP(N)=1 + NCORN(N)=0 + IMAT(N)=0 + ENDIF + GO TO 150 + ELSEIF (WInfoDialog(ExitButton) .EQ. IDF_DELETE) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL DELTEL(N) + RETURN + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + RETURN + ELSEIF (WInfoDialog(ExitButton) .EQ. IDFROTATE) THEN + call plotot(1) + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select starting node','CHOOSE NODE') + IBOX=1 + DO K=1,8 + NEAC(K)=NOP(N,K) + ENDDO + CALL PROXEL(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX,NEAC) + DO K=1,NCORN(N) + IF(NOOP(K) .EQ. INODE) THEN + LL=K-1 + DO L=1,NCORN(N) + LL=LL+1 + IF(NCORN(N) .EQ. 6 .AND. LL .EQ. 7) LL=LL+2 + NOOP(L)=NOOP(LL) + ENDDO + IF(NCORN(N) .EQ. 6) THEN + NOOP(7)=0 + NOOP(8)=0 + ENDIF + call wdialogload(IDD_ELTDATA) + GO TO 120 + ENDIF + enddo + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Selected node not within element','CHOOSE NODE') + call wdialogload(IDD_ELTDATA) + GO TO 120 + + ENDIF + END DO + RETURN + END + + Subroutine EltERRDisp(nsw,ims) + + USE WINTERACTER + USE BLK1MOD +! + include 'd.inc' +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: NSW,IBOX,NN,NOOP(16) + INTEGER :: IERR + CHARACTER*1 :: IFLAG + + DATA N/1/ + ims=0 + 100 continue + call wdialogload(IDD_ELTERR2) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,NSW) + + CALL WDialogSelect(IDD_ELTERR) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,ModaL) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,NSW) + ims=1 + return + else + ims=0 + return + endif + enddo + return + end + + + + \ No newline at end of file diff --git a/src/src83e/ELTS.F90 b/src/src83e/ELTS.F90 new file mode 100644 index 0000000..8261fbd --- /dev/null +++ b/src/src83e/ELTS.F90 @@ -0,0 +1,712 @@ +! Last change: IPK 12 Jan 98 1:59 pm +!ipk delete old calls to char(7) +!ipk last updated Nov 18 1997 +!ipk last updated June 24 1996 +! +!ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +! + SUBROUTINE ELTS + +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 ANS,ANSW(0:9) + DATA ANSW/'s','j','f','g','t','i','h','z','r','q'/ +! +! Draw box around selections +! + 2 CONTINUE + NHTP=6 + NMESS=0 + NBRR=0 + CALL HEDR +! +! Get answer +! + 3 call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(ANS .EQ. 'c') THEN + I=IBOX-1 + if(i .lt. 0) go to 3 + ANS=ANSW(I) + ENDIF +! + IF(ANS .EQ. 's') THEN + CALL SELECT + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'j') THEN + CALL MKELEM + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'd') THEN + CALL DELEL + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'f') THEN + CALL FINDEL + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'g') THEN + CALL GEL + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 't') THEN + CALL MATTYP + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'i') THEN +!ipk aug02 + CALL FILM(0) + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'h') THEN + CALL HELPS(2) + IF(IRMAIN .EQ. 1) RETURN + ELSEIF (ANS .EQ. 'q') THEN + RETURN + ELSE + GO TO 3 + ENDIF + GO TO 2 + END +! +!**************************************************************** +! + SUBROUTINE MATTYP +! + USE BLK1MOD + SAVE +! INCLUDE 'BLK1.COM' +! +!ipk feb97 CHARACTER*1 IFLAG +! + CHARACTER*1 IFLAG,ANSW(10) + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ +! +! +! Assign new material type +! +! +! + data itime/0/ + + if(itime .eq. 0) then + mat=1 + itime=1 + endif + ht=0.2 +!ipk feb97 + 4 CONTINUE + NHTP=0 + NBRR=4 +!ipk feb97 NBRR=0 + NMESS=45 + CALL HEDR + NMESS=2 + XPRT=3.2 +! READ(*,*) MAT +! +! Write out current material types +! + IF(NEFL .GT. 0) GO TO 100 +!ipk feb97 4 HT = .20 + HT = .15 + DO 10 J=1,NE + IF (IMAT(J) .GT. 0 .AND. IMAT(J) .LT. 901) THEN + IF(IESKP(J) .EQ. 0) THEN + IF(IQSW(1) .EQ. 1 .OR. IQSW(2) .EQ. 1) FPN = IMAT(J) + IF(IQSW(1) .EQ. 2 .OR. IQSW(2) .EQ. 2) FPN = IGRPSER(J) + X = XC(J) +!ipk jul02 Y = YC(J) - .11 + Y = YC(J) + .01 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.5) THEN + CALL NUMBR(X,Y,HT,FPN,0.0,-1) + ENDIF + ENDIF + ENDIF + 10 END DO + CALL GETINT(MAT) + + 5 CONTINUE + IBOX=1 + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + XPRT=XPRT+0.5 + IF(XPRT .GT. 9.6) XPRT=0. + FPN= IELEM + CALL NUMBR(XPRT,7.20,0.18,FPN,0.0,-1) +!ipk feb97 new setup +! + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF +! + IF(IFLAG .EQ. 'q') THEN + RETURN + ELSEIF(IFLAG .EQ. 'e' .OR. IFLAG .EQ. 'n') THEN +!ipk nov97 add (1) + CALL PLOTOT(1) + GO TO 4 + ENDIF + IF(IQSW(1) .EQ. 1 .OR. IQSW(2) .EQ. 1) IMAT(IELEM) = MAT + IF(IQSW(1) .EQ. 2 .OR. IQSW(2) .EQ. 2) IGRPSER(IELEM) = MAT + FPN = MAT + X = XC(IELEM) + Y = YC(IELEM) + .01 + CALL NUMBR(X,Y,0.15,FPN,0.0,-1) +! +!ipk feb97 ELSEIF(IFLAG .EQ. 'q') THEN +!ipkfeb94 CALL WRTOUT(0) +!ipk feb97 RETURN +! +!ipk feb97 ELSE +!ipk feb97 WRITE(*,*) CHAR(7),CHAR(7) +!ipk feb97 ENDIF +! + GOTO 5 +! +! Process list from prior selection +! + 100 CONTINUE + DO 150 K=1,NEFL + J=NEFLAG(K) + IMAT(J)=MAT + 150 END DO + NEFL=0 + RETURN + END +! + SUBROUTINE FINDEL +! + USE BLK1MOD + SAVE NELSE +! INCLUDE 'BLK1.COM' +! +! Read desired element number +! + data itime/0/ + if(itime .eq. 0) then + itime=1 + nelse=0 + endif + 2 CONTINUE + NHTPSAV=NHTP + NMESSAV=NMESS + NBRRSAV=NBRR + NHTP=0 + NBRR=0 + NMESS=3 + CALL HEDR + NMESS=3 + CALL GETINT(NELSE) +! READ(*,*) NELSE +! +! Obtain location of centroid +! +!ipkdec93 IF(IMAT(NELSE) .EQ. 0) GO TO 2 + IF(IMAT(NELSE) .EQ. 0) RETURN + DO 4 I=1,NP + IF(CORD(I,1) .GT. VOID) THEN + INSKP(I)=0 + ENDIF + 4 END DO + DO 5 I=1,NE + IF(IMAT(I) .GT. 0) THEN + IESKP(I)=0 + ENDIF + 5 END DO + NCN=NCORN(NELSE) + XX=0. + YY=0. + DO 150 K=1,NCN,2 + XX=XX+CORD(NOP(NELSE,K),1) + YY=YY+CORD(NOP(NELSE,K),2) + 150 END DO + XP=XX/FLOAT((NCN+1)/2) + YP=YY/FLOAT((NCN+1)/2) +! +! Make it center of screen and redraw +! + XMIN=XP-5.0*PSCALE + YMIN=YP-3.5*PSCALE +! CALL PLOTS(0) +!ipk nov97 add (1) + CALL PLOTOT(1) + HT=0.15 + FPN=NELSE + CALL RRED + CALL NUMBR(5.,3.5,HT,FPN,0.0,-1) + CALL RBLUE + NHTP=NHTPSAV + NMESS=NMESSAV + NBRR=NBRRSAV + CALL HEDR + RETURN + END +! + SUBROUTINE DELEL +! +! Routine to define element for deleting +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 IFLAG + IF(NEFL .GT. 0) GO TO 150 + 100 CONTINUE +! +! Check out mouse +! + IBOX=0 + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! +! Go and start again if quit called +! + IF(IFLAG .EQ. 'q') RETURN + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL DELTEL(IELEM) + GO TO 100 +! +! Call routine to delete elements in list +! + + 150 CONTINUE + IECHG=0 +!IPK MAY03 + ICHG=0 + DO 200 K=1,NEFL + J=NEFLAG(K) + CALL DELTEL(J) + 200 END DO + NEFL=0 + RETURN + END +! + SUBROUTINE DELTEL(J) +! +! Routine to delete a given element +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + IMAT(J)=0 + XC(J)=VOID + YC(J)=VOID + IF(J .LT. NELAST) NELAST=J + DO 170 KK=1,8 + NOP(J,KK)=0 + 170 END DO + IESKP(J)=1 + NCORN(J)=0 + JJ=0 +!IPK FEB08 TEST FOR LOWERING NE + IF(J .EQ. NE) THEN + DO J=NE,1,-1 + IF(IMAT(J) .NE. 0) THEN + JJ=J + GO TO 200 + ENDIF + ENDDO + 200 NE=JJ + ENDIF + RETURN + END +! + SUBROUTINE SELECT +! +! Routine to select elements +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 ANSW(10) + CHARACTER*1 IFLAG + DATA ANSW/'d','e','n','a','g','t','h','z','r','q'/ + data itime/0/ + + if(itime .eq. 0) then + ielem=1 + itime=1 + endif + +! +! Draw box around selections +! + + 2 CONTINUE +!IPK MAY94 DROP THIS PLOTTING +! CALL PLOTOT + NEFL=0 + 95 NHTP=7 + NMESS=0 + NBRR=0 + CALL HEDR + 100 CONTINUE +! +! Check out mouse +! + IBOX=1 + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! +! Return if quit called +! + IF(IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ELSEIF(IFLAG .EQ. 'c') THEN + GO TO 120 + ENDIF +! +! Check for reading number +! + IF(IFLAG .EQ. 'n') THEN + NHTP=0 + NMESS=45 + CALL HEDR + NMESS=20 + CALL GETINT(IELEM) + NEFL=NEFL+1 + NEFLAG(NEFL)=IELEM + CALL FILLEM(IELEM) + GO TO 95 +! +! Check for selecting all elements +! + ELSEIF(IFLAG .EQ. 'a') THEN + DO I=1,NE + IF(IMAT(I) .GT. 0) THEN + IF(IMAT(I) .LT. 901 .or. imat(i) .gt. 903) THEN + NEFL=NEFL+1 + NEFLAG(NEFL)=I + CALL FILLEM(I) + ENDIF + ENDIF + ENDDO + GO TO 95 +! +! Check for only rectangles +! + ELSEIF(IFLAG .EQ. 'g') THEN + DO I=1,NE + IF(NCORN(I) .EQ. 8) THEN + NEFL=NEFL+1 + NEFLAG(NEFL)=I + CALL FILLEM(I) + ENDIF + ENDDO + GO TO 95 +! +! Check for only triangles +! + ELSEIF(IFLAG .EQ. 't') THEN + DO I=1,NE + IF(NCORN(I) .EQ. 6) THEN + NEFL=NEFL+1 + NEFLAG(NEFL)=I + CALL FILLEM(I) + ENDIF + ENDDO + GO TO 95 +! +! Check for only line elements +! + ELSEIF(IFLAG .EQ. 'l') THEN + DO I=1,NE + IF((NCORN(I) .LT. 6 .and. ncorn(i) .gt. 2) .and. & + (imat(i) .lt. 901 .or. imat(i) .gt. 903)) THEN + NEFL=NEFL+1 + NEFLAG(NEFL)=I + CALL FILLEM(I) + xa=(cord(nop(i,1),1)+cord(nop(i,3),1))/2. + ya=(cord(nop(i,1),2)+cord(nop(i,3),2))/2. + fpn=i + CALL NUMBR(xa,ya,0.18,FPN,0.0,-1) + ENDIF + ENDDO + GO TO 95 +! +! Check for delete option +! + ELSEIF(IFLAG .EQ. 'd') THEN + CALL DELEL +! +! Check for refine option +! + ELSEIF(IFLAG .EQ. 'e') THEN + CALL REFB + IF(IRMAIN .EQ. 1) RETURN +! +! Check for help +! + ELSEIF (IFLAG .EQ. 'h') THEN + CALL HELPS(6) + IF(IRMAIN .EQ. 1) RETURN +! + ELSEIF(IFLAG .EQ. 'U') THEN + NEFLAG(NEFL)=0 + NEFL=NEFL-1 + CALL PLOTOT(1) + CALL HEDR + DO IELEM=1,NEFL + CALL FILLEM(NEFLAG(IELEM)) + ENDDO + GO TO 100 + ELSEIF(IFLAG .EQ. 'q') THEN + RETURN + ENDIF + GO TO 2 + 120 NEFL=NEFL+1 + NEFLAG(NEFL)=IELEM + CALL FILLEM(IELEM) + IF(NCORN(ielem) .LT. 6 .and. ncorn(ielem) .gt. 2) THEN + + xa=(cord(nop(ielem,1),1)+cord(nop(ielem,3),1))/2. + ya=(cord(nop(ielem,1),2)+cord(nop(ielem,3),2))/2. + fpn=ielem + CALL NUMBR(xa,ya,0.18,FPN,0.0,-1) + endif + GO TO 100 + END +! +!ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc +! + SUBROUTINE MKELEM + +! + USE BLK1MOD + INCLUDE 'BFILES.I90' +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 IFLAG + CHARACTER*32 IJNK + CHARACTER*23 ELTH +!ipk jan98 + CHARACTER*80 LIND + CHARACTER*60 MESSAGE,MESSAG1 +!ipk jun96 add messag2 + CHARACTER*26 MESSAG2 + DATA MESSAG2/' Press return to continue'/ +!ipkjul94 add a line + MEL=MAXE +! +! Form element nodal list by clicking on nodes with cursor +! + 3 CONTINUE + CALL GETELM(J) + 5 CONTINUE + IECHG=0 +!IPK MAY03 + ICHG=0 + WRITE(ELTH,5000) j + 5000 FORMAT('Processing element',i5) + CALL CLRBOX +!ipk jun96 clear a strip + call clrstp(7.2,7.5) + CALL SYMBL(0.,7.70,0.18,ELTH,0.,23) + XPRT=3.5 + + 6 DO 10 K=1,10,2 +! +! Find node nearest to cursor +! + 7 CONTINUE +!ipk sep94 reset ibox + IBOX=1 +!ipk sep49 add call to hedr + nhtp=0 +!ipk jun96 nmess=22 + nmess=15 + nbrr=3 + call hedr + write(155,*) width(1),width(2),width(3) + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! +! IF(IFLAG .EQ. 'z') THEN +! DO 62 I=1,NP +! IF(CORD(I,1) .GT. VOID) THEN +! INSKP(I)=0 +! ENDIF +! 62 CONTINUE +! DO 63 I=1,NE +! IF(IMAT(I) .GT. 0) THEN +! IESKP(I)=0 +! ENDIF +! 63 CONTINUE + CALL RBLUE + if(inode .lt. 1) return + CALL PLTNOD(INODE,1) + XPRT=XPRT+0.5 + IF(XPRT .GT. 9.6) then + XPRT=0. +!ipk jun96 clear a strip + call clrstp(7.2,7.5) + endif + FPN= INODE + CALL RBLUE + CALL NUMBR(XPRT,7.30,0.18,FPN,0.0,-1) +! + IF(K .EQ. 9) THEN + IF(IFLAG .EQ. 'm') THEN + NOP(J,K-1) = INODE + WD(INODE) = 0. +! +! Five node element +! + ELSEIF (IFLAG .EQ. 'f') THEN + NOP(J,4)=NOP(J,5) + NOP(J,5)=NOP(J,7) + NOP(J,7) = 0 + NOP(J,8) = 0 + ENDIF + GO TO 10 + ENDIF + IF (IFLAG .NE. 'r') THEN + NOP(J,K) = 0 + NOP(J,K+1) = 0 + ENDIF +! +! Corner node +! + IF (IFLAG .EQ. 'c') THEN + NOP(J,K) = INODE +! +! Midside node +! + ELSEIF (IFLAG .EQ. 'm') THEN + NOP(J,K-1) = INODE + GOTO 7 +! +! Triangular element +! + ELSEIF (IFLAG .EQ. 't' .AND. K .EQ. 7) THEN + NOP(J,7) = 0 + NOP(J,8) = 0 + GOTO 20 +! +! 1-d element +! + ELSEIF (IFLAG .EQ. 'l' .AND. K .EQ. 5) THEN + NOP(J,4) = 0 + NOP(J,5) = 0 + NOP(J,6) = 0 + NOP(J,7) = 0 + NOP(J,8) = 0 + GOTO 20 +! +! Junction element +! + ELSEIF (IFLAG .EQ. 'j' .AND. K .EQ. 3) THEN + INODE= NOP(J,1) + NOP(J,1)=0 + CALL JUNGEN(J,INODE,IER) + IF(IER .EQ. 1) THEN +! +! Redo if error +! +!ipk jan98 WRITE(*,*) CHAR(7),CHAR(7) + GOTO 7 + ENDIF + GO TO 20 +! +! Exit input +! + ELSEIF(IFLAG .EQ. 'q') THEN + NE=NE-1 +!ipkfeb94 CALL WRTOUT(0) + IRDONE=0 + RETURN +! +! Redo if error +! + ELSE +!ipk jan98 WRITE(*,*) CHAR(7),CHAR(7) + GOTO 6 + ENDIF + 10 END DO +! + 20 IF (IMAT(J) .EQ. 0) IMAT(J) = 1 +! +! rearrange if nop(j,4) .ne. 0 separate it from +! a transition element +! + IF(NOP(J,4) .NE. 0 .AND. NOP(J,6) .EQ. 0) THEN + IF(IFLAG .NE. 'f' .AND. IMAT(J) .LT. 901) THEN + + ITMP1 = NOP(J,1) + ITMP2 = NOP(J,2) + DO 30 KK=1,6 + NOP(J,KK) = NOP(J,KK+2) + 30 CONTINUE + IF(NOP(J,5) .EQ. 0) THEN + NOP(J,5)=ITMP1 + NOP(J,6)=ITMP2 + ELSE + NOP(J,7)=ITMP1 + NOP(J,8)=ITMP2 + ENDIF + ENDIF + ENDIF + NCN = 2 + IF (NOP(J,3) .NE. 0) NCN = 3 + IF (NOP(J,4) .NE. 0) NCN = 4 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .NE. 0) NCN = 5 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .EQ. 0) NCN = 6 + IF (NOP(J,6) .NE. 0) NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 +! +! Check to see if duplicate node numbers have been defined +! + DO 40 KK=1,NCN-1 + IF(NOP(J,KK) .EQ. 0) GO TO 40 + DO 37 LL=KK+1,NCN + IF(NOP(J,KK) .EQ. NOP(J,LL)) THEN + WRITE(MESSAGE,6000) J + 6000 FORMAT(' **ERROR** NODES AT ELEMENT NUMBER',I5,' ARE DUPLICATED RE& + &TRY') + WRITE(MESSAG1,6001) (NOP(J,II),II=1,8) + 6001 FORMAT(' NODE LIST FOLLOWS ',8I5) + CALL CLRBOX + CALL SYMBL(0.,7.75,0.18,MESSAGE,0.,60) + CALL SYMBL(0.,7.55,0.18,MESSAG1,0.,60) +!IPK JUN96 + CALL SYMBL(0.,7.35,0.18,MESSAG2,0.,25) + call keybrd(k) +!cc read(*,'(A)') ijnk +!ipk jun96 change transfer location +! GO TO 6 + go to 5 + ENDIF + 37 CONTINUE + 40 END DO + NCORN(J) = NCN + IESKP(J) = 0 + NE = MAX(J,NE) +!IPK JAN98 + IERC=0 + CALL PLTELM(J,IERC) +! +! WRITE(IOT,'(10I5)') J, (NOP(J,K),K=1,8), IMAT(J) +! +! Return if dimensions exceeded +! +!ipk jul94 IF (J .GE. MAXE) THEN + IF (J .GE. MEL) THEN + CALL WRTOUT(0) + CALL CLSCRN +!ipk jan98 CALL SETD(24) +!ipk jan98 WRITE(*,*) ' Element number exceeds MAXE. Press retur + WRITE(lind,*) & + & ' Element number exceeds MAXE. Press return to exit' + call symbl & + & (1.1,4.0,0.20,LIND,0.0,80) +!ipk jan98 READ(*,'(A)') IJNK + ndig=1 + CALL GTCHARX(IJNK,NDIG,5.0,4.0) + RETURN + ENDIF +! +! Go do another element +! + GOTO 3 + +! + END diff --git a/src/src83e/ELVSET.F90 b/src/src83e/ELVSET.F90 new file mode 100644 index 0000000..5dd39c6 --- /dev/null +++ b/src/src83e/ELVSET.F90 @@ -0,0 +1,425 @@ + SUBROUTINE SETRNG(XNEARS,NMAP) + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! +! Establish size for range +! + JS=1 + K=0 + KPT=0 + VDX=-1.E9 + write(90,*) 'maxpts', maxpts + DO 120 J=1,MAXPTS+1 +! +! Determine how long each line is +! + MLEN=J-JS +! write(90,*) 'mlen',j,js,mlen,xmap(j),nmap,vdx +! write(90,*) j,js,mlen,cmap(j,1),xmap(j),vdx,maxpts + IF(XMAP(J) .LT. VDX) THEN +!IPK NOV05 IF(CMAP(J,1) .LT. VDX) THEN +! +! Now check it. +! + K=K+1 + IF(MLEN .GT. 1) THEN +! LTP=LINTYP(K) + DO 110 M=1,MLEN +! write(191,*) j,m,js+m-1,nmap + IF(VAL(JS+M-1) .GT. -9000.) THEN + KPT=KPT+1 + ENDIF + 110 CONTINUE + ENDIF + NMAP=J + IF(MLEN .EQ. 0) GO TO 130 + JS=J+1 + go to 120 + ENDIF + cxcur=xmap(j) + cycur=ymap(j) + 120 END DO + 130 CONTINUE + write(90,*) 'number of points forming map',nmap + write(90,*) 'last map coordinates',cxcur,cycur +! +! Estimate areal density to get 100 points +! + ADEN=AMAP*40./(FLOAT(KPT)*TXSCAL**2) +! +! Find square coverage +! + XNEARS=SQRT(ADEN) + xnearo=xnears + xnearf=xnears +!ipk sep97 xnearo forms the current value xnearp is limiting plus side + XNEARP=XNEARS +! xnears=2.0 + WRITE(90,*) 'Radius for nearby points',XNEARS + RETURN + END + + SUBROUTINE SETELV(XNEARS,NMAP,M,ISWT) + + USE WINTERACTER + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +! common /mapc/imap(maxpl),NCRS(MAXPL) +! dimension ccmap(maxpl) + + DIMENSION LISTM(1000),listt(1600,4),nlf(4),icomp(4),xnear(4) + dimension xnearkp(4) + + + DATA ITIME/0/ + + IF(.NOT. ALLOCATED(CCMAP)) THEN + ALLOCATE (CCMAP(MAXPL)) + ENDIF + call WcursorShape(CurHourGlass) + + +!ipk feb94 change logic to allow 4 passes and check angles +! +! initialize range +! + ict=0 +!ipk sep97 xnears=xnearo + xnearo=xnears + xnearp=xnears + xnearf=xnears + write(90,*) 'working node',m + do nang=1,4 + XNEAR(nang)=XNEARS + xnearkp(nang)=0. + icomp(nang)=0 + enddo +! +! set imap to zero to start or -1 if no value +! +!IPK MAY97 INITIALIZE COUNTER + ntime=0 + 220 continue + + do n=1,nmap + if(cmap(n,1) .lt. vdx) then + imap(n)=-1 + elseif(val(n) .lt. -9000.) then + imap(n)=-1 + else + imap(n)=0 + endif + enddo +! +!ipk sep97 Sortlist of map points in increasing x except for single poin +! + IF(ielvsw .EQ. 0 .AND. ISWT .NE. 1) THEN +!ipk mar99 + do n=1,nmap + ccmap(n)=cmap(n,1) + enddo + CALL SORTMAP(CCMAP,NCRS,NMAP,IMAP) + ielvsw=1 +! DO N=1,NMAP +! WRITE(90,*) N,CMAP(NCRS(N),1),IMAP(NCRS(N)) +! ENDDO + ENDIF +!ipk sep97 end addition +! +! initialize list and completeness test +! + do nang=1,4 + icomp(nang)=0 + do n=1,1600 + listt(n,nang)=0 + enddo + enddo +! +! start processing +! + 280 continue +! +! check for completeness intialize counter +! + ict=0 + do nang=1,4 + if(icomp(nang) .eq. 0) then + nlf(nang)=0 + else + ict=ict+1 + endif + enddo +! +! if ict = 4 we are done +! + if(ict .lt. 4) then +! +! loop through map points +! +!ipk sep97 change loop + do nang=1,4 + nlf(nang)=0 + icomp(nang)=0 + enddo + IFND=0 + NN=0 + 285 NN=NN+1 + IF(NN .GT. NMAP) GO TO 305 +! DO 300 NNN=1,NMAP + N=NN + if(val(n) .lt. -9990.) go to 285 + IF(ISWT .EQ. 1) GO TO 297 + IF(IFND .EQ. 1) GO TO 295 + IF(XNEARO .LT. XNEARF) THEN + IFND=1 + GO TO 294 + ENDIF + +!IPK SEP97 START SEARCH + NLOCA=NMAP/2 + NSTEPS=NMAP/2 +290 CONTINUE + +! WRITE(90,*) 'elvset-164',NLOCA +! write(90,*) NSTEPS,NCRS(NLOCA) +! WRITE(90,*) CMAP(NCRS(NLOCA),1),CORD(M,1),XNEAR(1) + NCUR=NCRS(NLOCA) +! IF(CMAP(NCUR,1) .GT. 1.E34) THEN +! WE ARE AOUT OF RANGE +! GO TO +! ENDIF + IF(CMAP(NCUR,1)+XNEARO .LT. CORD(M,1).and. val(ncur) .gt. -9000.) THEN +! still below increase nloca + NSTEPS=NSTEPS/2 + IF(NSTEPS .EQ. 0) THEN +! we are there + NLOCA=NLOCA-1 + IFND=1 + GO TO 293 + ENDIF + NLOCA=NLOCA+NSTEPS + GO TO 290 + ELSE +! too great decrease nloca + NSTEPS=(NSTEPS+1)/2 + NLOCA=NLOCA-NSTEPS + IF(NLOCA .LE. 0) THEN + NLOCA=0 + IFND=1 + GO TO 293 + ENDIF + GO TO 290 + ENDIF + 293 NLOCS=NLOCA +! WRITE(90,*) 'elvset-201',NLOCA,NSTEPS,NCRS(NLOCA) +! WRITE(90,*) CMAP(NCRS(NLOCA),1),CORD(M,1),XNEAR(1) + GO TO 295 + 294 NLOCA=NLOCS + 295 CONTINUE + NLOCA=NLOCA+1 + if(nloca .gt. nmap) go to 305 + NCUR=NCRS(NLOCA) +! +! test to see if we are past area +! + if(ncur .eq. 0) go to 305 + IF(CMAP(NCUR,1)-XNEARP .GT. CORD(M,1)) GO TO 305 + if(val(ncur) .lt. -9000.) go to 295 + N=NCUR + 297 CONTINUE + d1=cmap(n,1)-cord(m,1) + d2=cmap(n,2)-cord(m,2) +!ipk may97 IF(ABS(D1) .LT. XNEAR(1)) THEN +!ipk may97 IF(ABS(D2) .LT. XNEAR(1)) THEN + IF(ABS(D1) .LT. max(XNEARO,xnearp)) THEN + IF(ABS(D2) .LT. max(XNEARO,xnearp)) THEN + if(d1 .lt. 0) then + if(d2 .lt. 0) then + nang=3 + if(abs(d1) .lt. xnear(NANG) .and. & + & abs(d2) .lt. xnear(NANG)) then + imap(n)=3 + else + imap(n)=-1 + go to 300 + endif + else + nang=2 + if(abs(d1) .lt. xnear(NANG) .and. & + & abs(d2) .lt. xnear(NANG)) then + imap(n)=2 + else + imap(n)=-1 + go to 300 + endif + endif + elseif(d2 .lt. 0) then + nang=4 + if(abs(d1) .lt. xnear(NANG) .and. & + & abs(d2) .lt. xnear(NANG)) then + imap(n)=4 + else + imap(n)=-1 + go to 300 + endif + else + nang=1 + if(abs(d1) .lt. xnear(NANG) .and. & + & abs(d2) .lt. xnear(NANG)) then + imap(n)=1 + else + imap(n)=-1 + go to 300 + endif + endif +! +! set to skip out if out of range +! + else + imap(n)=-1 + go to 300 + endif + else + imap(n)=-1 + go to 300 + endif +! +!IPK SEP97 END MAJOR REWRITE +! +! save value if total less then 50 +! + NLF(NANG)=NLF(NANG)+1 + IF(NLF(NANG) .LT. 101) THEN + LISTT(NLF(NANG),NANG)=N + ENDIF + 300 CONTINUE + GO TO 285 + 305 CONTINUE +! +! now reset range if we need to +! + ictz=0 +! write(90,*) ' ' +! write(90,*) ntime +! write(90,*) 'nlf',nlf +! write(90,*) 'xnear',xnear + do nang=1,4 + if(nlf(nang) .gt. 150) then +! rat=sqrt((45.+ntime*3.)/nlf(nang)) +! if(rat .lt. 0.2) rat=0.2 + rat=sqrt(0.1+0.06*ntime) + xnearkp(nang)=xnear(nang) + xnear(nang)=xnear(nang)*rat +!ipk may97 elseif(nlf(nang) .eq. 0) then + elseif(nlf(nang) .lt. 2) then +!ipk may97 if(xnear(nang) .eq. xnears) then + ictz=ictz+1 +!ipk may97 else +!ipk may97 icomp(nang)=1 +!ipk may97 endif + else + icomp(nang)=1 + endif + enddo + xnearf=xnearo +! write(90,*) 'ntime,ictz,xnear',ntime,ictz +! write(90,*) 'icomp',icomp +! write(90,*) 'xneara',xnear + if(ictz .gt. 0) then + do nang=1,4 + if(nlf(nang) .lt. 2) then + if(xnearkp(nang) .gt. 0.) then + xnear(nang)=xnearkp(nang) + else + xnear(nang)=xnear(nang)*1.5 + endif + if(nang .eq. 2 .or. nang .eq. 3) then + if(xnear(nang) .gt. xnearo) xnearo=xnear(nang) + endif + if(nang .eq. 1 .or. nang .eq. 4) then + if(xnear(nang) .gt. xnearp) xnearp=xnear(nang) + endif + endif +!ipk may97 xnears=xnears*2. +! write(90,*) 'nang,xnear',nang,xnear(nang) +! write(90,*) 'xnearo,xnearp',xnearo,xnearp + + enddo +!ipk sep97 xnears=xnears*2. + ntime=ntime+1 + if(ntime .lt. 12) go to 220 +! go to 220 +! endif + endif +! +! go back and try again +! +!ipk may97 go to 280 + ntime=ntime+1 + if(ntime .lt. 16) go to 280 + endif +! +! finished now compact list +! + do nang=1,4 +! write(90,*)'nang',nang,nlf(nang),xnear(nang) + enddo + nlg=0 + do nang=1,4 + nlim=nlf(nang) +!ipksep97 if(nlim .eq. 0) then +!ipksep97 nlim=50 +!ipk sep97 endif +!ipk sep97 chnage limit and act only if nlim > 0 +! write(90,*) 'nlim',nlim + if(nlim .gt. 1600) nlim=1600 + if(nlim .gt. 0) then + do nlgg=1,nlim + if(listt(nlgg,nang) .gt. 0) then + if(nlg .eq. 1000) nlg=999 + nlg=nlg+1 + listm(nlg)=listt(nlgg,nang) + endif + enddo + endif + enddo +! write(90,*) nlg +! write(90,*) m,(listm(n),n=1,nlg),xnear +!ipk feb94 end changes +! do n=1,nmap +! write(90,*) n,cmap(n,1),cmap(n,2),val(n) +! enddo +! write(90,*) 'LIST MAP POINTS NEAR ',M,CORD(M,1),CORD(M,2) +! DO N=1,NLG +! WRITE(90,*) listm(n),CMAP(LISTM(N),1),CMAP(LISTM(N),2),val(listm(n)) +! ENDDO +! read(*,*) n234 + +!IPK JUL98 CALL GRIDIN(M,SOLN,LISTM,NLG) + XXX=CORD(M,1) + YYY=CORD(M,2) + CALL GRIDIN(XXX,YYY,SOLN,LISTM,NLG) + IF(IRMAIN .EQ. 1) then + call WcursorShape(CurArrow) + RETURN + endif + WD(M)=SOLN + FPN = WD(M)*10. + X = CORD(M,1) + Y = CORD(M,2) - .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.5) THEN + CALL RRED + CALL NUMBR(X,Y,0.1,FPN,0.0,-1) + ENDIF +! call WcursorShape(0) + call WcursorShape(CurArrow) + RETURN + END \ No newline at end of file diff --git a/src/src83e/EVENT.F90 b/src/src83e/EVENT.F90 new file mode 100644 index 0000000..2eda33a --- /dev/null +++ b/src/src83e/EVENT.F90 @@ -0,0 +1,2085 @@ +!IPK LAST UPDATE SEP 23 2015 ADD TESTING FOR status + SUBROUTINE gim_an_event(ix,iy,iflag) + + USE WINTERACTER + + include 'd.inc' + + COMMON /TMPLIST/ ilisttmp(100),INREORD + +! THIS BLOCK IS IN BLK1.F90 + + COMMON /VIEWS/ HANG,VANG,VRTSCAL,HANGOLD,VANGOLD,VRTORIG,IASPCT + + + INTEGER :: NP,NE,NHTP,NMESS,NBRR,IPSW,IRMAIN,ISCRN,icolon,nhtpsv,nmessv,nbrrsv,ntempin,IPW2 + + +!ipk jan01 Expand IPSW to 10 + CHARACTER*6 DESCR + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + COMMON /HEDS1/ NWINDWS,IWNDWS(10),ISCRNS(10),DESCR(10),ICRSR(10) + + REAL HSIZE + COMMON /SSIZE/ HSIZE + + REAL :: RSCLX,RSCLY,HRAD,VRAD + + real*8 xms,yms + INTEGER :: MOUSEX, MOUSEY, MBUTTON, ITIME, IWINDOW,MENUS + INTEGER :: IMP,IIN,IOT,IOT1,impf,IBAKON,N,NDM,IDRAG,IYES,ITRIAN,INFO(3) + + LOGICAL :: OPENED,EXISTS + CHARACTER(LEN=255) :: FNAME,FNAMGE,FNAMRM,FNAMEB + CHARACTER(LEN=3) :: SUB,SUB1 + CHARACTER(LEN=4) :: SUB2 + character(len=43) :: zoomh + CHARACTER(LEN=50) :: STBAR + character(len=1000) :: header + CHARACTER(len=10) :: DATEC,TIMEC,ZONEC + INTEGER :: DTI(8) + CHARACTER(LEN=256) :: FILTER + CHARACTER(LEN=72) :: CRSTIT + REAL :: XX1,XX2,XX3,XX4,XX5,XX6 + + COMMON /UNITS/IOT,IOT1 + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + TYPE(WIN_MESSAGE) :: MESSAGE + TYPE (WIN_FONT) :: FONT + +! Define a common block with background file names + + INCLUDE 'BFILES.I90' + + DATA IBAKON/1/ + DATA rsclx,rscly/100.0,100./,IDOWN/0/ + +! +! Interacter graphics input routine +! Shows the mouse, collects mouse location and character +! on the mouse-click or on a keystroke + + + character*1 iflag + + CALL WMenuSetState(ID_ITEM11,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM12,ItemEnabled,0) + + nhtpsv=nhtp + nmessv=nmess + nbrrsv=nbrr + 100 continue + DO I=1,255 + FNAME(I:I)=' ' + ENDDO + MENUS=0 + idrag=0 + 101 continue + CALL WMessage(ITYPE, MESSAGE) + SELECT CASE (ITYPE) + CASE (KeyDown) ! Key pressed + KEY = MESSAGE%VALUE1 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + XM=MESSAGE%GX + YM=MESSAGE%GY + IFLAG=CHAR(KEY) +! WRITE(90,*) 'KEY PRESSED',KEY +! WRITE(90,'(A)') 'KEY PRESSED',IFLAG,menus + CASE (MenuSelect) ! Menu item selected + INREORD=0 + DO J=1,100 + ilisttmp (j)=0 + ENDDO + SELECT CASE (MESSAGE%VALUE1) + CASE (ID_ITEM11) ! New option + IMP=0 + IIN=0 + CASE (ID_ITEM12) ! Open option + IMP=0 + IIN=0 + CALL IgrUnits(0.,0.,HSIZE,8.0) + + CALL WSelectFile(ID_STRING1,PromptOn+DirChange,FNAME,'Load Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'mpb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='unformatted',action='read') + ELSEIF(SUB .EQ. 'mbb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='binary',action='read') + ENDIF + ENDIF + + FILTER ="Network Files|*.rm1;*.geo;*.gfg;*.bin;*.ele|Rm1 file -- *.rm1|*.rm1|Geo file -- *.geo|*.geo|GFGEN file -- *.gfg|*.gfg|GFGEN bin file -- *.bin|*.bin|Rst file -- *.rst|*.rst|TRIANG file -- *.ele|*.ele|MESH2D file -- *.2dm|*.2dm|All files|*.*|" + CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) + + ITRIAN=0 + IF(SUB .EQ. 'rm1') then + IIN = 10 + OPEN(10,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'ele') then + IIN=10 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=1 + IGFG=0 + FNAMKEP=FNAME + ELSEIF(SUB .EQ. 'rst') then + IIN=11 +! OPEN(IIN ,FILE=FNAME,STATUS='OLD',access='transparent') + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') +! OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='BINARY') + ELSE + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',form='binary') + ENDIF + ENDIF + + CASE (ID_NMAP) + CALL WSelectFile(ID_STRING1,PromptOn,FNAME,'Load Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'shp') then + IMP=113 + OPEN(113,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + SUB='DBF' + CALL ADDSUB(FNAME,SUB) + OPEN(114,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'mpb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='unformatted',action='read') + ELSEIF(SUB .EQ. 'mbb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='binary',action='read') + ENDIF + ENDIF + CALL RDMAP(2,IMP,0,0) + CALL PLOTOT(0) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + GO TO 100 + +!IPK MAY03 LOAD ADDITIONAL FILES + + CASE (ID_LOADRM1) + +! Load additional RM1 files + + FILTER ="Network Files|*.rm1;*.geo;*.gfg;*.bin;*.ele|Rm1 file -- *.rm1|*.rm1|Geo file -- *.geo|*.geo|Gfgen file -- *.gfg|*.gfg|GFGEN bin file -- *.bin|*.bin|Rst file -- *.rst|*.rst|TRIANG file -- *.ele|*.ele|All files|*.*|" + CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + GO TO 200 + ELSE + GO TO 250 + ENDIF + 200 CONTINUE + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) + + ITRIAN=0 + IF(SUB .EQ. 'geo') then + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',form='binary',ACTION='READ') + FNAMKEP=FNAME + IGFG=0 + ELSEIF(SUB .EQ. 'gfg') then + IIN = 10 + IGFG=1 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ELSEIF(SUB .EQ. '2dm') then + IIN = 10 + IGFG=3 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ELSEIF(SUB .EQ. 'bin') then + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') + IGFG=2 + ELSEIF(SUB .EQ. 'rst') then + IIN=11 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') + IGFG=0 + ELSEIF(SUB .EQ. 'ele') then + IIN=10 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=1 + IGFG=0 + FNAMKEP=FNAME + ELSE + IIN = 10 + IGFG=0 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ENDIF + ITOTFIL=ITOTFIL+1 + FNAMEOUT(ITOTFIL)=FNAME + CALL GETNEWFIL(IIN,IGFG,ITRIAN,0) + + fname=' ' + GO TO 100 + + CASE (ID_CRSF) + +! Load cross-section files + + ICRIN=0 + FILTER ="Cross-Section files -- *.crs|*.crs|All files -- |*.*|" + CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Cross-Section File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + GO TO 210 + ELSE + GO TO 250 + ENDIF + 210 CONTINUE + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + ICRIN = 23 + OPEN(ICRIN,FILE=FNAME,STATUS='OLD',ACTION='READ') + CALL GETCRS(CRSTIT) + + fname=' ' + GO TO 100 + + +! Load group number files + + IGRPIN=0 + FILTER ="Group number files -- *.txt|*.txt|All files -- |*.*|" + CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Group Number File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + GO TO 215 + ELSE + GO TO 250 + ENDIF + 215 CONTINUE + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + IGRP = 28 + OPEN(IGRP,FILE=FNAME,STATUS='OLD',ACTION='READ') + CALL GETGRP + + fname=' ' + GO TO 100 + + CASE (ID_SAVCRS) + ICROUT=24 + INQUIRE(24, OPENED=OPENED) + if(.not. opened) then + Filter='CRS file -- *.crs|*.crs|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Cross Section File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(ICROUT,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + ELSE + GO TO 250 + ENDIF + ENDIF + REWIND ICROUT + CALL WRTCRS(ICROUT,CRSTIT) + fname=' ' + GO TO 100 + + CASE (ID_SAVGP) + IGRPOUT=29 + INQUIRE(29, OPENED=OPENED) + if(.not. opened) then + Filter='TXT file -- *.txt|*.txt|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Group Number File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(IGRPOUT,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + ELSE + GO TO 250 + ENDIF + ENDIF + REWIND IGRP + CALL WRTGP + fname=' ' + GO TO 100 + + CASE (ID_ITEM13) ! Save option +! WRITE(90,*) 'WINTER AT ITEM13' + INQUIRE(20, OPENED=OPENED) + if(.not. opened) then + Filter='Network Files|*.rm1;*.gfg;*.ele|Rm1 file -- *.rm1|*.rm1|gfg file -- *.gfg|*.gfg|TRIANG file -- *.ele|*.ele|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) +! SUB='rm1' +! CALL ADDSUB(FNAME,SUB) + +! WRITE(90,*) 'IN ITEM13',IOT +! WRITE(90,'(A)') FNAME,SUB + IOT = 20 + FNAMRM=FNAME + ITRIANOUT=0 + if(sub .eq. 'rm1') then + igfgsw=0 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') +! +! Check if file cords format to be short or long +! +! + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to save'//& + CHAR(13)//'coordinates in long format?' ,& + 'Coordinate save format') +! +! If answer 'No', use short format +! + IF (WInfoDialog(4) .EQ. 2) then + ntempin=0 + else + ntempin=2 + END IF +! + call wrtout(1) + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + elseif(sub .eq. 'ele') then + igfgsw=0 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + itrianout=1 + call wrtout(1) + DO L=255,1,-1 + IF(FNAME(L:L) .EQ. '.') THEN + FNAME(L+1:L+1)='n' + FNAME(L+2:L+2)='o' + FNAME(L+3:L+3)='d' + FNAME(L+4:L+4)='e' + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + itrianout=2 + call wrtout(1) + GO TO 220 + ENDIF + ENDDO + 220 continue + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + else + igfgsw=1 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + call wrtout(1) + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + endif + ENDIF + if(iactvfil .le. 0) iactvfil=1 + FNAMEOUT(IACTVFIL)=FNAMRM + + else + + CALL GETSUB(FNAMRM,SUB) + + if(sub .eq. 'ele') then + FNAME=FNAMRM + igfgsw=0 + itrianout=1 + call wrtout(1) + DO L=255,1,-1 + IF(FNAME(L:L) .EQ. '.') THEN + FNAME(L+1:L+1)='n' + FNAME(L+2:L+2)='o' + FNAME(L+3:L+3)='d' + FNAME(L+4:L+4)='e' + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + itrianout=2 + call wrtout(1) + GO TO 221 + ENDIF + ENDDO + 221 continue + ELSE + call wrtout(1) + ENDIF + CLOSE (IOT) + fnamrm=FNAMEOUT(IACTVFIL) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + endif + GO TO 100 + + CASE (ID_ITEM14) ! Save option for binary + +! WRITE(90,*) 'WINTER AT ITEM14' + INQUIRE(22, OPENED=OPENED) +! WRITE(90,'(L2)') OPENED + if(.not. opened) then + Filter='Geo file -- *.geo|*.geo|GFGEN file -- *.bin|*.bin|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Network File') +! WRITE(90,'(A)') FNAME + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) +! SUB='geo' +! CALL ADDSUB(FNAME,SUB) + +! WRITE(90,*) 'IN ITEM14',IOT1 +! WRITE(90,'(A)') FNAME,SUB + IOT1=22 + FNAMGE=FNAME + if(sub .eq. 'geo') then + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='binary') + igfgswb=0 + +! add header to binary file + + DO J=11,1000 + HEADER(J:J)=' ' + ENDDO + HEADER(1:10)='RMAGEN ' + CALL DATE_AND_TIME(DATEC,TIMEC,ZONEC,DTI) + HEADER(11:20)=DATEC + HEADER(21:30)=TIMEC + HEADER(31:40)=ZONEC + WRITE(IOT1) HEADER + call wrtout(2) + + CLOSE (IOT1) + OPEN(IOT1 ,FILE=FNAMGE,STATUS='UNKNOWN',form='binary') + else + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='unformatted') + igfgswb=1 + call wrtout(2) + CLOSE (IOT1) + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='unformatted') + endif + ENDIF + else + +! add header to binary file + + DO J=11,1000 + HEADER(J:J)=' ' + ENDDO + HEADER(1:10)='RMAGEN ' + CALL DATE_AND_TIME(DATEC,TIMEC,ZONEC,DTI) + HEADER(11:20)=DATEC + HEADER(21:30)=TIMEC + HEADER(31:40)=ZONEC + WRITE(IOT1) HEADER + call wrtout(2) + CLOSE (IOT1) + OPEN(IOT1 ,FILE=FNAMGE,STATUS='UNKNOWN',form='binary') + endif + FNAMEOUT(IACTVFIL)=FNAMRM + GO TO 100 + + CASE (ID_ITEM18) ! Save As option + FILTER ="Bin Map file -- *.mpb|*.mpb|Bin Map file (no head) -- *.mbb|*.mbb|" + CALL WSelectFile(filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + if(SUB .eq. 'mpb') then + CALL ADDSUB(FNAME,SUB) + impf=93 + OPEN(IMPF ,FILE=fname,STATUS='unknown',form='unformatted') + + call wrtmap(1) + elseif(Sub .eq. 'map') then + impf=94 + OPEN(IMPF ,FILE=fname,STATUS='unknown',form='formatted') + call wrtmap(2) + endif + ENDIF + + go to 100 + + CASE (ID_LAYFL) ! input layer data + + CALL WSelectFile(ID_STRING9,PromptOn+DirChange,FNAME,'Load Layer File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='lay' + CALL ADDSUB(FNAME,SUB) + impf=103 + OPEN(103,FILE=FNAME,STATUS='OLD') + call rdlayer + ENDIF + + go to 100 + + CASE (ID_OUTLAY) ! Save layer data + + call wrtlayer + GO TO 100 + + CASE (ID_ITEM15) ! Save As option + + Filter='Network Files|*.rm1;*.gfg;*.ele|Rm1 file -- *.rm1|*.rm1|GFGEN file -- *.gfg|*.gfg|TRIANG file -- *.ele|*.ele|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) +! SUB='rm1' +! CALL ADDSUB(FNAME,SUB) + FNAMRM=FNAME + IOT = 20 + + if(sub .eq. 'rm1') then + igfgsw=0 + itrianout=0 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + +! +! Check if file cords format to be short or long +! + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to save'//& + CHAR(13)//'coordinates in long format?' ,& + 'Coordinate save format') + +! If answer 'No', use short format + + IF (WInfoDialog(4).EQ.2) then + ntempin=0 + else + ntempin=2 + END IF +! + call wrtout(1) + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + + elseif(sub .eq. 'ele') then + igfgsw=0 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + itrianout=1 + call wrtout(1) + DO L=255,1,-1 + IF(FNAME(L:L) .EQ. '.') THEN + FNAME(L+1:L+1)='n' + FNAME(L+2:L+2)='o' + FNAME(L+3:L+3)='d' + FNAME(L+4:L+4)='e' + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + itrianout=2 + call wrtout(1) + GO TO 225 + ENDIF + ENDDO + 225 continue + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + + elseif(sub .eq. 'gfg') then + igfgsw=1 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + call wrtout(1) + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + endif + IF(IACTVFIL .LE. 0) IACTVFIL=1 + FNAMEOUT(IACTVFIL)=FNAMRM + ENDIF + + go to 100 + + CASE (ID_ITEM16) ! Save As option + + Filter='Geo file -- *.geo|*.geo|GFGEN file -- *.bin|*.bin|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) +! SUB='geo' +! CALL ADDSUB(FNAME,SUB) + FNAMGE=FNAME + IOT1 = 22 + if(SUB .EQ. 'geo') then + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='binary') + igfgswb=0 +! add header to binary file + + DO J=11,1000 + HEADER(J:J)=' ' + ENDDO + HEADER(1:10)='RMAGEN ' + CALL DATE_AND_TIME(DATEC,TIMEC,ZONEC,DTI) + HEADER(11:20)=DATEC + HEADER(21:30)=TIMEC + HEADER(31:40)=ZONEC + WRITE(IOT1) HEADER + call wrtout(2) + CLOSE (IOT1) + OPEN(IOT1 ,FILE=FNAMGE,STATUS='UNKNOWN',form='binary') + else + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='unformatted') + igfgswb=1 + call wrtout(2) + CLOSE (IOT1) + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='unformatted') + endif + FNAMEOUT(IACTVFIL)=FNAMRM + ENDIF + + go to 100 + + CASE (ID_SBIN) ! Save As special binary format + + CALL GETHDRTYP(IHDSWT) + + Filter='Geo file -- *.geo|*.geo|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + CALL SHORTNAME(FNAME,FNAMEDISP) +! SUB='geo' +! CALL ADDSUB(FNAME,SUB) + FNAMGE=FNAME + IOT1 = 22 + if(SUB .EQ. 'geo') then + if(ihdswt .eq. 1) then + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='UNFORMATTED', CONVERT='LITTLE_ENDIAN') + else + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='UNFORMATTED', CONVERT='BIG_ENDIAN') + endif + igfgswb=0 +! add header to binary file + + DO J=11,1000 + HEADER(J:J)=' ' + ENDDO + HEADER(1:10)='RMAGEN ' + CALL DATE_AND_TIME(DATEC,TIMEC,ZONEC,DTI) + HEADER(11:20)=DATEC + HEADER(21:30)=TIMEC + HEADER(31:40)=ZONEC + WRITE(IOT1) HEADER + call wrtout(2) + CLOSE (IOT1) + if(ihdswt .eq. 1) then + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='UNFORMATTED', CONVERT='LITTLE_ENDIAN') + else + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='UNFORMATTED', CONVERT='BIG_ENDIAN') + endif + endif + ENDIF + + go to 100 + CASE (ID_BKF) ! Read background option + + fname=' ' +!!! CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Background file') + FILTER ="Background Files|*.wmf;*.bmp;*.pcx;*.png;*.cgm;*.pic;*.jpg|wmf file -- *.wmf|*.wmf|bmp file -- *.bmp|*.bmp|pcx file -- *.pcx|*.pcx|png file -- *.png|*.png|jpeg file -- *.jpg|*.jpg|cgm file -- *.cgm|*.cgm|pic file -- *.pic|*.pic|" + CALL WSelectFile(FILTER,PromptOn+DirChange+Appendext,FNAME,'Load Background file') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + NBKFL=NBKFL+1 + BFNAME(NBKFL)=FNAME + IF(SUB .EQ. 'bmp') then + ISWBKFL(NBKFL) = 2 + ELSEIF(SUB .EQ. 'pcx') then + ISWBKFL(NBKFL) = 2 + ELSEIF(SUB .EQ. 'png' .or. sub .eq. 'jpg') then + ISWBKFL(NBKFL) = 2 + ELSE + ISWBKFL(NBKFL)=1 + ENDIF + write(90,*) 'nbkfl in winnew',nbkfl + write(90,*) ' iswbkfl',iswbkfl(nbkfl) + SUB1=SUB + SUB='ORG' + CALL ADDSUB(FNAME,SUB) + BFNAMR(NBKFL)=FNAME + INQUIRE (FILE = fname, EXIST = exists) + IF (.NOT. exists) THEN + IF(SUB1 .EQ. 'PNG' .or. SUB1 .EQ. 'png') SUB2='PNGW' + IF(SUB1 .EQ. 'JPG' .or. SUB1 .EQ. 'jpg') SUB2='JPGW' + CALL ADDSUB(FNAME,SUB2) + BFNAMR(NBKFL)=FNAME + INQUIRE (FILE = fname, EXIST = exists) + IF (.NOT. exists) THEN + IF(SUB2 .EQ. 'JPGW') THEN + SUB1='JGW' + CALL ADDSUB(FNAME,SUB1) + BFNAMR(NBKFL)=FNAME + ENDIF + ENDIF + INQUIRE (FILE = fname, EXIST = exists) + IF (.NOT. exists) THEN + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'ORG file does not exist!!'//CHAR(13)// & + 'Do you wish to create file and view image','Looking for ORG file') +! If answer 'Yes' set ifrmel to 0 +! + IF (WInfoDialog(4) .ne. 2) then + OPEN(104,FILE=FNAME,STATUS ='NEW', FORM ='FORMATTED') + BFNAMR(NBKFL)=FNAME + BFMINMAX(NBKFL,1) = - XS + BFMINMAX(NBKFL,2) = - YS + BFMINMAX(NBKFL,3) = HSIZE*TXSCAL - XS + BFMINMAX(NBKFL,4) = 7.50*TXSCAL - YS + WRITE(104,'(4G16.8)') (BFMINMAX(NBKFL,I),I=1,4) + CLOSE(104) + GO TO 100 + ELSE + NBKFL=NBKFL-1 + GO TO 100 + ENDIF + ENDIF + OPEN(104,FILE=FNAME,STATUS ='OLD', FORM ='FORMATTED') + READ(104,'(G16.8)') XX1 + READ(104,'(G16.8)') XX2 + READ(104,'(G16.8)') XX3 + READ(104,'(G16.8)') XX4 + READ(104,'(G16.8)') XX5 + READ(104,'(G16.8)') XX6 + call IGrFileInfo(BFNAME(NBKFL),INFO,3) + + BFMINMAX(NBKFL,1) = XX5 + BFMINMAX(NBKFL,2) = XX6+INFO(3)*XX4 + BFMINMAX(NBKFL,3) = XX5+INFO(2)*XX1 + BFMINMAX(NBKFL,4) = XX6 + + CLOSE(104) + GO TO 100 +! yes + + ENDIF + + OPEN(104,FILE=FNAME,STATUS ='OLD', FORM ='FORMATTED') + READ(104,'(4G16.8)') (BFMINMAX(NBKFL,J),J=1,4) + CLOSE(104) + + ENDIF + +! ipk jan10 + go to 100 + + CASE (ID_ICOPY) + CALL WSelectFile(ID_STRING6,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Copy File Name') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + FNAMEB=FNAME + SUB1='ORG' + CALL ADDSUB(FNAMEB,SUB1) + CALL OUTORG(FNAMEB) + if(sub .eq. 'jpg' .or. sub .eq. 'png' .or. sub .eq. 'pcx' .or. sub .eq. 'bmp') then +! call doplot(0) + CALL WGrSaveImageOptions(31,100) + CALL WGrSaveImageOptions(32,150) + call igrsaveimage(fname) + call doplot(0) + call IGrFileInfo(FNAME,INFO,3) + IF(SUB .EQ. 'jpg') THEN + SUB2='jpgw' + CALL ADDSUB(FNAMEB,SUB2) + CALL OUTJPGW(FNAMEB,INFO) + ENDIF + CALL HEDR + go to 100 + endif + + CALL IGrInit('HP') ! hardcopy only output +!ipk may10 + IYPIX=HSIZE/7.5*540 + IXPIX=540 + + IF(SUB .EQ. 'wmf') then + CALL IGrHardCopySelect(1,11) + CALL IGrHardCopyOptions(27,1) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + + ELSEIF(SUB .EQ. 'emf') then + CALL IGrHardCopySelect(1,11) + CALL IGrHardCopyOptions(27,2) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + ELSEIF(SUB .EQ. 'dxf') then + CALL IGrHardCopySelect(1,8) + ELSEIF(SUB .EQ. 'pcx') then + CALL IGrHardCopySelect(1,6) + CALL IGrHardCopyOptions(26,0) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + CALL IGrHardCopyOptions(2,540) + ELSEIF(SUB .EQ. 'bmp') then + CALL IGrHardCopySelect(1,6) + CALL IGrHardCopyOptions(26,1) +!ipk may10 + IYPIX=IYPIX*1.5 + IXPIX=810 + CALL IGrHardCopyOptions(1,IYPIX) +!IPK MAY10 CALL IGrHardCopyOptions(2,540) + CALL IGrHardCopyOptions(2,IXPIX) + ELSEIF(SUB .EQ. 'png') then + CALL IGrHardCopySelect(1,6) + CALL IGrHardCopyOptions(26,3) + CALL IGrHardCopyOptions(23,24) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + CALL IGrHardCopyOptions(2,540) + ELSEIF(SUB .EQ. 'jpg') then + CALL IGrHardCopySelect(1,6) + CALL IGrHardCopyOptions(23,24) + CALL IGrHardCopyOptions(26,4) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + CALL IGrHardCopyOptions(2,540) + ELSEIF(SUB .EQ. 'cgm') then + CALL IGrHardCopySelect(1,9) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + ELSEIF(SUB .EQ. 'pic') then + CALL IGrHardCopySelect(1,7) +!ipk may10 + CALL IGrHardCopyOptions(1,IYPIX) + CALL IGrHardCopyOptions(2,540) + ENDIF + CALL IGrHardcopy(fname) ! Start print manager + CALL IGrFillPattern(Solid) + + CALL IgrUnits(0.,0.,HSIZE,7.5) + if(menus .eq. 12 .or. menus .eq. 13) then + call conout(menus) + else + CALL CLSCRN + CALL PLOTOT(-1) ! plot graph + endif + call rblack + call frame(0.,0.,HSIZE,7.5) + CALL IGrHardcopy('S') ! Send data to the printer + CALL IGrInit('P') ! Turn graphics back on + CALL IGrFillPattern(Solid) + + CALL IgrUnits(0.,0.,HSIZE,8.0) + if(menus .eq. 12 .or. menus .eq. 13) then + call conout(menus) + else + CALL CLSCRN + CALL PLOTOT(0) ! plot graph + endif + CALL HEDR + call rblack + CALL IGrHardCopySelect(1,10) + GO TO 100 + ENDIF + +! ipk jan10 + go to 100 + + CASE (ID_CLIP) + + call igrsaveimage( ) + call doplot(0) + CALL HEDR + go to 100 + +! Clipboard save +!ipk may10 +! IYPIX=HSIZE/7.5*540 +! IXPIX=540 +! CALL IGrHardCopySelect(1,11) +! CALL IGrHardCopyOptions(27,2) +!ipk may10 +! CALL IGrHardCopyOptions(1,IYPIX) +! CALL IGrHardcopy() ! Start print manager +! CALL IGrFillPattern(Solid) + +! CALL IgrUnits(0.,0.,HSIZE,7.5) +! if(menus .eq. 12 .or. menus .eq. 13) then +! call conout(menus) +! else +! CALL CLSCRN +! CALL PLOTOT(-1) ! plot graph +! endif +! call rblack +! CALL IGrHardcopy('S') ! Send data to the printer +! CALL IGrInit('P') ! Turn graphics back on +! CALL IGrFillPattern(Solid) +! +! CALL IgrUnits(0.,0.,HSIZE,8.0) +! if(menus .eq. 12 .or. menus .eq. 13) then +! call conout(menus) +! else +! CALL CLSCRN +! CALL PLOTOT(0) ! plot graph +! endif +! CALL HEDR +! call rblack +! CALL IGrHardCopySelect(1,10) +! GO TO 100 + + CASE (ID_SAVSHP) ! Copy to shape file selected is selected + call saveshp + go to 100 + + CASE (ID_ITEM24) ! Print option is selected + CALL WHardcopyOptions(3) +! +! If the user clicked OK on page setup dialog then output the contents +! to the selected printer +! + IF (WinfoDialog(ExitButtonCommon).EQ.CommonOK) THEN + CALL IGrInit('HP') ! hardcopy only output + CALL IGrFillPattern(Solid) + + CALL IgrUnits(0.,0.,HSIZE,7.5) + CALL IGrHardcopy(' ') ! Start print manager + if(menus .eq. 12 .or. menus .eq. 13) then + call conout(menus) + else + CALL CLSCRN + CALL PLOTOT(-1) ! plot graph + endif + call rblack + CALL IGrFillPattern(0,0,0) + CALL IGrRectangle(0.,0.,HSIZE,7.5) + CALL IGrHardcopy('S') ! Send data to the printer + CALL IGrInit('P') ! Turn graphics back on + CALL IGrFillPattern(Solid) + + CALL IgrUnits(0.,0.,HSIZE,8.0) + if(menus .eq. 12 .or. menus .eq. 13) then + call conout(menus) + else + CALL CLSCRN + CALL PLOTOT(0) ! plot graph + endif + CALL HEDR + call rblack + CALL IGrFillPattern(0,0,0) + CALL IGrRectangle(0.,0.,HSIZE,7.5) + GO TO 100 + END IF + +! ipk jan10 + go to 100 + + CASE (ID_ITEM19) ! Demo option + SUB='DEM' + CALL RBLUE + CALL SYMBL(1.,5.,0.25,SUB,0.0,3) + CALL DEMOS + +! ipk jan10 + go to 100 + + CASE (ID_MMAP) + call mmap + go to 100 + +!IPK MAY03 + CASE (ID_SELRM1) ! Select different mesh file + IOLDACT=IACTVFIL + CALL PANELFIL + IF (IOLDACT .NE. IACTVFIL) THEN +! Resave current file + + IFILOUT=IOLDACT+50 + CALL WRTFIL(IFILOUT) + CALL LOADFIL + ENDIF + GO TO 100 +!IPK MAY03 + CASE (ID_ADDMESH) ! Select file FOR MESH ADDITION + IOLDACT=IACTVFIL + CALL PANELFIL + IF( IOLDACT .EQ. IACTVFIL) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Same file selected for addition'//& + CHAR(13)//'Process ended','SAME FILE') + GO TO 100 + ENDIF + IFILADD=IACTVFIL + IACTVFIL=IOLDACT + CALL ADDTOMESH(IFILADD,0) + GO TO 100 +!IPK MAY03 + CASE (ID_MRGMESH) ! Select file FOR MESH MERGING + IOLDACT=IACTVFIL + CALL PANELFIL + IF( IOLDACT .EQ. IACTVFIL) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Same file selected for merging'//& + CHAR(13)//'Process ended','SAME FILE') + GO TO 100 + ENDIF + IFILADD=IACTVFIL + IACTVFIL=IOLDACT + CALL ADDTOMESH(IFILADD,1) + GO TO 100 +!ipk sep16 ADD MESH FROM POINTS + CASE (ID_ADDMESHTR) + CALL ADDMESHT + GO TO 100 +!ipk may03 + CASE (ID_TRIANG) ! add a triangle of elements + CALL ADDTRIANG + GO TO 100 + + CASE (ID_ADDMAP) ! add a triangle of elements + CALL ADDMAP + GO TO 100 + + CASE (ID_3DVIEW) + CALL SETANGLE + I3DVIEW=1 + if(menus .eq. 12 .or. menus .eq. 13) then + CALL CLSCRN + call conout(menus) + else + call plotot(0) + endif + call hedr + GO TO 100 + + CASE (ID_VIEWANGLE) + + I3DVIEW=1 + CALL SETANGLE + CALL PLOTOT(0) + call hedr + GO TO 100 + + + +!ipk may03 + CASE (ID_QUAD) ! add a quad of elements + CALL ADDQUAD + GO TO 100 + +!ipk may03 + CASE (ID_SETUPLEV) ! setup levees + CALL RESETWHGT + GO TO 100 + + CASE (ID_SETTYPLEV) ! setup levees + CALL LEVSETTYP + GO TO 100 + + + CASE (ID_G1D) + CALL FORM1DEL + GO TO 100 +!ipk apr04 + CASE (ID_CREATM) ! create mesh from contours + CALL CREATM + GO TO 100 + + CASE (ID_OUTLINFL) ! read outline file + CALL RDOUTLIN + GO TO 100 + + CASE (ID_TESTOUT) ! read outline file + CALL CHECKPOLY + GO TO 100 + + CASE (ID_CGEN) ! generate contours + CALL CGEN + GO TO 100 + + CASE (ID_SPLITN) + CALL SPLITN + GO TO 100 + + CASE (ID_FORM999) + CALL FORM999(0,0,1) + GO TO 100 + + CASE (ID_FORM2D) + CALL FORM999(1,0,1) + GO TO 100 +!IPK FEB03 + + CASE (ID_TRIAN) + CALL TRIANG + GO TO 100 + + CASE (ID_SWMAP) + CALL SWMAP + GO TO 100 + + CASE (ID_SWRM1) + CALL SWRM1 + GO TO 100 + + CASE (ID_MAP) + CALL GRELV + GO TO 100 + + CASE (ID_SELPR) + CALL GETALLANGS + GO TO 100 + + CASE (ID_RVSDIAG) + CALL RVSDIAG + GO TO 100 + + CASE (ID_LOADELTLD) + CALL GETEQ + GO TO 100 + + CASE (ID_SHOWELTLD) + CALL SHOWEQ(0) + GO TO 100 + + CASE (ID_RESHOWELTLD) + CALL SHOWEQ(1) + GO TO 100 + + CASE (ID_ASSIGNELTLD) + CALL ASSIGNEQ + GO TO 100 + + CASE (ID_SAVELTLD) + CALL SAVEEQ + GO TO 100 + + CASE (ID_ITEM17) ! Exit option +!IPK SEP02 + call rquit(iyes) + if(iyes .ne. 1) go to 100 + MENUS=0 + CALL QUIT_PGM + CASE (ID_EXIT) ! Exit program (menu option) + call rquit(iyes) + if(iyes .ne. 1) go to 100 + MENUS=0 + CALL QUIT_PGM + + CASE (ID_NODEDATA) + CALL NODEDISP(0) + GO TO 101 + + CASE (ID_ELTDATA) + CALL ELTDISP(0) + GO TO 101 + + CASE (ID_EDLAY) + CALL LAYDISP + GO TO 101 + + CASE (ID_RESETRG) + CALL RESETREG + GO TO 101 + + CASE (ID_MOVMESH) + CALL MOVMESH + GO TO 101 + + CASE (ID_TRANSFORM) + CALL TRANSMESH + GO TO 101 + +!IPK SEP02 + CASE (ID_GETELM) + CALL GETELMNO + GO TO 101 + + CASE (ID_ATTACH) + CALL REATTACH + GO TO 101 + + CASE (ID_DDRAW) + IDDSW=MOD(IDDSW+1,2) + IF(IDDSW .EQ. 1) CALL WMenuSetState(ID_DDRAW,ItemChecked,1) + + GO TO 101 + + CASE (ID_COMPLEX) + CALL GNODE(2) + GO TO 101 + + CASE (ID_fillagap) + CALL JOINEL + GO TO 101 + + CASE (ID_GETSTRESSFIL) + CALL GETSTRESSFIL + GO TO 101 + + CASE (ID_NODE) + MENUS=2 + CASE (ID_DELM) + CALL DELETM(0) + go to 100 + CASE (ID_DELETELM) + CALL DELETEM + go to 100 + CASE (ID_ELTS) + MENUS=1 + CASE (ID_FILL) + CALL FILM(1) + call hedr + go to 100 + CASE (ID_FILLTR) + CALL FILLTR + call hedr + go to 100 + CASE (ID_JOIN) + CALL JOIN(1) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + go to 100 + CASE (ID_JOINALL) + CALL JOINALL + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + go to 100 + CASE (ID_CRGRID) + CALL CRGRID + GO TO 100 + CASE (ID_CRSECT) + CALL CRSECT + GO TO 101 + CASE (ID_CRSCAL) + CALL COMPWGT + GO TO 101 + CASE (ID_CSLOC) + CALL GETCSLOC + GO TO 101 + CASE (ID_ORDR) + MENUS=3 + CASE (ID_ORDR1) + CALL ORDALL + GO TO 101 + CASE (ID_DCONTR) + MENUS=12 + CALL CONOUT(MENUS) + GO TO 101 + CASE (ID_CONTOPT) + MENUS=13 + CALL CONOUT(MENUS) + GO TO 101 +!ipk feb02 + CASE (ID_cdata) +! +! Create data for message file and display +! + CALL ELDAT + go to 101 + CASE (ID_CCLN) + MENUS=6 + CASE (ID_CHKCCLN) + CALL CHKLIN + GO TO 101 + CASE (ID_CSEC) + MENUS=7 + CASE (ID_ZIN) + MENUS=8 + iflag='z' + zoomh=' Zooming, click and drag to form rectangle' + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,43) + go to 101 + CASE (ID_OUT2) + MENUS=8 + iflag='y' + CASE (ID_OUT4) + MENUS=8 + iflag='x' + CASE (ID_CHCK) + CALL CHKAREA + GO TO 101 + CASE (ID_FINDNODE) + CALL FINDNOD + GO TO 101 + CASE (ID_FINDELEM) + CALL FINDEL + GO TO 101 + CASE (ID_MCHCK) + CALL CHKAREA + GO TO 101 + CASE (ID_SMOOTHMAP) + CALL SMOOTHMP + GO TO 101 + + CASE (ID_DRAG) + MENUS=8 + iflag='d' + idrag=1 + zoomh=' drag/pan , click right to end' + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,30) + call WCursorShape(CurCrossHair) + go to 101 + CASE (ID_ROTATE) + MENUS=8 + iflag='d' + idrag=2 + zoomh=' rotate view , click right to end' + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,30) + call WCursorShape(CurCrossHair) + go to 101 + CASE (ID_VROTATE) + MENUS=8 + iflag='d' + idrag=2 + zoomh=' rotate view , click right to end' + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,30) + call WCursorShape(CurCrossHair) + go to 101 + CASE (ID_RSET) + MENUS=8 + iflag='w' + CASE (ID_PLEFT) + MENUS=8 + iflag='v' + CASE (ID_PRIGHT) + MENUS=8 + iflag='u' + CASE (ID_PUP) + MENUS=8 + iflag='t' + CASE (ID_PDOWN) + MENUS=8 + iflag='s' + CASE (ID_IDRWT) + + DO + call wdialogload(IDD_DIALOG06) + + call wdialogputcheckbox(IDF_RADIO1,IPSW(1)) + call wdialogputcheckbox(IDF_RADIO2,IPSW(2)) + call wdialogputcheckbox(IDF_RADIO3,IPSW(4)) +! call wdialogputcheckbox(IDF_RADIO4,IPSW(3)) +! call wdialogputcheckbox(IDF_RADIO5,IPSW(9)) + call wdialogputcheckbox(IDF_RADIO6,IPSW(5)) + call wdialogputcheckbox(IDF_RADIO7,IPSW(7)) + call wdialogputcheckbox(IDF_RADIO8,IPSW(6)) + call wdialogputcheckbox(IDF_RADIO19,IPSW(15)) + call wdialogputcheckbox(IDF_RADIO9,IPSW(8)) +!ipk jan01 + call wdialogputcheckbox(IDF_RADIO10,IPSW(10)) +!ipk oct02 + call wdialogputcheckbox(IDF_RADIO11,IPSW(11)) + call wdialogputcheckbox(IDF_RADIO12,IPSW(12)) + call wdialogputcheckbox(IDF_RADIO13,IPSW(13)) +! call wdialogputcheckbox(IDF_RADIO17,IPSW(14)) + IF(IPSW(3) .EQ. 1) THEN + call wdialogputradiobutton(IDF_RADIO4) + ELSEIF(IPSW(9) .EQ. 1) THEN + call wdialogputradiobutton(IDF_RADIO5) + ELSEIF(IPSW(14).EQ. 1) THEN + call wdialogputradiobutton(IDF_RADIO17) + ELSE + call wdialogputradiobutton(IDF_RADIO18) + ENDIF + IF(IPW1 .EQ. 1) THEN + call wdialogputradiobutton(IDF_RADIO14) + ELSEIF(IPW1 .EQ. 2) THEN + call wdialogputradiobutton(IDF_RADIO15) + ELSEIF(IPW1 .EQ. 3) THEN + call wdialogputradiobutton(IDF_RADIO16) + ENDIF + call wdialogputreal(IDF_REAL1,WIDEL) + call wdialogputreal(IDF_REAL2,WIDSCL) + + CALL WDialogSelect(IDD_DIALOG06) + CALL WDialogShow(-1,-1,0,Modal) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + call wdialoggetcheckbox(IDF_RADIO1,IPSW(1)) + call wdialoggetcheckbox(IDF_RADIO2,IPSW(2)) + call wdialoggetcheckbox(IDF_RADIO3,IPSW(4)) + call wdialoggetcheckbox(IDF_RADIO4,IPSW(3)) + call wdialoggetcheckbox(IDF_RADIO5,IPSW(9)) + call wdialoggetcheckbox(IDF_RADIO6,IPSW(5)) + call wdialoggetcheckbox(IDF_RADIO7,IPSW(7)) + call wdialoggetcheckbox(IDF_RADIO8,IPSW(6)) + call wdialoggetcheckbox(IDF_RADIO8,IPSW(15)) + call wdialoggetcheckbox(IDF_RADIO9,IPSW(8)) +!ipk jan01 + call wdialoggetcheckbox(IDF_RADIO10,IPSW(10)) +!ipk oct02 + call wdialoggetcheckbox(IDF_RADIO11,IPSW(11)) + call wdialogGetcheckbox(IDF_RADIO12,IPSW(12)) + call wdialogGetcheckbox(IDF_RADIO13,IPSW(13)) +! call wdialoggetcheckbox(IDF_RADIO4,IPSW(3)) +! call wdialoggetcheckbox(IDF_RADIO5,IPSW(9)) +! call wdialogGetcheckbox(IDF_RADIO17,IPSW(14)) + call wdialoggetradiobutton(IDF_RADIO4,ipw2) + IPSW(3)=0 + IPSW(9)=0 + IPSW(14)=0 + IF(IPW2 .EQ. 1) THEN + IPSW(3)=1 + ELSEIF(IPW2 .EQ. 2) THEN + IPSW(9)=1 + ELSEIF(IPW2 .EQ. 3) THEN + IPSW(14)=1 + ENDIF +! IF(IPSW(3) .EQ. 1) THEN +! IPSW(9)=0 +! call wdialogputcheckbox(IDF_RADIO5,0) +! IPSW(14)=0 +! call wdialogputcheckbox(IDF_RADIO17,0) +! ENDIF +! IF(IPSW(9) .EQ. 1) THEN +! IPSW(3)=0 +! call wdialogputcheckbox(IDF_RADIO4,0) +! IPSW(14)=0 +! call wdialogputcheckbox(IDF_RADIO17,0) +! ENDIF +! IF(IPSW(14) .EQ. 1) THEN +! IPSW(9)=0 +! call wdialogputcheckbox(IDF_RADIO5,0) +! IPSW(3)=0 +! call wdialogputcheckbox(IDF_RADIO4,0) +! ENDIF + + IF(IPSW(5) .EQ. 1) THEN + IPSW(7)=0 + call wdialogputcheckbox(IDF_RADIO7,0) + ENDIF + call wdialoggetradiobutton(IDF_RADIO14,ipw1) + call wdialoggetreal(IDF_REAL1,WIDEL) + call wdialoggetreal(IDF_REAL2,WIDSCL) + MENUS=9 + endif + CALL PLOTOT(0) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + + GO TO 100 + ENDDO + GO TO 100 + + CASE (ID_ITYPN) + MENUS=9 +! IQSW(1)=1-IQSW(1) +! IF(IQSW(1) .EQ. 1) THEN +! IQSW(2)=0 +! ENDIF + IQSW(1)=1 + IQSW(2)=0 + CALL WMenuSetState(ID_ITYPN,ItemChecked,1) + CALL WMenuSetState(ID_ITYPC,ItemChecked,0) + CALL WMenuSetState(ID_IGPC,ItemChecked,0) + CALL WMenuSetState(ID_IGPN,ItemChecked,0) + go to 100 + CASE (ID_ITYPC) + MENUS=9 +! IQSW(2)=1-IQSW(2) +! IF(IQSW(2) .EQ. 1) THEN +! IQSW(1)=0 +! ENDIF + IQSW(2)=1 + IQSW(1)=0 + CALL WMenuSetState(ID_ITYPC,ItemChecked,1) + CALL WMenuSetState(ID_ITYPN,ItemChecked,0) + CALL WMenuSetState(ID_IGPC,ItemChecked,0) + CALL WMenuSetState(ID_IGPN,ItemChecked,0) + go to 100 + CASE (ID_IGPN) + MENUS=9 + IQSW(1)=2 + IQSW(2)=0 + CALL WMenuSetState(ID_ITYPN,ItemChecked,0) + CALL WMenuSetState(ID_ITYPC,ItemChecked,0) + CALL WMenuSetState(ID_IGPN,ItemChecked,1) + CALL WMenuSetState(ID_IGPC,ItemChecked,0) + go to 100 + CASE (ID_IGPC) + MENUS=9 + IQSW(1)=0 + IQSW(2)=2 + CALL WMenuSetState(ID_ITYPC,ItemChecked,0) + CALL WMenuSetState(ID_ITYPN,ItemChecked,0) + CALL WMenuSetState(ID_IGPN,ItemChecked,0) + CALL WMenuSetState(ID_IGPC,ItemChecked,1) + go to 100 + CASE (ID_MAPOPD) + DO + call wdialogload(IDD_DIALOG05) + + call wdialogputcheckbox(IDF_CMAP0,ICOLON(1)) + call wdialogputcheckbox(IDF_CMAP1,ICOLON(2)) + call wdialogputcheckbox(IDF_CMAP2,ICOLON(3)) + call wdialogputcheckbox(IDF_CMAP3,ICOLON(4)) + call wdialogputcheckbox(IDF_CMAP4,ICOLON(5)) + call wdialogputcheckbox(IDF_CMAP5,ICOLON(6)) + call wdialogputcheckbox(IDF_CMAP6,ICOLON(7)) + call wdialogputcheckbox(IDF_CMAP7,ICOLON(8)) + call wdialogputcheckbox(IDF_CMAP8,ICOLON(9)) + call wdialogputcheckbox(IDF_CMAP9,ICOLON(10)) + call wdialogputcheckbox(IDF_CMAP10,ICOLON(11)) + call wdialogputcheckbox(IDF_CMAP11,ICOLON(12)) + + CALL WDialogSelect(IDD_DIALOG05) + CALL WDialogShow(-1,-1,0,Modal) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetcheckbox(IDF_CMAP0,ICOLON(1)) + call wdialoggetcheckbox(IDF_CMAP1,ICOLON(2)) + call wdialoggetcheckbox(IDF_CMAP2,ICOLON(3)) + call wdialoggetcheckbox(IDF_CMAP3,ICOLON(4)) + call wdialoggetcheckbox(IDF_CMAP4,ICOLON(5)) + call wdialoggetcheckbox(IDF_CMAP5,ICOLON(6)) + call wdialoggetcheckbox(IDF_CMAP6,ICOLON(7)) + call wdialoggetcheckbox(IDF_CMAP7,ICOLON(8)) + call wdialoggetcheckbox(IDF_CMAP8,ICOLON(9)) + call wdialoggetcheckbox(IDF_CMAP9,ICOLON(10)) + call wdialoggetcheckbox(IDF_CMAP10,ICOLON(11)) + call wdialoggetcheckbox(IDF_CMAP11,ICOLON(12)) + + ENDIF + CALL PLOTOT(0) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + GO TO 100 + + ENDDO + GO TO 100 + + CASE (ID_DRAWD) + CALL PLOTOT(0) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + + GO TO 100 + + CASE (ID_BSEL) + CALL PANEL012(IBAKON) + IF(IBAKON .EQ. 1) THEN +! FONT%IBCOL = TextWhite +! call WindowFontColour(0,7) + IRGB = WRGB(220,220,220) + + ELSE +! FONT%IBCOL = TextWhiteBold +! call WindowFontColour(0,15) + IRGB = WRGB(255,255,255) + ENDIF +! CALL WindowFont(FONT) + call clear_screen + call plotot(0) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + + GO TO 100 + + CASE (ID_REGST) + DO N=1,NBKFL + IF(ISWBKFL(N) .NE. 0) THEN + CALL REGISTR(N) + ENDIF + ENDDO + GO TO 100 + +! CASE (ID_BACGDG) +! call clear_screen +! call plotot(0) +! nhtp=nhtpsv +! nmess=nmessv +! nbrr=nbrrsv +! call hedr + +! GO TO 100 + + + CASE (ID_HELP1) + call helps(0) +! call WHelpfile('rmagenv5.htm') + go to 100 +! MENUS=4 + CASE (ID_HELP2) + call RMINFO + go to 100 + + CASE (ID_ITEM20) + CALL GDIST + GO TO 100 + + CASE (ID_ITEM22) + CALL SELNODE(0) + menus=2 + GO TO 100 + + CASE (ID_ALLNODES) + CALL SELNODE(1) + menus=2 + GO TO 100 + + CASE (ID_UNUSNODES) + CALL SELNODE(2) + menus=2 + GO TO 100 + + CASE (ID_SELELTYP) + CALL SELNODE(3) + menus=2 + GO TO 100 + + CASE (ID_MOVGRP) + CALL SELNODE(4) + menus=2 + GO TO 100 + + CASE (ID_ITEM23) + CALL SELELT(0) + menus=0 + GO TO 100 + CASE (ID_SECGRP) + CALL SELELT(2) + menus=0 + GO TO 100 +! CALL HEDR + CASE (ID_SELAREA) + CALL SELELT(1) + menus=2 + GO TO 100 + CASE (ID_DISPTYP) + CALL FINDTYP + menus=2 + GO TO 100 + + CASE (ID_UNDO) + CALL UNDOACT + GO TO 100 + CASE (ID_UNDOS) + IFLAG='U' + CASE (ID_UNDOGEN) +! IF(ITOTFIL .EQ. 1) THEN +! CALL ZEROOUT +! IACTVFIL=0 +! CALL PLOTOT(0) +! ELSE + CALL UNDOGEN +! ENDIF + GO TO 100 + CASE (ID_GOUTLIN) + CALL GOUTLIN + GO TO 100 + CASE (ID_XOUTLIN) + CALL OUTLINES(0) + GO TO 100 + + END SELECT + +! +! Mouse button down - only process mouse button 1 events +! + CASE (MouseButDown) + if(menus .eq. 8) then + call rred + IF (MESSAGE%VALUE1.EQ.1) THEN +! +! Enable button up and mouse movement events +! + CALL WMessageEnable(MouseButUp, Enabled) +! CALL WMessageEnable(MouseMove , Enabled) + IDOWN = 1 +! +! Save the current cursor position +! + XPOS = MESSAGE%GX + YPOS = MESSAGE%GY +! For box plotting we must initialise Exclusive-OR plotting, +! set the fill type, draw the initial box and save the corner +! co-ordinates +! + CALL IGrPlotMode('E') +!DEC09 CALL IGrPlotMode(0) + if(idrag .eq. 0) then + CALL IGrFillPattern(0,0,0) + CALL IGrRectangle(XPOS, YPOS, MESSAGE%GX, MESSAGE%GY) + else + call Rgreen + CALL IGrJoin(XPOS, YPOS, MESSAGE%GX, MESSAGE%GY) + iflag='d' + endif + XOLD = MESSAGE%GX + YOLD = MESSAGE%GY + ELSE + call WCursorShape(CurArrow) + idrag=0 + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + menus=0 + ENDIF + GO TO 101 + ELSE + MBUTTON = MESSAGE%VALUE1 + ITIME = MESSAGE%VALUE2 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + XM=MESSAGE%GX + YM=MESSAGE%GY + IF(MBUTTON .EQ. 1) THEN + IFLAG='c' + ELSE + if(idrag .eq. 0) then + IFLAG='r' + else + idrag=0 + menus=0 + go to 101 + endif + ENDIF + ENDIF +! +! Mouse Movement +! + CASE (MouseMove) + IF (IDOWN.EQ.1) THEN +! +! For rectangle plotting we must redraw the last box to erase it from the +! screen. We then update the co-ordinates and draw the new rectangle +! + IF(IDRAG .EQ. 0) THEN + CALL IGrRectangle(XPOS, YPOS, XOLD, YOLD) + XOLD = MESSAGE%GX + YOLD = MESSAGE%GY + XSCRN= XOLD + YSCRN= YOLD + XMS = XSCRN*TXSCAL - XS + YMS = YSCRN*TXSCAL - YS + WRITE(STBAR,'(2g19.10)') XMS,YMS + CALL WindowOutStatusBar(2,STBAR) + WRITE(STBAR,'('' NP = ''i6,'' NE = ''i6)') NP,NE + CALL WindowOutStatusBar(3,STBAR) + WRITE(STBAR,'(2x,A48)') FNAMEDISP + CALL WindowOutStatusBar(5,STBAR) + xsiz=abs(xold-xpos) + ysiz=abs(yold-ypos) + slen=sqrt(xsiz**2+ysiz**2) + + shapef=hsize/8. + +!jan09 if(xsiz .lt. 1.25*ysiz) then +!jan09 xsiz=1.25*ysiz + if(xsiz .lt. shapef*ysiz) then + xsiz=shapef*ysiz +! xsiz=16./25.*slen + if(xold .lt. xpos) then + xold=xpos-xsiz + else + xold=xpos+xsiz + endif +!jan09 elseif(ysiz .lt. 0.80*xsiz) then +!jan09 ysiz=0.80*xsiz + elseif(ysiz .lt. xsiz/shapef) then + ysiz=xsiz/shapef +! ysiz=9./25.*slen + if(yold .lt. ypos) then + yold=ypos-ysiz + else + yold=ypos+ysiz + endif + endif + CALL IGrRectangle(XPOS, YPOS, xold,yold) + go to 101 + ELSE + CALL IGrJoin(XPOS, YPOS, XOLD, YOLD) + XOLD = MESSAGE%GX + YOLD = MESSAGE%GY + XSCRN= XOLD + YSCRN= YOLD + XMS = XSCRN*TXSCAL - XS + YMS = YSCRN*TXSCAL - YS + WRITE(STBAR,'(2g19.10)') XMS,YMS + CALL WindowOutStatusBar(2,STBAR) + WRITE(STBAR,'('' NP = ''i6,'' NE = ''i6)') NP,NE + CALL WindowOutStatusBar(3,STBAR) + WRITE(STBAR,'(2x,A48)') FNAMEDISP + CALL WindowOutStatusBar(5,STBAR) + CALL IGrJoin(XPOS, YPOS, XOLD, YOLD) + go to 101 + ENDIF + ELSE + XOLD = MESSAGE%GX + YOLD = MESSAGE%GY + XSCRN= XOLD + YSCRN= YOLD + XMS = XSCRN*TXSCAL - XS + YMS = YSCRN*TXSCAL - YS + WRITE(STBAR,'(2g19.10)') XMS,YMS + CALL WindowOutStatusBar(2,STBAR) + WRITE(STBAR,'('' NP = ''i6,'' NE = ''i6)') NP,NE + CALL WindowOutStatusBar(3,STBAR) + WRITE(STBAR,'(2x,A48)') FNAMEDISP + CALL WindowOutStatusBar(5,STBAR) + GO TO 101 + ENDIF + +! CASE (PushButton) ! Dialog button pressed +! IDBUTN = MESSAGE%VALUE1 +! IDFIELD = MESSAGE%VALUE2 + + CASE (MouseButUp) ! Mouse button up + IF(MENUS .NE. 8) THEN + MBUTTON = MESSAGE%VALUE1 + ITIME = MESSAGE%VALUE2 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + XM=MESSAGE%GX + YM=MESSAGE%GY + IF(MBUTTON .EQ. 1) THEN + IFLAG='c' + ELSE + IFLAG='r' + ENDIF + ELSE +! +! We disable movement and button up events +! + IDOWN = 0 + CALL WMessageEnable(MouseButUp, Disabled) +! CALL WMessageEnable(MouseMove , Disabled) + IF(IDRAG .EQ. 0) THEN + CALL IGrRectangle(XPOS, YPOS, XOLD, YOLD) + CALL IGrPlotMode('N') + CALL IGrRectangle(XPOS, YPOS, xold,yold) + XPOS1=MESSAGE%GX + YPOS1=MESSAGE%GY + menus=-8 + zoomh=' Click right if size OK' +! + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,23) + GO TO 101 + ELSEIF(IDRAG .EQ. 1) THEN + menus=8 + CALL IGrJoin(XPOS, YPOS, XOLD, YOLD) + CALL IGrPlotMode('N') + CALL IGrJoin(XPOS, YPOS, xold,yold) + + XPOS1=MESSAGE%GX + YPOS1=MESSAGE%GY + xpos=xpos1-xpos + ypos=ypos1-ypos + xpos1=xpos+HSIZE + ypos1=ypos+8. + iflag='d' + call zoomnew(xpos,ypos,xpos1,ypos1,iflag) + zoomh=' Click right to end ' +! + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,20) + iflag='r' + GO TO 101 + ELSE + menus=8 + CALL IGrJoin(XPOS, YPOS, XOLD, YOLD) + CALL IGrPlotMode('N') + CALL IGrJoin(XPOS, YPOS, xold,yold) + + XPOS1=MESSAGE%GX + YPOS1=MESSAGE%GY + xpos=xpos1-xpos + ypos=ypos1-ypos + zoomh=' Click right to end ' + + IF(ABS(XPOS) .GT. ABS(YPOS)) THEN + hrad=xpos/(YPOS1-4) + VRAD=0. + ELSE + vrad=-ypos/10. + HRAD=0. + ENDIF + call adjustang(hrad,vrad) +! + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,20) + iflag='r' + GO TO 101 + ENDIF + ENDIF +! WRITE(90,*) 'MOUSE BUT',MOUSEX,MOUSEY,XM,YM +! WRITE(90,'(A)') 'MOUSE BUT',IFLAG + CASE (Expose) ! Window partly/wholly exposed + iflag='P' + IX = MESSAGE%X + IY = MESSAGE%Y + IWIDTH = MESSAGE%VALUE1 + IHEIGHT = MESSAGE%VALUE2 + call hedr + if(menus .eq. 12 .or. menus .eq. 13) then + call conout(menus) + else + call plotot(0) + endif + call hedr +!IPK MAY01 + IRDISP=1 + if(nmess .eq. 11) CALL PLTPT + + if(menus .eq. 13) CALL CONOUT(MENUS) + + go to 100 + CASE (Resize) ! Window resized + CALL IGrUnits(0.,0.,HSIZE,8.0) + iflag='P' + IWIDTH = MESSAGE%VALUE1 + IHEIGHT = MESSAGE%VALUE2 + call hedr + + if(menus .eq. 12 .or. menus .eq. 13) then + call conout(menus) + else + call plotot(0) + endif + call hedr +!IPK MAY01 + IRDISP=1 + if(nmess .eq. 11) CALL PLTPT + + if(menus .eq. 13) CALL CONOUT(MENUS) + + go to 100 + CASE (CloseRequest) ! Close window (e.g. Alt/F4) + IWINDOW = MESSAGE%WIN + if(iwindow .eq. 0) then +!IPK SEP02 + call rquit(iyes) + if(iyes .ne. 1) go to 100 + CALL QUIT_PGM ! Root window : exit program + else + CALL WindowCloseChild(iwindow) + DO I=1,NWINDWS + IF(IWINDOW .EQ. IWNDWS(I)) THEN + IWNDWS(i)=0 + ISCRNS(i)=0 +! This call removes the bitmap + CALL BACKP(3,I) + ENDIF + ENDDO + go to 100 + endif +! CASE (FieldChanged) ! Field change in modeless dialog +! IDFIELDOLD = MESSAGE%VALUE1 +! IDFIELDNEW = MESSAGE%VALUE2 + END SELECT +! WRITE(90,'(A)') 'endselect',IFLAG +! write(90,*) 'endselect',menus + menus =abs(menus) + IF(MENUS .GT. 0 .and. menus .lt. 8) THEN + CALL RMAGEN(MENUS,IMP,IIN,1,IOT,IOT1,NDM,ITRIAN,N2,M2) + ENDIF + if(menus .eq. 8) then + IF(IFLAG .EQ. 'w') THEN + HANG=0. + VANG=90 + VRTSCAL=100. + VRTORIG=0. + i3dview=0 + endif + if( IFLAG .EQ. 'r' .or.& + iflag .eq. 'y' .or.& + iflag .eq. 'x' .or.& + iflag .eq. 'w' .or.& + iflag .eq. 'v' .or.& + iflag .eq. 'u' .or.& + iflag .eq. 't' .or.& + iflag .eq. 's' ) then + call zoomnew(xpos,ypos,xpos1,ypos1,iflag) + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv + call hedr + endif +!IPK MAY01 + IRDISP=1 + if(nmess .eq. 11) CALL PLTPT + go to 100 + endif + IF(MENUS .EQ. 9) GO TO 101 + + + ix=xm*100. + iy=ym*100. +! call IMouseCursorHide() + 250 continue + nhtp=nhtpsv + nmess=nmessv + nbrr=nbrrsv +! WRITE(90,'(A)') 'end',IFLAG +! write(90,*) 'end',menus,nhtp,nhtpsv +! call clscrn +! call hedr + END SUBROUTINE diff --git a/src/src83e/FILE.F90 b/src/src83e/FILE.F90 new file mode 100644 index 0000000..72e835c --- /dev/null +++ b/src/src83e/FILE.F90 @@ -0,0 +1,160 @@ +! last update March 6 2000 add default values for CMAP + SUBROUTINE FILE(ientry) +! +! Define input output units +! + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' +!IPK APR94 + COMMON /RECOD/ IRECD,TSPC + common /cols/ ibakk,icolr,iblkk + COMMON /PAGE/ XL,XH,YL,YH +! + CHARACTER*80 LIND +!IPK APR94 CHARACTER*40 FNAM,FNAMB + CHARACTER*40 FNAM,FNAMB,FNAMC + CHARACTER*3 SUB + CHARACTER*1 ANS + LOGICAL*4 EXST,STATM + data ihere/0/ + if(ihere .eq. 1) return + mpnam='elt.mpb' + ibakk=8 + icolr=11 + iblkk= 9 + xl=0. + yl=0. + xh=HSIZE + yh=8.0 + ielvsw=0 + if(ientry .eq. 1) then + ihere=1 +! MAXPL=200000 + MAXELMP=100000 + + ALLOCATE (NOPEL(MAXELMP,3),XCEN(MAXELMP),YCEN(MAXELMP)& + ,RADS(MAXELMP) ,NKEY(MAXELMP),CMAP(MAXPL,2)& + ,XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL)) + + ALLOCATE (imap(maxpl),NCRS(MAXPL)) + RADS=0. + XCEN=0. + YCEN=0. + endif + +!ipk jan98 + OPEN(UNIT=90,FILE='messgen.out',STATUS='UNKNOWN', IOSTAT=iost) + if(iost .gt. 0) then + OPEN(UNIT=90,FILE='messgen1.out',STATUS='UNKNOWN', IOSTAT=iost) + if(iost .gt. 0) then + OPEN(UNIT=90,FILE='messgen2.out',STATUS='UNKNOWN', IOSTAT=iost) + if(iost .gt. 0) then + write(*,*) 'ERROR UNABLE TO OPEN MESSGEN.OUT FILE' + write(*,*) 'PRESS RETURN TO END' + read(*,'(I5)') junk + STOP + endif + endif + endif +!ipk jan98 + write(lind,6010) + 6010 format(' Compilation limits are') + call symbl(1.1,1.5,0.20,LIND,0.0,80) + write(lind,6110) maxe + 6110 FORMAT( ' Maximum elements =',i8) + call symbl(1.1,1.2,0.20,LIND,0.0,80) + write(lind,6111) maxp + 6111 FORMAT( ' Maximum nodes =',i8) + call symbl(1.1,0.9,0.20,LIND,0.0,80) + +! +! Open files +! + IBAK = 21 + OPEN(IBAK,FILE='ELT.BAK',STATUS='UNKNOWN',FORM='UNFORMATTED',IOSTAT=iost) + if(iost .gt. 0) then + OPEN(IBAK,FILE='ELT1.BAK',STATUS='UNKNOWN',FORM='UNFORMATTED',IOSTAT=iost) + if(iost .gt. 0) then + OPEN(IBAK,FILE='ELT2.BAK',STATUS='UNKNOWN',FORM='UNFORMATTED',IOSTAT=iost) + if(iost .gt. 0) then + write(*,*) 'ERROR UNABLE TO OPEN ELT.BAK FILE' + write(*,*) 'PRESS RETURN TO END' + read(*,'(I5)') junk + STOP + endif + ENDIF + ENDIF +! OPEN(IBAK,FILE='ELT.BAK',STATUS='UNKNOWN',FORM='BINARY') + + IS11=94 + INQUIRE(FILE='startup.dat',EXIST= EXST) + IF(EXST) THEN + OPEN(IS11 ,FILE='startup.dat',STATUS='OLD',FORM='FORMATTED') + ELSE + IS11=0 + ENDIF + +! Initialize variables + NCLM=0 + +!ipk may94 add 2 lines below + XREF=0. + YREF=0. + MNP = MAXP + MEL = MAXE +!! uncertain call INITSIZ(0,0,1) + nmapf=1 + NSIGF=1 + DO I=1,MNP + XUSR(I) = -1.D20 + YUSR(I) = -1.D20 + CORD(I,1) = -1.D20 + CORD(I,2) = -1.D20 + WD(I) = -9999. + LAY(I) = -9999 + WIDTH(I) = 0.0 + SS1(I) = 0.0 + SS2(I) = 0.0 + WIDS(I) = 0.0 + WIDBS(I)=0. + SSO(I)=0. + INSKP(I) = 1 + INEW(I) = 0 +!ipk mar02 + lock(i)=0 + bs1(I)=0. + ENDDO +! + DO I=1,MEL + DO K=1,8 + NOP(I,K) = 0 + ENDDO +! + IEM(I) = 0 + IMAT(I) = 0 + THTA(I)=0. + XC(I) = -1.E20 + YC(I) = -1.E20 + IESKP(I) = -1 + ENDDO +! + MLIN = MAXLIN + DO I=1,MLIN + LINTYP(I) = -999 + ENDDO +!IPK OCT96 + DO I=1,10 + ICOLON(I)=1 + ENDDO + +!ipk mar00 define default values for CMAP + DO J=1,MAXPTS + CMAP(J,1) = -1.e20 + CMAP(J,2) = -1.e20 + enddo + + + RETURN + END diff --git a/src/src83e/FILL.F90 b/src/src83e/FILL.F90 new file mode 100644 index 0000000..67cdfd8 --- /dev/null +++ b/src/src83e/FILL.F90 @@ -0,0 +1,269 @@ +!IPK LAST UPDATE jAN 25 2001 INCREMENT NP FOR ALREADY EXISTING NODES IN NOP +!IPK LAST UPDATE APR 6 1998 + SUBROUTINE FILM(ISWT) +!june93 SUBROUTINE FILM(IFILL) +!- +! ISWT = 0 means read a value for IFILL +! ISWT = 1 means use a value of 1 for IFILL +! If IFILL = 1, use all unused node nos. for filling midside nodes +! If IFILL = 0, start midside node numbering with max node no. +!- + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INCLUDE 'BFILES.I90' + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + INTEGER NUSED(MAXP) + +!IPK MAY02 + REAL*8 XX,YY + data itime/0/ + + if(itime .eq. 0) then + ifill=0 + itime=1 + endif +! call WcursorShape(1) + NHTPsv = nhtp + NMESSsv = nmess + NBRRsv = nbrr + NHTP = 0 + NBRR = 0 + NMESS=45 + CALL HEDR + NMESS = 19 + xprt=3.2 +! + IF(ISWT .EQ. 0) THEN + CALL GETINT(IFILL) + ELSE + IFILL=1 + ENDIF +! + +!- +!-.....FIND MISSING NODE NUMBERS..... +!- + NP0 = 0 + DO 10 I=1,MAXP + 10 NUSED(I) = 0 + DO 101 J = 1, NE + IF( IMAT(J) .EQ. 0 ) GO TO 101 + DO 100 K = 1, 8 + IF( NOP(J,K) .LE. 0) GOTO 100 + NUSED(NOP(J,K))=999 + 100 END DO + 101 END DO + +! Form list of elements connected to nodes + IERR=0 + CALL NDNECON(IERR) + IF(IERR .GT. 0) THEN + LIMIT=MAXECON + CALL NODERR(IERR,LIMIT) + GO TO 200 + ENDIF +!C- +!C-.....PUT INPUTS INTO PROPER LOCATIONS..... +!C- +! DO 140 J = 1, NE +! IF( IMAT(J) .EQ. 0 ) GO TO 140 +! IF( NOP(J,5) .GT. 0 ) GO TO 140 +! DO 130 K = 1, 4 +! IT(K) = NOP(J,K) +! NOP(J,K) = 0 +! 130 CONTINUE +! KK = 0 +! DO 135 K = 1, 8, 2 +! KK = KK + 1 +! NOP(J,K) = IT(KK) +! 135 CONTINUE +! 140 CONTINUE +!- +!-.....INSERT NEW NUMBERS..... +!- + NP0=0 + IF(IFILL .EQ. 0) NP0=NP + DO 190 J = 1, NE +!ipk apr98 IF( IMAT(J) .GT. 0 .AND. IMAT(J) .LT.901) THEN + IF(( IMAT(J) .GT. 0 .AND. IMAT(J) .LT.901) .or. & + & imat(j) .gt. 903) THEN + NCN = NCORN(J) + JN = J + 1 + DO 180 K = 2, NCN, 2 + if((imat(j) .gt. 995 .and. imat(j) .lt. 1999) .and. (k .eq. 4 .or. k .eq. 8) & + & ) go to 180 + NA = K - 1 + NB = MOD(K+1,NCN) + IF(NB .EQ. 0) NB=NCN + NA = NOP(J,NA) + NB = NOP(J,NB) + AA=(WD(NA)+WD(NB))/2. + AB=(WD1(NA)+WD1(NB))/2. + IF( NOP(J,K) .EQ. 0 ) THEN + IRDONE=0 +99 NP0 = NP0 + 1 + IF(NP0 .GT. MAXP) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Execution terminated, nodal limits exceeded. Backup written','LIMITS EXCEEDED') + CALL WRTOUT(0) + STOP + ENDIF + IF(INEW(NP0) .EQ. 1) GO TO 99 + IF (NUSED(NP0) .GT. 0) GOTO 99 + NOP(J,K) = NP0 + XX=(CORD(NA,1)+CORD(NB,1))/2. + YY=(CORD(NA,2)+CORD(NB,2))/2. + CORD(NP0,1)=XX + CORD(NP0,2)=YY + WD(NP0)=AA + WD1(NP0)=AB + WIDTH(NP0)=(WIDTH(NA)+WIDTH(NB))/2. + SS1(NP0)=(SS1(NA)+SS1(NB))/2. + SS2(NP0)=(SS2(NA)+SS2(NB))/2. + WIDS(NP0)=(WIDS(NA)+WIDS(NB))/2. + WIDBS(NP0)=(WIDBS(NA)+WIDBS(NB))/2. + BS1(NP0)=(BS1(NA)+BS1(NB))/2. + + + INEW(NP0) = 1 + IF(LOCK(NA) .EQ. 1 .AND. LOCK(NB) .EQ. 1) LOCK(NP0)=1 + XUSR(NP0) = XX*TXSCAL - XS + + YUSR(NP0) = YY*TXSCAL - YS + INSKP(NP0) = 0 +!SSO(N),- +!,BS1(N)-.....SEARCH FOR OTHER ELEMENT..... +!- +!ipk dec98 set a counter + ielct=0 + +!ipk0ct93 DO 170 JJ = JN, NE + + DO 170 JJJ=1,NDELM(NA) + JJ=NECON(NA,JJJ) +!IPK SEP02 DO 170 JJ = 1, NE +!ipkoct93 IF( IMAT(JJ) .GT. 0 .OR. IMAT(JJ) .LT.901) THE + if(jj .eq. j) go to 170 + if(imat(jj) .gt. 0) then + NNCN = NCORN(JJ) + DO 160 KK = 2, NNCN, 2 + IF( NOP(JJ,KK-1) .EQ. NB ) THEN + KN = MOD(KK+1,NNCN) + IF(KN .EQ. 0) KN=NNCN + IF( NOP(JJ,KN) .EQ. NA ) THEN + NOP(JJ,KK) = NP0 +!ipk dec98 + ielct=ielct+1 + if(ielct .eq. 2) then + GO TO 180 + else + go to 170 + endif +!ipk dec98 end changes + ENDIF +!IPK APR98 ADD + ELSEIF( NOP(JJ,KK-1) .EQ. NA ) THEN + KN = MOD(KK+1,NNCN) + IF(KN .EQ. 0) KN=NNCN + IF( NOP(JJ,KN) .EQ. NB ) THEN + NOP(JJ,KK) = NP0 +!ipk dec98 + ielct=ielct+1 + if(ielct .eq. 2) then + GO TO 180 + else + go to 170 + endif +!ipk dec98 end changes + ENDIF +!IPK APR98 + ENDIF + 160 CONTINUE + ENDIF + 170 CONTINUE + ELSE + NM=NOP(J,K) + IF(INEW(NM) .NE. 1) THEN + XX=(CORD(NA,1)+CORD(NB,1))/2. + YY=(CORD(NA,2)+CORD(NB,2))/2. + CORD(NM,1)=XX + CORD(NM,2)=YY + WD(NM)=AA + WD1(NM)=AB + WIDTH(NM)=(WIDTH(NA)+WIDTH(NB))/2. + SS1(NM)=(SS1(NA)+SS1(NB))/2. + SS2(NM)=(SS2(NA)+SS2(NB))/2. + WIDS(NM)=(WIDS(NA)+WIDS(NB))/2. + WIDBS(NM)=(WIDBS(NA)+WIDBS(NB))/2. + BS1(NM)=(BS1(NA)+BS1(NB))/2. + INEW(NM) = 1 + IF(LOCK(NA) .EQ. 1 .AND. LOCK(NB) .EQ. 1) LOCK(NM)=1 + XUSR(NM) = XX*TXSCAL - XS + YUSR(NM) = YY*TXSCAL - YS + INSKP(NM) = 0 +!ipk jan01 + IF(NM .GT. NP) NP=NM + ELSE + WD(NM)=AA + WD1(NM)=AB + ENDIF + ENDIF + 180 CONTINUE + ENDIF + 190 CONTINUE + IF (NP0 .GT. NP) NP=NP0 + 200 CONTINUE + NHTP = nhtpsv + NMESS = nmesssv + NBRR = nbrrsv +! call WcursorShape(0) + +!IPK MAY03 + ICHG=0 + + RETURN + END + + + SUBROUTINE NODERR(NODER,LIMIT) + + USE WINTERACTER + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + + INTEGER :: IERR,NODER,LIMIT + + call wdialogload(IDD_NODERR) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_NODERR) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER2,LIMIT) + CALL WDialogPutInteger(IDF_INTEGER3,NODER) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + RETURN + ELSE + RETURN + ENDIF + enddo + RETURN + END diff --git a/src/src83e/FILLTR.F90 b/src/src83e/FILLTR.F90 new file mode 100644 index 0000000..dfad3e1 --- /dev/null +++ b/src/src83e/FILLTR.F90 @@ -0,0 +1,293 @@ + SUBROUTINE FILLTR + USE WINTERACTER + USE IFPORT + USE BLKMAP + CHARACTER(LEN=256) :: FILTER,FNAME + CHARACTER(LEN=80) :: DATAIN,OPTIONS + CHARACTER(LEN=96) :: LOCDIR + CHARACTER(LEN=3) :: SUB + INTEGER INOUTL,NOUTL,OUTPOL + INTEGER NTRIAN(5000,2),TWO,ZERO,ntrans(5000) + INTEGER*2 RESULT + LOGICAL EXISTS + do k=1,80 + options(k:k)=' ' + enddo + TWO=2 + ZERO=0 + INOUTL=22 + OUTPOL=23 + VOID = - 1.0E+10 + VDX = - 1.0E+9 + +! +! get filename + +! FILTER ="Data files|*.dat;*.txt;*.map|Map file -- *.map|*.map|" +! CALL WSelectFile(FILTER,PromptOn+DirChange+Appendext,FNAME,'Load data file') + +! IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN +! OPEN(INOUTL,FILE=FNAME,STATUS='OLD') +! CALL IlowerCase(FNAME) +! CALL GETSUB(FNAME,SUB) +! IF(SUB .EQ. 'map') then +! IMAPIN=1 +! ELSE +! IMAPIN=0 +! ENDIF +! ELSE +! WRITE(*,*) 'ERROR NO FILE' +! ENDIF + IMAPIN=1 +! read outline +! + IF(IMAPIN .EQ. 1) THEN + OPEN(113,FORM='BINARY',STATUS='SCRATCH') + WRITE(113) XMAP,YMAP + REWIND (113) + DO K=1,5000 + IF(XMAP(K) .LT. VDX) THEN + NOUTL=K-1 + GO TO 90 + ENDIF + ENDDO +90 CONTINUE + ELSE +! IF(IMAPIN .EQ. 1) READ(INOUTL,'(A80)') DATAIN + DO K=1,5000 + READ(INOUTL,'(A80)') DATAIN + IF(DATAIN(1:3) .EQ. 'END' .OR. DATAIN(1:3) .EQ. 'end') then + NOUTL=K-1 + GO TO 100 + ELSE + READ(DATAIN,*) XMAP(K),YMAP(K) + ENDIF + ENDDO +100 CONTINUE + ENDIF + IF(XMAP(NOUTL) .EQ. XMAP(1) .AND. YMAP(NOUTL) .EQ. YMAP(1)) THEN + XMAP(NOUTL)=VOID + YMAP(NOUTL)=VOID + NOUTL=NOUTL-1 + LOOPC=1 + ELSE + LOOPC=0 + ENDIF + + DO J=1, NOUTL + NTRIAN(J,1)=J + NTRIAN(J,2)=J+1 + ENDDO + NTRIAN(NOUTL,2)=1 + JC=NOUTL +! read contours + NOUTBE=NOUTL+1 + NOUTT=NOUTL + DO N=1,100 + if(imapin .eq. 1) then + noutb=noutt+2+LOOPC + ncnt=0 + DO K=NOUTB,5000 + if(k .eq. noutb) then + if(xmap(k) .lt. vdx) go to 300 + endif + IF(XMAP(K) .LT. VDX) THEN + NOUTT=K-1 + GO TO 110 + ENDIF + ncnt=ncnt+1 + ENDDO +110 CONTINUE + else + READ(INOUTL,'(A80)', END=300) DATAIN + IF(DATAIN(1:3) .EQ. 'END') GO TO 300 + NOUTB=NOUTT+1 + NCNT=0 + DO K=NOUTB,5000 + READ(INOUTL,'(A80)') DATAIN + IF(DATAIN(1:3) .EQ. 'END' .OR. DATAIN(1:3) .EQ. 'end') then + NOUTT=K-1 + GO TO 200 + ELSE + READ(DATAIN,*) XMAP(K),YMAP(K) + NCNT=NCNT+1 + ENDIF + ENDDO +200 CONTINUE + endif + IF(XMAP(NOUTT) .EQ. XMAP(NOUTB) .AND. YMAP(NOUTT) .EQ. YMAP(NOUTB)) THEN + XMAP(NOUTT)=VOID + YMAP(NOUTT)=VOID + NOUTT=NOUTT-1 + LOOPC=1 + ELSE + LOOPC=0 + ENDIF + JC=NOUTB-1 + JCB=JC+1 + DO J=NOUTBE, NOUTBE+NCNT-2-LOOPC + JC=JC+1 + NTRIAN(J,1)=JC + NTRIAN(J,2)=JC+1 + ENDDO + IF(LOOPC .EQ. 1) THEN + NTRIAN(NOUTBE+NCNT-2,1)=JC+1 + NTRIAN(NOUTBE+NCNT-2,2)=JCB + NOUTBE=NOUTBE+NCNT-1 + ELSE + NOUTBE=NOUTBE+NCNT-1 + ENDIF + JC=JC+1 + ENDDO +! copy to a file +300 CONTINUE + OPEN(OUTPOL,FILE='TEST.POLY', STATUS='UNKNOWN') + ncnt=0 + DO K=1,NOUTT + if(xmap(k) .lt. vdx) cycle + ncnt=ncnt+1 + ntrans(k)=ncnt + ENDDO + WRITE(OUTPOL,*) NCNT,TWO,ZERO,ZERO + ncnt=0 + DO K=1,noutt + if(xmap(k) .lt. vdx) cycle + ncnt=ncnt+1 + WRITE(OUTPOL,*) ncnt,XMAP(K),YMAP(K) + ENDDO + WRITE(OUTPOL,*) NOUTBE-1,ZERO + DO J=1, NOUTBE-1 + WRITE(OUTPOL,*) J,ntrans(NTRIAN(J,1)),ntrans(NTRIAN(J,2)) + ENDDO + WRITE(OUTPOL,*) ZERO + FLUSH (OUTPOL) + REWIND (OUTPOL) + CLOSE (OUTPOL) +! close (inoutl) +! setup options + +! OPTIONS = ' -pqa5000V TEST' + OPTIONS(1:3) = ' -p' + nct=3 + iswq=1 + iswy=0 + id1=100 + CALL PANELFILLT(ISWQ,ISWY,ID1) + + IF(ISWQ .EQ. 1) THEN + NCT=NCT+1 + OPTIONS(NCT:NCT)='q' + ENDIF + IF(ISWY .EQ. 1) THEN + NCT=NCT+1 + OPTIONS(NCT:NCT)='q' + ENDIF + ID1=ID1**2/2 + WRITE(OPTIONS(NCT+1:NCT+12),'(''a'',I6.6,'' TEST'')') ID1 +! go to TRIANGLE + + INQUIRE (FILE = 'test.1.ele', EXIST = exists) + if(exists) then + open(77,file= 'test.1.ele') + close(77,status='DELETE') + ENDIF + + INQUIRE (FILE = 'test.1.node', EXIST = exists) + if(exists) then + open(77,file= 'test.1.node') + close(77,status='DELETE') + ENDIF + + INQUIRE (FILE = 'test.1.poly', EXIST = exists) + if(exists) then + open(77,file= 'test.1.poly') + close(77,status='DELETE') + ENDIF + INQUIRE (FILE = "C:\Program Files\RMA\TRIANGLE.EXE", EXIST = exists) + if(.not. exists) then + INQUIRE (FILE = "TRIANGLE.EXE", EXIST = exists) + if(.not. exists) then + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'TRIANGLE is not available in '//CHAR(13)//& + 'C:\Program Files\RMA\ directory'//CHAR(13)//'Do you wish to define directory?'& + ,'WARNING TRIANGLE IS NOT AVAILABLE') + +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) return + CALL GETDIR(LOCDIR) + else + LOCDIR(1:8)='TRIANGLE' +! WRITE(155,*) LOCDIR + RESULT= RUNQQ(LOCDIR, OPTIONS) + GO TO 600 + endif + endif + + RESULT= RUNQQ("C:\Program Files\RMA\TRIANGLE", OPTIONS) +! RESULT= RUNQQ("TRIANGLE", OPTIONS) +600 CONTINUE + IF(IMAPIN .EQ. 1) THEN + READ(113) XMAP,YMAP + CLOSE (113) + ENDIF + IIN=10 + OPEN(IIN,FILE='TEST.1.ELE', STATUS='OLD') + + CALL GETNEWFIL(IIN,0,1,1) + + +! finish up + RETURN + END + + SUBROUTINE PANELFILLT(N1,N2,N3) + + use winteracter + implicit none + SAVE + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR,ITIME +! real :: +! character*3 :: + DATA ITIME/0/ +! IF(ITIME .EQ. 0) THEN +! ITIME=1 +! N1=1 +! N2=0 +! N3=100 +! ENDIF + + call wdialogload(IDD_FTRIAN) + ierr=infoerror(1) + + CALL WDialogPutCheckBox(idf_check1,n1) + CALL WDialogPutCheckBox(idf_check2,n2) + CALL WDialogPutInteger(idf_integer1,n3) + + + CALL WDialogSelect(IDD_FTRIAN) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetCheckBox(idf_check1,n1) + CALL WDialogGetCheckBox(idf_check2,n2) + CALL WDialogGetInteger(idf_integer1,n3) + ELSEIF(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + N3=-1 + ENDIF + RETURN + END + \ No newline at end of file diff --git a/src/src83e/FORMGP.F90 b/src/src83e/FORMGP.F90 new file mode 100644 index 0000000..add79ff --- /dev/null +++ b/src/src83e/FORMGP.F90 @@ -0,0 +1,145 @@ + SUBROUTINE FORMGP + + USE WINTERACTER + USE BLK1MOD + include 'd.inc' + + CHARACTER*47 MESSAGE + + DATA MESSAGE /'Enter Group Number'/ + + DATA ITIME/0/ + +! SWITCH TO GROUP ACTIVITY + + IF(IQSW(1) .EQ. 1) IQSW(1)=2 + IF(IQSW(2) .EQ. 1) IQSW(2)=2 + + +! IF FIRST TIME ASK TO LOAD FILE OR SET GROUPS = 1 + + if(ITIME .EQ. 0) THEN +! ALLOCATE ARRAY SIZES + + IF(.NOT. ALLOCATED(IGRPNUM)) THEN + ALLOCATE (IGRPNUM(25,MAXE),MAXENT(25)) + CALL TOPAR + ENDIF + ISW=2 + ITIME=1 + ELSE + CALL TOPAR + ENDIF + + +! ASSIGN A NUMBER TO THE NEW GROUP + + call wdialogload(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogPutString(IDF_STRING1,MESSAGE) + CALL WDialogPutInteger(IDF_INTEGER1,ISW) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetInteger(IDF_INTEGER1,ISW) + GO TO 200 + ENDIF + ENDDO + + 200 CONTINUE + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish add these elements to the current group?'//& + CHAR(13)//' ','ADD ELEMENTS?') + +! If answer 'No', start afresh +! + IF (WInfoDialog(4).EQ.2) then + +! STORE GROUP NUMBERS STARTING AT 1 + + DO K=1,NEFL + IGRPNUM(ISW,K)=NEFLAG(K) + ENDDO + MAXENT(ISW)=NEFL + ELSE +! +! FOR EACH ELEMENT SEARCH FIRST IF NOT FOUND ADD TO THE END + + DO K=1,NEFL + DO J=1,MAXENT(ISW) + IF(NEFLAG(K) .EQ. IGRPNUM(ISW,J)) GO TO 240 + ENDDO + MAXENT(ISW)=MAXENT(ISW)+1 + IGRPNUM(ISW,MAXENT(ISW))=NEFLAG(K) + 240 CONTINUE + ENDDO + ENDIF + +! REMOVE FROM OLD LIST + DO I=1,25 + IF(I .NE. ISW) THEN + DO J=1,MAXENT(I) + DO K=1,NEFL + IF(NEFLAG(K) .EQ. IGRPNUM(I,J)) THEN + IGRPNUM(I,J)=0 + GO TO 260 + ENDIF + ENDDO + 260 CONTINUE + ENDDO + JT=0 + LIMIT=MAXENT(I) + J=0 + 270 J=J+1 + 275 IF(J+JT .LE. LIMIT) THEN + IF(IGRPNUM(I,J+JT) .EQ. 0) THEN + JT=JT+1 + GO TO 275 + ENDIF + IGRPNUM(I,J)=IGRPNUM(I,J+JT) + GO TO 270 + ENDIF + DO J=MAXENT(I),MAXENT(I)+1-JT,-1 + IGRPNUM(I,J)=0 + ENDDO + MAXENT(I)=MAXENT(I)-JT + ENDIF + ENDDO + + CALL TOSER + + RETURN + END + + SUBROUTINE TOSER + USE BLK1MOD + DO I=1,25 + DO J=1,MAXENT(I) + IGRPSER(IGRPNUM(I,J))=I + ENDDO + ENDDO + RETURN + END + + SUBROUTINE TOPAR + USE BLK1MOD + + MAXENT=0 + IGRPNUM=0 + + DO K=1,NE + I=IGRPSER(K) + MAXENT(I)=MAXENT(I)+1 + IGRPNUM(I,MAXENT(I))=K + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/src83e/FORMSHP.F90 b/src/src83e/FORMSHP.F90 new file mode 100644 index 0000000..f13c701 --- /dev/null +++ b/src/src83e/FORMSHP.F90 @@ -0,0 +1,455 @@ + subroutine formshp2(istyp,ivecact) + use winteracter + + include 'D.inc' + + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + character*1 ai1a,ai1b,ai1c,ai1d,label,ai1f + character*3 sub + character*4 ai1,ai7,aai7,ai8,ai9,anrs,aii,aioff + character*10 as + character*11 name + character*80 headr + character*255 fnamein,filter + integer*2 i3s,i4s + integer status,i1,i2,i3,i4,i5,i6,i7,i8,i9,ia1,ia7,ia8,ia9,nrs& + ,nars,ii,ioff,iaoff,i1a,i1b,i1c,i1d,istyp,nptemp + integer*8 i88 + real*8 fp1,fp2,fp3,fp4,fp5,fp6,fp7,fp8,bx(1000),by(1000),bm(1000)& + ,bxmn,bymn,bxmx,bymx,bmmn,bmmx,axmn,aymn,axmx,aymx,fz,ammn,ammx + real bed,val + integer ityp,icl + allocatable bed(:),val(:,:),ityp(:),icl(:) + + LOGICAL OPENED + equivalence(ai1,ia1),(ai7,ia7),(aii,ii),(anrs,nrs),(aioff,ioff) + + if(.not. allocated(bed)) then + allocate (bed(250000),val(250000,4),ityp(250000),icl(250000)) + bed=0. + val=0. + ityp=0 + icl=0 + endif + filter='Shape file *.shp|*.shp|' + INQUIRE(99,opened= OPENED) + IF( .NOT. OPENED) THEN + CALL WSelectFile(filter,SaveDialog+PromptOn+AppendExt,FNAMEIN,'Shapefile Name') + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + open(99,file=fnamein,form='binary') + sub='shx' + call ADDSUB(fnamein,sub) + open(98,file=fnamein,form='binary') + sub='dbf' + call ADDSUB(fnamein,sub) + open(97,file=fnamein,form='binary') + ELSE + RETURN + ENDIF + ENDIF +! read data file to establish sizes and max/min + nfils=50 + axmn=1.e36 + aymn=1.e36 + ammn=1.e36 + axmx=-1.e36 + aymx=-1.e36 + ammx=-1.e36 +! if(ivecact .ne. 1) then +! read(70,'(a80)') headr +! read(70,'(a80)') headr +! read(headr(9:16),'(i8)') istyp +! endif + do i=1,250000 + if(istyp .eq. 25) then + read(113,end=100) iclt,ityp(i),npts,(bx(j),by(j),bm(j),j=1,npts) + do j=1,npts + write(155,*) bx(j),by(j),bm(j) + enddo + icl(i)=iclt + write(155,*) icl(i),ityp(i),npts + do j=1,npts + axmn=min(axmn,bx(j)) + aymn=min(aymn,by(j)) + ammn=min(ammn,bm(j)) + axmx=max(axmx,bx(j)) + aymx=max(aymx,by(j)) + ammx=max(ammx,bm(j)) + enddo +! NEED TO FIX THIS + nfils=nfils+36+12*npts +! NEED TO FIX THIS + elseif(istyp .eq. 5) then + IF(IVECACT .EQ. 5) THEN + read(113,end=100) iclt,ityp(i),npts,(bx(j),by(j),bm(j),j=1,npts) + ELSE + read(113,end=100) iclt,npts,(bx(j),by(j),j=1,npts) + ENDIF + icl(i)=iclt + do j=1,npts + axmn=min(axmn,bx(j)) + aymn=min(aymn,by(j)) + axmx=max(axmx,bx(j)) + aymx=max(aymx,by(j)) + enddo + ammn=0. + ammx=0. + nfils=nfils+28+8*npts + elseif(istyp .eq. 3) then + read(113,end=100) npts,(bx(j),by(j),j=1,npts),d1 + do j=1,npts + axmn=min(axmn,bx(j)) + aymn=min(aymn,by(j)) + axmx=max(axmx,bx(j)) + aymx=max(aymx,by(j)) + enddo + ammn=0. + ammx=0. + nfils=nfils+28+8*npts + elseif(istyp .eq. 1 .and. ivecact .eq. 0) then + read(70,9875,end=100) bx(1),by(1) + 9875 format(10x,2f20.0,f10.0) + axmn=min(axmn,bx(1)) + aymn=min(aymn,by(1)) + axmx=max(axmx,bx(1)) + aymx=max(aymx,by(1)) + ammn=0. + ammx=0. + nfils=nfils+14 + elseif(istyp .eq. 1 .and. ivecact .eq. 1) then +! read(113,end=100) NR,bxt,byt,d1,d2,d3,d4,d5,d6 + read(113,end=100) NR,bxt,byt,d1,d2,d3,d4 + 9874 format(9x,8f14.0) + axmn=min(axmn,bxt) + aymn=min(aymn,byt) + axmx=max(axmx,bxt) + aymx=max(aymx,byt) + ammn=0. + ammx=0. + nfils=nfils+14 + elseif(istyp .eq. 1 .and. ivecact .eq. 6) then + read(113,end=100) NR,bx(1),by(1),d1 + axmn=min(axmn,bx(1)) + aymn=min(aymn,by(1)) + axmx=max(axmx,bx(1)) + aymx=max(aymx,by(1)) + ammn=0. + ammx=0. + nfils=nfils+14 + endif + numdat=i + enddo + 100 rewind 113 + +! read(70,'(a80)') headr +!c if(ivecact .eq. 1) read(70,'(a80)') headr +!c setup header + ia1=9994 + call BTOL(ai1,i1) + i2=0 + i3=0 + i4=0 + i5=0 + i6=0 + ia7=nfils + call BTOL(ai7,i7) + i8=1000 + i9=istyp + fz=0. + write(99) i1,i2,i3,i4,i5,i6,i7,i8,i9,axmn,aymn,axmx,aymx,fz,fz,ammn,ammx + ia7=50+4*numdat + call BTOL(ai7,i7) + write(98) i1,i2,i3,i4,i5,i6,i7,i8,i9,axmn,aymn,axmx,aymx,fz,fz,ammn,ammx + ioff=50 + +! header now complete for shp and shx options + do i=1,numdat + if(istyp .eq. 25) then + read(113,end=100) iclt,ityp(i),npts,(bx(j),by(j),bm(j),j=1,npts) + icl(i)=iclt + nrs=32+12*npts + nrsc=nrs+4 +! write(155,*) 'nrs',nrs + call btol(anrs,nars) + elseif(istyp .eq. 5) then + IF(IVECACT .EQ. 5) THEN + read(113,end=100) iclt,ityp(i),npts,(bx(j),by(j),bm(j),j=1,npts) + ELSE + read(113) iclt,npts,(bx(j),by(j),j=1,npts) + ENDIF + icl(i)=iclt + nrs=24+8*npts + nrsc=nrs+4 +! write(155,*) 'nrs',nrs + call btol(anrs,nars) + elseif(istyp .eq. 3) then + read(113) npts,(bx(j),by(j),j=1,npts),val(i,1) + icl(i)=iclt + nrs=24+8*npts + nrsc=nrs+4 +! write(155,*) 'nrs',nrs + call btol(anrs,nars) + elseif(istyp .eq. 1) then + if(ivecact .eq. 0) then + read(70,9875) bx(1),by(1),bed(i) + elseif(ivecact .eq. 6) then + read(113) ityp(i),bx(1),by(1),val(i,1) + else + read(113) idum,bxt,byt,(val(i,j),j=1,4) + bx(1)=bxt + by(1)=byt + endif + nrs=10 + nrsc=14 +! write(155,*) 'nrs',nrs + call btol(anrs,nars) + endif + ii=i + call btol(aii,nrec) + write(99) nrec,nars + if(istyp .eq. 25) then + j1=istyp + j2=1 + bxmn=bx(1) + bymn=by(1) + bmmn=bm(1) + bxmx=bx(1) + bymx=by(1) + bmmx=bm(1) + do k=2,npts + bxmn=min(bxmn,bx(k)) + bymn=min(bymn,by(k)) + bmmn=min(bmmn,bm(k)) + bxmx=max(bxmx,bx(k)) + bymx=max(bymx,by(k)) + bmmx=max(bmmx,bm(k)) + enddo + j3=npts + j4=0 + write(99) j1,bxmn,bymn,bxmx,bymx,j2,j3,j4 + do k=1,npts + write(99) bx(k),by(k) + enddo + write(99) bmmn,bmmx + do k=1,npts + write(99) bm(k) + enddo + + elseif(istyp .gt. 2) then + j1=istyp + j2=1 + bxmn=bx(1) + bymn=by(1) + bxmx=bx(1) + bymx=by(1) + do k=2,npts + bxmn=min(bxmn,bx(k)) + bymn=min(bymn,by(k)) + bxmx=max(bxmx,bx(k)) + bymx=max(bymx,by(k)) + enddo + j3=npts + j4=0 + write(99) j1,bxmn,bymn,bxmx,bymx,j2,j3,j4 +! write(155,*) j1,bxmn,bymn,bxmx,bymx,j2,j3,j4 + do k=1,npts + write(99) bx(k),by(k) +! write(155,*) k,bx(k),by(k) + enddo + elseif(istyp .eq. 1) then + j4=1 + write(99) j4,bx(1),by(1) + endif +! write(155,*) ioff,nrs + call btol(aioff,iaoff) + write(98) iaoff,nars + ioff=ioff+nrsc + enddo + i1a=3 + i1b=115 + i1c=12 + i1d=9 + ai1a=char(i1a) + ai1b=char(i1b) + ai1c=char(i1c) + ai1d=char(i1d) + i2=numdat + if(ivecact .eq. 0 .or. ivecact .gt. 3) then + i4s=18 + i3s=97 + elseif(ivecact .eq. 3) then + i4s=11 + i3s=65 + else + i4s=37 + i3s=161 + endif + i5=0 + write(97) ai1a,ai1b,ai1c,ai1d,i2,i3s,i4s,i5 + ai1a=char(0) + ai1b='W' + write(97) i5,i5,i5,ai1a,ai1a,ai1b,ai1a + i2a=0 + IF(ISTYP .EQ. 25) THEN + name='ID ' + label='N' + i2=0 + ai1a=char(8) + ai1b=char(0) + ai1c=char(0) + ai1f=char(13) + ai1d=char(0) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c + name='Type ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(0) + ai1c=char(0) + ai1f=char(13) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c,ai1f + ELSEIF(ISTYP .EQ. 5) THEN + name='ID ' + label='N' + i2=0 + ai1a=char(8) + ai1b=char(0) + ai1c=char(0) + ai1f=char(13) + ai1d=char(0) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c + name='Contour ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(2) + IF(IVECACT .EQ. 5) THEN + name='TYPE * ' + label='N' + ai1b=char(0) + ENDIF + ai1c=char(0) + ai1f=char(13) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c,ai1f + elseif(istyp .eq. 3) then + name='CONTOUR ' + label='N' + i2=0 + ai1a=char(10) + ai1b=char(4) + ai1c=char(0) + ai1f=char(13) + ai1d=char(0) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c,ai1f + elseif(istyp .eq. 1) then + if(ivecact .eq. 6) then + name='NODE ' + label='N' + i2=0 + ai1a=char(8) + ai1b=char(0) + ai1c=char(0) + ai1f=char(13) + ai1d=char(0) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c + name='Bed Elev ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(0) + ai1c=char(0) + ai1f=char(13) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c,ai1f + else + name='VEL ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(4) + ai1c=char(0) + ai1f=char(13) + ai1d=char(0) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c + name='DIR ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(2) + ai1c=char(0) + ai1f=char(13) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c + name='DEP ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(3) + ai1c=char(0) + ai1f=char(13) + write(97)name,label,i2,ai1a,ai1b,i2a,i2a,i2a,ai1d,ai1c + name='WS-ELEV ' + label='N' + i2=0 + ai1a=char(9) + ai1b=char(3) + ai1c=char(0) + ai1f=char(13) + write(97)name,label,i2,ai1a,ai1b,i2,i2,i2,ai1d,ai1c + write(97)ai1f + endif + endif + ai1a=char(32) + ai1f=char(32) + do i=1,numdat + write(97) ai1a + if(istyp .eq. 25) then + write(as(1:8),'(i8)') icl(i) + write(97) as(1:8) + write(as(1:9),'(i9)') ityp(i) + write(97) as(1:9) + elseif(istyp .eq. 5) then + write(as(1:8),'(i8)') icl(i) + write(97) as(1:8) + if(IVECACT .EQ. 5) then + write(as(1:9),'(i9)') ityp(i) + write(97) as(1:9) + else + ficl=contur(icl(i)) + write(as(1:9),'(f9.2)') ficl + write(97) as(1:9) + endif + elseif(istyp .eq. 3) then + write(as(1:10),'(f10.4)') val(i,1) + write(97) as(1:10) + elseif(istyp .eq. 1) then + if(ivecact .eq. 0) then + write(as(1:8),'(i8)') i + write(97) as(1:8) + write(as(1:8),'(f8.2)') bed(i) + write(97) as(1:8) + elseif(ivecact .eq. 6) then + write(as(1:8),'(i8)') ityp(i) + write(97) as(1:8) + write(as(1:9),'(f9.2)') val(i,1) + write(97) as(1:9) + else + write(as(1:9),'(f9.4)') val(i,1) + write(97) as(1:9) + write(as(1:9),'(f9.2)') val(i,2) + write(97) as(1:9) + write(as(1:9),'(f9.3)') val(i,3) + write(97) as(1:9) + write(as(1:9),'(f9.3)') val(i,4) + write(97) as(1:9) + endif + endif + enddo + ai1a=char(26) + write(97) ai1a + close (99) + close (98) + close (97) + return + end + + \ No newline at end of file diff --git a/src/src83e/FRMNODQ.f90 b/src/src83e/FRMNODQ.f90 new file mode 100644 index 0000000..482e145 --- /dev/null +++ b/src/src83e/FRMNODQ.f90 @@ -0,0 +1,29 @@ + SUBROUTINE FRMNODQ(X1,Y1,X2,Y2,X3,Y3,X4,Y4,NPTS1,NPTS2) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +! X1,X2,X3,X4 AND Y1,Y2,Y3,Y4 are vertices of quad +! NPTS1 and NPTS2 are the nominal number of elements on each side + + +! Work along first side AND backwards along second line + + DO N=1,NPTS1-1 + RATIO=FLOAT(N)/FLOAT(NPTS1) + X12=X1+RATIO*(X2-X1) + Y12=Y1+RATIO*(Y2-Y1) + X43=X4+RATIO*(X3-X4) + Y43=Y4+RATIO*(Y3-Y4) + +! Now get interior points + + DO M=1,NPTS2-1 + RATIO=FLOAT(M)/FLOAT(NPTS2) + XNEW=X12+RATIO*(X43-X12) + YNEW=Y12+RATIO*(Y43-Y12) + CALL DEFNOD(XNEW,YNEW) + ENDDO + ENDDO + RETURN + END diff --git a/src/src83e/GETANG.F90 b/src/src83e/GETANG.F90 new file mode 100644 index 0000000..3f2e67d --- /dev/null +++ b/src/src83e/GETANG.F90 @@ -0,0 +1,144 @@ + SUBROUTINE GETALLANGS + + USE BLK1MOD + USE BLK2MOD + SAVE ICOUNTMX + + DIMENSION ANGA(2),ANGB(2) + + DATA ICOUNTMX/0/ + + IF(.NOT. ALLOCATED(NKEY1)) THEN + ALLOCATE (NKEY1(MAXE)) + ENDIF + IF(.NOT. ALLOCATED(ANGOP)) THEN + ALLOCATE (ANGOP(MAXP)) + ENDIF + + CALL HEDR + ICOUNTMX=50 + ILMIT=0 + CALL GEtrev(ICOUNTMX,ILMIT) + IF(ICOUNTMX .LT. 0) RETURN + NKEY1=0 +! set all the nodal angles negative + ANGOP=-1. +! get elements connected to nodes table + IERR=0 + CALL NDNECON(IERR) +! loop on the elements to find mid-sides + DO N=1,NE +! work only with triangles + IF(NCORN(N) .EQ. 6) THEN +! go to each mid-side + DO K=2,6,2 + N1=NOP(N,K-1) + KN=MOD(K+1,6) + N3=NOP(N,KN) + KP=MOD(K+3,6) + N2=NOP(N,KP) + NCUR=NOP(N,K) + IF(NCUR .EQ. 0) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK, & + 'You have tried to reverse before executing "FILL"'//CHAR(13) & + //'Reversing terminated',& + 'UNABLE TO REVERSE') +! CALL SYMBL(0.,7.30,0.20,STRELS,0.,60) + RETURN + ENDIF +! call GETANG to get angle opposite N1-N3 line + ANGTMP=GETANG(N1,N2,N3) + IF(ANGTMP .GT. ANGOP(NCUR)) ANGOP(NCUR)=ANGTMP + ENDDO + ENDIF + ENDDO +! get the angles in ascending order + CALL SORT(ANGOP,ICN,NP) + + ICOUNT=0 +! loop backwards and use the sorrt key ICN + DO J=NP,1,-1 + MIDND=ICN(J) +! only work when angles greater than 90 deg + IF(ANGOP(MIDND) .GT. 1.5708) THEN +! check if there are two elements connected to this mid side + IF(NECON(MIDND,2) .GT. 0) THEN +! make sure the opposite elements are not quadrilaterals + IF(NCORN(NECON(MIDND,1)) .EQ. 6 .AND. NCORN(NECON(MIDND,2)) .EQ. 6) THEN +! only proceed when the first mid-side has not been processed + IF(NKEY1(NECON(MIDND,1)) .EQ. 0) THEN + NEL1=NECON(MIDND,1) +! only proceed when the second mid-side has not been processed + IF(NKEY1(NECON(MIDND,2)) .EQ. 0) THEN +! we really have a candidate lest check if it will make the angles worse +! first find the locations of the mid sides in the order data to get more angles + DO KK=1,2 + DO K=2,6,2 +! test for a fit + IF(NOP(NECON(MIDND,KK),K) .EQ. MIDND) THEN +! get angles before and after +! corner before + N1=NOP(NECON(MIDND,KK),K-1) +! corner after + N3=MOD(K+1,6) + N3=NOP(NECON(MIDND,KK),N3) +! test for possible equal elev + if(ilmit .eq. 1) then + if(wd(n1) .gt. -9000.) then + if(wd(n1) .eq. wd(n3)) go to 180 + endif + endif +! corner opposite + N2=MOD(K+3,6) + N2=NOP(NECON(MIDND,KK),N2) +! call GETANG to get angle opposite N2-N3 LINE + ANGB(KK)=GETANG(N2,N1,N3) +! call GETANG to get angle opposite N1-N2 LINE + ANGA(KK)=GETANG(N1,N3,N2) + ENDIF + ENDDO + ENDDO +! test if the side angles are larger, if so skip out + IF(ANGOP(MIDND) .LT. ANGB(2)+ANGA(1)) GO TO 180 + IF(ANGOP(MIDND) .LT. ANGB(1)+ANGA(2)) GO TO 180 +! finally we can proceed + ICOUNT=ICOUNT+1 +! NELPR(ICOUNT,2)=NECON(MIDND,2) +! NELPR(ICOUNT,1)=NEL1 + NKEY1(NECON(MIDND,1))=1 + NKEY1(NECON(MIDND,2))=1 + N1=NEL1 + N2=NECON(MIDND,2) +! carry out reversal + CALL REVERS(N1,N2) +! show the elements + call fillemc(n1,4) + call fillemc(n2,4) + IF(ICOUNT .GE. ICOUNTMX) GO TO 200 + ENDIF + ENDIF + ENDIF + ENDIF + ELSE + GO TO 200 + ENDIF + 180 CONTINUE + ENDDO + 200 CONTINUE + RETURN + END + + FUNCTION GETANG(N1,N2,N3) + + USE BLK1MOD + + A=SQRT((XUSR(N1)-XUSR(N2))**2+(YUSR(N1)-YUSR(N2))**2) + B=SQRT((XUSR(N2)-XUSR(N3))**2+(YUSR(N2)-YUSR(N3))**2) + C=SQRT((XUSR(N3)-XUSR(N1))**2+(YUSR(N3)-YUSR(N1))**2) + ANG1=(A**2+B**2-C**2)/(2.*A*B) + IF(ANG1 .GT. 1.) ANG1=1. + + GETANG=ACOS(ANG1) + + RETURN + END diff --git a/src/src83e/GETCRS.F90 b/src/src83e/GETCRS.F90 new file mode 100644 index 0000000..767afdc --- /dev/null +++ b/src/src83e/GETCRS.F90 @@ -0,0 +1,241 @@ + SUBROUTINE GETCRS(CRSTIT) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + CHARACTER*8 ID1 + CHARACTER*72 DLIN1,CRSTIT + +!IPK JUN06 + DATA VOIDCR/-1.E15/ + + XCRS=VOIDCR + YCRS=VOIDCR + NRIVCR1=0 + NRIVCR2=0 +!ipk jun11 + NOREACH=0 + NRIVL=0 + + call ginpt(icrin,id1,dlin1) + + IF(ID1(1:2) .EQ. 'TC') THEN + CRSTIT=DLIN1 + call ginpt(icrin,id1,dlin1) + ELSE + CALL WMessageBox(0,3,1,'Cross-section Title not found'//char(13)//& + 'Cross-section file input terminated','ERROR') + return + ENDIF + N=0 + + 200 N=N+1 + IF(N .GT. MCRS) THEN + CALL WMessageBox(0,3,1,'Allowable number of sections (1000) exceeded'//char(13)//& + 'Cross-section file input terminated','ERROR') + return + ENDIF + IF(ID1(1:3) .EQ. 'RCH') THEN + READ(DLIN1,'(I8)') NOREACHTMP + write(90,'(a)') 'rch',id1,dlin1 + Call ginpt(icrin,id1,dlin1) + ENDIF + + IF(ID1(1:3) .EQ. 'ICS') THEN + READ(DLIN1,'(2I8,8x,2f16.0)') IVMIL(N),NRIVL(IVMIL(N)),XCRS(IVMIL(N)),YCRS(IVMIL(N)) + write(90,'(a)') 'ics',id1,dlin1 + NOREACH(IVMIL(N))=NOREACHTMP + IF(NRIVL(IVMIL(N)) .GT. MPTS) THEN + CALL WMessageBox(0,3,1,'Allowable number of points in a cross-section (75) exceeded'//char(13)//& + 'Cross-section file input terminated','ERROR') + return + ENDIF +! IF(NOREACH(N) .EQ. 0) THEN +! IF(N .GT. 1) THEN +! NOREACH(N)=NOREACH(N-1) +! ELSE +! NOREACH(N)=1 +! ENDIF +! ENDIF + call ginpt(icrin,id1,dlin1) + DO I=1,NRIVL(IVMIL(N)) + write(90,'(a)') 'crs',id1,dlin1 + READ(DLIN1,'(3F8.0)') (CRSDAT(IVMIL(N),I,J),J=1,3) +!IPK JUN04 + if(i .gt. 1) then + CRSDAT(IVMIL(N),I,2)=CRSDAT(IVMIL(N),I-1,2)+& + (CRSDAT(IVMIL(N),I,1)-CRSDAT(IVMIL(N),I-1,1))*& + (CRSDAT(IVMIL(N),I,3)+CRSDAT(IVMIL(N),I-1,3))/2. + endif + call ginpt(icrin,id1,dlin1) + ENDDO + NCRSEC=N +! TEST NCRSEC=MAX(N,IVMIL(N)) + GO TO 200 + ENDIF + +!ipk jun06 DO N=1,NCRSEC + + DO N=1,MCRS + IF(ID1(1:3) .EQ. 'XYL') THEN + READ(DLIN1,'(I8,2F16.0)') NN,XCRS(NN),YCRS(NN) +!IPK JUN06 + IF(NN .GT. NCRSEC) NCRSEC=NN + call ginpt(icrin,id1,dlin1) + ELSE + GO TO 400 + ENDIF + ENDDO + + 400 CONTINUE + DO N=1,MAXP + IF(ID1(1:3) .EQ. 'CRF') THEN + READ(DLIN1,'(2I8,F8.0,I8,F8.0)') NODCRS& + ,NRIVCR1(NODCRS),WTRIVCR1(NODCRS)& + ,NRIVCR2(NODCRS),WTRIVCR2(NODCRS) + call ginpt(icrin,id1,dlin1) + ELSE + GO TO 500 + ENDIF + ENDDO + 500 CONTINUE + + CLOSE(ICRIN) + +! CHECK THE DATA LOADED + + IERR=0 + DO N=1,NE + IF(IMAT(N) .LT. 900) THEN + IF(NCORN(N) .EQ. 3 .OR. NCORN(N) .EQ. 5) THEN + DO J=1,3,2 + IF(NRIVCR1(NOP(N,J)) .NE. 0) THEN + WD1(NOP(N,J))=& + CRSDAT(NRIVCR1(NOP(N,J)),1,1)*WTRIVCR1(NOP(N,J))+& + CRSDAT(NRIVCR2(NOP(N,J)),1,1)*WTRIVCR2(NOP(N,J)) +! ELSE +! WRITE(75,*) ' NO CROSS-SECTION FILE REFERENCE FOR',NOP(N,J) +! WRITE(75,*) ' EXECUTION TERMINATED' +! WRITE(*,*) ' NO CROSS-SECTION FILE REFERENCE FOR',NOP(N,J) +! WRITE(*,*) ' EXECUTION TERMINATED' +! IERR=IERR+1 + ELSE + WD1(NOP(N,J))=WD(NOP(N,J)) + ENDIF +! + ENDDO + + WD1(NOP(N,2))=(WD1(NOP(N,1))+WD1(NOP(N,3)))/2. +! + ELSE + DO J=1,NCORN(N) + WD1(NOP(N,J))=WD(NOP(N,J)) + ENDDO + ENDIF + ENDIF + ENDDO + + RETURN + END + + SUBROUTINE WRTCRS(ICROUT,CRSTIT) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! COMMON/ICN1/ ICN(MAXP) + + + CHARACTER*8 ID1,ENDDAT + CHARACTER*72 CRSTIT + +!IPK JUN06 + DATA VOIDCRP/-1.E14/ + + DO J=1,MAXP + ICN(J)=0 + END DO +! First sort out the potential midsides +! Note that transition elements caues a problem +! Find these first + DO 200 N=1,NE + if(NCORN(N) .GT. 5) GO TO 200 + IF(NCORN(N) .EQ. 5 .AND. IMAT(N) .LT. 901) THEN +! +! We have a transition mark node number as if it were corner +! + ICN(NOP(N,3))=1 + ICN(NOP(N,1))=2 + ICN(NOP(N,4))=2 + ICN(NOP(N,5))=2 + ELSE +! +! Store ICN = 2 for corner nodes +! + NCN=NCORN(N) +!IPKOCT93 IF(IMAT(N) .GT. 900) THEN + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) THEN + MST=1 + ELSE + MST=2 + ENDIF + + DO 180 M=1,NCN,MST + + ICN(NOP(N,M))=2 + 180 CONTINUE + ENDIF + 200 END DO + ID1='TC ' + WRITE(ICROUT,'(A8,A72)') ID1,CRSTIT + + + DO N=1,NCRSEC +!ipk jun06 +!! IF(NRIVL(N) .GT. 0) THEN + ID1='RCH ' + WRITE(ICROUT,'(A8,I8)') ID1,NOREACH(IVMIL(N)) + ID1='ICS ' +!! write(icrout,'(A8,2I8,8x,2f16.4)') ID1,IVMIL(N),NRIVL(N),XCRS(N),YCRS(N) +!!jul15 write(icrout,'(A8,2I8,8x,2f16.4)') ID1,N,NRIVL(N),XCRS(N),YCRS(N) + write(icrout,'(A8,2I8,8x,2f16.4)') ID1,IVMIL(N),NRIVL(IVMIL(N)),XCRS(IVMIL(N)),YCRS(IVMIL(N)) + ID1='CRS ' + DO I=1,NRIVL(IVMIL(N)) + if(crsdat(IVMIL(N),i,2) .gt. 999999.) then + WRITE(ICROUT,'(A8,3F8.0)') ID1,(CRSDAT(IVMIL(N),I,J),J=1,3) + elseif(crsdat(IVMIL(N),i,2) .gt. 99999.) then + WRITE(ICROUT,'(A8,3F8.1)') ID1,(CRSDAT(IVMIL(N),I,J),J=1,3) + else + WRITE(ICROUT,'(A8,3F8.2)') ID1,(CRSDAT(IVMIL(N),I,J),J=1,3) + endif + ENDDO +!ipk jun06 +!! ENDIF + ENDDO + + + DO N=1,NCRSEC +!ipk jun06 + IF(XCRS(N) .GT. VOIDCRP) THEN + ID1='XYL ' + WRITE(ICROUT,'(A8,I8,2F16.4)') ID1,IVMIL(N),XCRS(IVMIL(N)),YCRS(IVMIL(N)) +!ipk jun06 + ENDIF + ENDDO + + ID1='CRF ' + DO N=1,NP + IF(ICN(N) .EQ. 2) THEN + IF(NRIVCR1(N) .GT. 0) THEN + WRITE(ICROUT,'(A8,2I8,F8.4,I8,F8.4)') ID1,N& + ,NRIVCR1(N),WTRIVCR1(N)& + ,NRIVCR2(N),WTRIVCR2(N) + ENDIF + ENDIF + ENDDO + + ENDDAT='ENDDATA ' + WRITE(ICROUT,'(A8)') ENDDAT + RETURN + END + + diff --git a/src/src83e/GETEQ1.F90 b/src/src83e/GETEQ1.F90 new file mode 100644 index 0000000..461efc4 --- /dev/null +++ b/src/src83e/GETEQ1.F90 @@ -0,0 +1,485 @@ +!IPK LAST UPDATE OCT 23 2015 ADD DECODAT OPTION FOR INPUT +!IPK LAST UPDATE nov 20 2014 IMPLEMENT BINARY FILE SAVE FOR ELEMENT INFLOW DATA +!IPK LAST UPDATE nov 17 2014 initialise TPRVH FOR ALL TYPES +!IPK last update oct 22 2012 initialize TPRVH +!IPK LAST UPDATE MAY 04 2011 FIX BUG CAUSED WHEN SPANNING MULTIPLE FILES +!IPK LAST UPDATE SEPT 3 2007 ADD FULL DATE TO INPUT +!IPK last update sept 01 2007 permit comma delimited entry of data +!IPK LAST UPDATE SEP 06 2004 ADD ERROR FILE +! Last change: IPK 19 Sep 2000 11:44 am +!IPK LAST UPDATE APR 16 1997 +!IPK last update Jan 23 1996 +!IPK last update jan 9 1996 + SUBROUTINE GETEQ +!IPK APR97 SAVE + + use winteracter + USE BLKELTLD + + include 'D.inc' +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE +!IPK AUG05 SAVE + INTEGER JCNV(12) + CHARACTER*32 FNAM + CHARACTER*8 ID + CHARACTER*80 QHTITLE,DLIN + CHARACTER*10 DATE + character*255 fnamein,filter +!IPK oct 12 add initial value + data tprvh/0./,ITIME/0/ + DATA JCNV/0,31,59,90,120,151,181,212,243,273,304,334/ + LOGICAL OPENED + IF(ITIME .EQ. 0) THEN + DAYOFY=-9999 + ITIME=1 + IQEUNIT=0 + IBINEL=0 + IRMATYP=10 + NQHYD=0 + NQP=0 + ENDIF + call wdialogload(IDD_CHOOSEMODEL) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_CHOOSEMODEL) + ierr=infoerror(1) + + call wdialogputRadioButton(idf_radio1) + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ntyp) + + GO TO 50 + ENDIF + + enddo + +50 CONTINUE + IF(NTYP .EQ. 1) IRMATYP=2 + IF(NTYP .EQ. 2) IRMATYP=10 + IF(NTYP .EQ. 3) THEN + IRMATYP=11 + NQP=1 + call wdialogload(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogPutString(IDF_STRING1,'NUMBER OF WQ GRAPH ENTRIES') + CALL WDialogPutInteger(IDF_INTEGER1,NQP) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetInteger(IDF_INTEGER1,NQP) + +! TEMPORARY LIMIT + IF(NQP .GT. 3) NQP=3 + + GO TO 70 + ELSE + RETURN + ENDIF + ENDDO + ENDIF + +!IPK NOV14 ADD IBINEL TO TEST + 70 CONTINUE + IF(IQEUNIT .EQ. 0 .and. ibinel .eq. 0) THEN + INQUIRE(201,opened= OPENED) + filter='Element Input files|*.elt;*.elf;*.dat;*.txt;*.grh|All files --|*.*|' + IF( .NOT. OPENED) THEN + CALL WSelectFile(filter,PromptOn+DirChange,FNAMEIN,'Element Load File Name') + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + OPEN(201,FILE=FNAMEIN,STATUS='OLD') + ELSE + RETURN + ENDIF + ENDIF + IQEUNIT=201 + ENDIF + IF(NQHYD .EQ. 0) THEN + +!IPK NOV14 READ AND ALLOCATE DATA FROM BINARY FILE + IF(IBINEL .GT. 0) THEN + TSTARTS=(DAYOFY-1)*24.+TIME-TETH + READ(IBINEL)NEDPTS,NQHYD,TSTARTKP,IYRKP + YEARC=0. + IF(IYRR .NE. IYRKP) THEN + IF(IYRR .GT. IYRKP) THEN + 80 CALL HRYRT(IYRKP,HRYR) + YEARC=YEARC+HRYR + IYRKP=IYRKP+1 + IF(IYRR .GT. IYRKP) GO TO 80 + ELSE + 90 CALL HRYRT(IYRKP,HRYR) + YEARC=YEARC-HRYR + IYRKP=IYRKP-1 + IF(IYRR .LT. IYRKP) GO TO 90 + ENDIF + ENDIF + ALLOCATE(DYE(NEDPTS,NQHYD),TAE(NEDPTS,NQHYD),HAE(NEDPTS,NQHYD),HDE(NEDPTS,NQHYD,3),ILAYRE(NEDPTS,NQHYD)) + do j=1,NQHYD + READ(IBINEL) NCLINE(j),NEST(j),IYDATE(j),NHYE(J) + READ(IBINEL) (DYE(I,j),TAE(I,j),HAE(I,j),I=1,nedpts) + DO I=1,NEDPTS + TAE(I,J)=TAE(I,J)+TSTARTKP-TSTARTS-YEARC + ENDDO + enddo + GO TO 199 + ENDIF +!IPK NOV14 END UPDATE + NEDPTS=0 + CALL ALLOCFL(NEDPTS,NELDS,IQEUNIT,3) +! +! set starting time in hours of the year +! teth contains the first time step + + 95 READ(IQEUNIT,'(A8,A72)') ID,QHTITLE +!IPK sep07 CHECK FOR COMMA'S + 98 IFREE=0 + DO K=1,8 + IF(ID(K:K) .NE. ',') THEN + IFREE=0 + ELSE + KFIRST=K+1 + IFREE=1 + GO TO 99 + ENDIF + ENDDO + 99 IF(IFREE .EQ. 1) THEN + QHTITLE=ID(KFIRST:8)//QHTITLE(1:71+KFIRST) + ENDIF + READ(IQEUNIT,'(A8,A72)') ID,DLIN + IF(ID(1:3) .EQ. 'QEI' .OR. ID(1:3) .EQ. 'QT ') THEN + 101 NQHYD=NQHYD+1 +!IPK sep07 CHECK FOR COMMA'S +!IPK nov14 initialise TPRVH + tprvh=0 + IFREE=0 + DO K=1,8 + IF(ID(K:K) .NE. ',') THEN + IFREE=0 + ELSE + KFIRST=K+1 + IFREE=1 + GO TO 102 + ENDIF + ENDDO + 102 IF(IFREE .EQ. 1) THEN + DLIN=ID(KFIRST:8)//DLIN(1:71+KFIRST) + ENDIF +!IPK APR97 TEST FOR LIMIT + IF(NQHYD .GT. NELDS) THEN +!IPK SEP04 + CLOSE(75) + OPEN(75,file='ERROR.OUT') + WRITE(75,*) 'ERROR STOP TOO MANY ELEMENT INFLOWS' + WRITE(*,*) 'ERROR STOP TOO MANY ELEMENT INFLOWS' + STOP 'ERROR STOP TOO MANY ELEMENT INFLOWS' + ENDIF + NHYE(NQHYD)=0 +!IPK sep07 + if(ifree .eq. 0) then + READ(DLIN,'(3I8,2F16.2)',ERR=801) NCLINE(NQHYD),NEST(NQHYD),IYDATE(NQHYD),XYCEL(NQHYD,1),XYCEL(NQHYD,2) + GO TO 811 +801 READ(DLIN,'(3I8)') NCLINE(NQHYD),NEST(NQHYD),IYDATE(NQHYD) +811 CONTINUE + else + READ(DLIN,*) NCLINE(NQHYD),NEST(NQHYD),IYDATE(NQHYD) + endif + IF(NCLINE(NQHYD) .EQ. 0) NCLINE(NQHYD)=-9999 +! + IYD=IYDATE(NQHYD) +!IPK may11 set IYDOLD + IYDOLD=IYD + DO 120 I=1,NEDPTS+1 + READ(IQEUNIT,'(A8,A72)') ID,DLIN +!IPK sep07 ADD QN + IF(ID(1:3) .EQ. 'TI ') GO TO 98 + IF(ID(1:3) .EQ. 'QEI' .OR. ID(1:3) .EQ. 'QT ') THEN +! NHYE(NQHYD)=NHYE(NQHYD)+1 +!IPK jan96 add day of year to logic +! DYE(NHYE(NQHYD),NQHYD)=1.E+6 +! TAE(NHYE(NQHYD),NQHYD)=1.E+8 +! HAE(NHYE(NQHYD),NQHYD)=HAE(NHYE(NQHYD)-1,NQHYD) + GO TO 101 + ELSEIF(ID(1:2) .EQ. 'QE' .OR. ID(1:2) .EQ. 'QN' .OR. ID(1:2) .EQ. 'QD' .or. ID(1:2) .EQ. 'QM') THEN +!IPK jan96 add day of year to logic +!IPK sep07 CHECK FOR COMMA'S + IFREE=0 + DO K=1,8 + IF(ID(K:K) .NE. ',') THEN + IFREE=0 + ELSE + KFIRST=K+1 + IFREE=1 + GO TO 105 + ENDIF + ENDDO + 105 IF(IFREE .EQ. 1) THEN + DLIN=ID(KFIRST:8)//DLIN(1:71+KFIRST) + ENDIF +!IPK sep07 ALLOW FOR QN + IF(ID(1:2) .EQ. 'QE' .OR. ID(1:2) .EQ. 'QD') THEN + IF(IFREE .EQ. 0) THEN + READ(ID(5:8),'(F4.0)') DYE(I,NQHYD) + IF(IRMATYP .EQ. 2) READ(DLIN,'(2F8.0)') TAE(I,NQHYD),HAE(I,NQHYD) + IF(IRMATYP .EQ. 10) READ(DLIN,'(F8.0,I8,4F8.0)') TAE(I,NQHYD),ILAYRE(I,NQHYD),HAE(I,NQHYD),(HDE(I,NQHYD,K),K=1,3) + IF(IRMATYP .EQ. 11) READ(DLIN,'(F8.0,4F8.0)') TAE(I,NQHYD),HAE(I,NQHYD),(HDE(I,NQHYD,K),K=1,NQP) + else + IF(IRMATYP .EQ. 2) READ(DLIN,*) TAE(I,NQHYD),HAE(I,NQHYD) + IF(IRMATYP .EQ. 10) READ(DLIN,*) DYE(I,NQHYD),TAE(I,NQHYD),ILAYRE(I,NQHYD),HAE(I,NQHYD),(HDE(I,NQHYD,K),K=1,3) + IF(IRMATYP .EQ. 11) READ(DLIN,*) TAE(I,NQHYD),HAE(I,NQHYD),(HDE(I,NQHYD,K),K=1,NQP) + endif +!IPK SEP07 ADD DATE INPUT + ELSE +!IPK oct15 add decodat option + IF(IFREE .EQ. 1) THEN + READ(DLIN,'(A10)') DATE + READ(DLIN(12:80),*) TAE(I,NQHYD),HAE(I,NQHYD) + READ(DATE,'(I2,1X,I2,1X,I4)') IDAYY,IMTHH,IYYR + DYE(I,NQHYD)=IDAYY+JCNV(IMTHH) + IF(MOD(IYYR,4) .EQ. 0 .AND. IYYR .NE. 2000) THEN + IF(IMTHH .GT. 2) DYE(I,NQHYD)=DYE(I,NQHYD)+1 + ENDIF + ELSE + CALL DECODDAT(DLIN,DYE(I,NQHYD),TAE(I,NQHYD)) + IF(IRMATYP .EQ. 2) READ(DLIN(17:24),'(F8.0)') HAE(I,NQHYD) + IF(IRMATYP .EQ. 10) READ(DLIN(17:64),'(I8,4F8.0)') ILAYRE(I,NQHYD),HAE(I,NQHYD),(HDE(I,NQHYD,K),K=1,3) + IF(IRMATYP .EQ. 11) READ(DLIN(17:64),'(4F8.0)') HAE(I,NQHYD),(HDE(I,NQHYD,K),K=1,NQP) + ENDIF +!IPK oct15 end decodat update + ENDIF + IF(DAYOFY .LT. 0) THEN + DAYOFY=DYE(I,NQHYD) + TSTARTS=(DAYOFY-1)*24. + IYRR=IYD + ENDIF + NHYE(NQHYD)=NHYE(NQHYD)+1 +! IF(I .EQ. 1) THEN +! +! reduce input time to time since that set to start simulation +! + 110 CONTINUE +! IF(MOD(IYD,4) .EQ. 0) THEN +! ILP=1 +! ELSE +! ILP=0 +! ENDIF +! IF(IYD .EQ. IYRR) THEN +! +! If now for for the same year +! + TCUR1=(DYE(I,NQHYD)-1.)*24.+TAE(I,NQHYD) +! +! set time as the difference +! + TAE(I,NQHYD)=TCUR1 +! WRITE(75,*) I,TAE(I,NQHYD),HAE(I,NQHYD) +! ELSEIF(IYD .LT. IYRR) THEN +! IF(MOD(IYD,4) .EQ. 0) THEN +! TPRVH=TPRVH+366.*24. +! ELSE +! TPRVH=TPRVH+365.*24. +! ENDIF +! IYD=IYD+1 +! GO TO 110 +! ELSE +!IPK SEP04 +! CLOSE(75) +! OPEN(75,file='ERROR.OUT') +!IPK SEP00 +! WRITE(*,*) ' Element inflows for wrong year' +! WRITE(*,*) ' Execution stopped' +! WRITE(75,*) ' Element inflows for wrong year' +! WRITE(75,*) ' Excution stopped' +! STOP +! ENDIF +! ELSE +!IPK may11 reset IYD +! IYD=IYDOLD +! IF(DYE(I,NQHYD) .LT. DYE(I-1,NQHYD)) THEN +! TCUR1=TCUR1-365.*24. +!IPK MAY11 IF(ILP .EQ. 1) TCUR1=TCUR1-24. +!IPK MAY11 IYD=IYD+1 +! IF(MOD(IYD,4) .EQ. 0) THEN +! ILP=1 +! ELSE +! ILP=0 +! ENDIF +!IPK may11 +! IYDOLD=IYDOLD+1 +! IF(ILP .EQ. 1) TCUR1=TCUR1-24. +! ENDIF +! TCUR=(DYE(I,NQHYD)-1.)*24.+TAE(I,NQHYD) +! TAE(I,NQHYD)=TAE(I-1,NQHYD)+TCUR-TCUR1 +! TCUR1=TCUR +! WRITE(75,*) I,TAE(I,NQHYD),HAE(I,NQHYD) +! ENDIF + ELSE +! NHYE(NQHYD)=NHYE(NQHYD)+1 +!IPK jan96 add day of year to logic +! DYE(NHYE(NQHYD),NQHYD)=1.E+6 +! TAE(NHYE(NQHYD),NQHYD)=1.E+8 +! HAE(NHYE(NQHYD),NQHYD)=HAE(NHYE(NQHYD)-1,NQHYD) +! IF(IRMATYP .EQ. 10) THEN +! DO K=1,3 +! HDE(NHYE(NQHYD),NQHYD,K)=HDE(NHYE(NQHYD)-1,NQHYD,K) +! ENDDO +! ENDIF + GO TO 199 + ENDIF + 120 CONTINUE +!IPK SEP04 + CLOSE(75) + OPEN(75,file='ERROR.OUT') +!IPK SEP00 + WRITE(*,*) 'Execution terminated more lines than allowed in element graph' + WRITE(75,*)'Execution terminated more lines than allowed in element graph' + stop + ENDIF + 199 continue + ENDIF +200 CONTINUE + CLOSE(IQEUNIT) + IQEUNIT=0 + + DO I=1,NQHYD + IF(XYCEL(I,1) .EQ. 0. .AND. XYCEL(I,2) .EQ. 0) THEN + JJ=NCLINE(I) + CALL GETXCL(JJ,XYCEL(I,1),XYCEL(I,2)) + ENDIF + ENDDO + RETURN + END + +!IPK NOV14 ADD LEAP YEAR ROUTINE + + SUBROUTINE HRYRT(IYRKP,HRYR) + + IF(MOD(IYRKP,4) .EQ. 0) THEN + ILP=1 + HRYR=366.*24. + ELSE + ILP=0 + HRYR=365.*24. + ENDIF + RETURN + END + +!IPK NEW WITH VERSION 9.0H OCT 25 2015 + +! DECODE JULIAN DAY FROM DAY/MONTH/YEAR DATA + + SUBROUTINE DECODDAT(DATAIN,DAYJUL,TIME) + CHARACTER*72 DATAIN + REAL DAYJUL,TIME + INTEGER IMTS(12,2),IDAY,IMO,IYR,HR,MIN + DATA IMTS/0,31,59,90,120,151,181,212,243,273,304,334,0,31,60,91,121,152,182,213,244,274,305,335/ +! +! LOOP THROUGH COLUMNS ADDING A COMMA + IDBLNK=0 + DO I=1,16 + IF(DATAIN(I:I) .EQ. ':') THEN + IHSW=0 + DATAIN(I:I)=',' + ELSEIF(DATAIN(I:I) .EQ. '.') THEN + IHSW=1 + ENDIF + IF(DATAIN(I:I) .EQ. '/') DATAIN(I:I)=',' + IF(I .GT. 8 .AND. DATAIN(I:I) .EQ. ' ') THEN + IF(IDBLNK .EQ. 0) THEN + DATAIN(I:I)=',' + IDBLNK=1 + IHSW=1 + ELSE + DATAIN(I:I)='0' + ENDIF + ENDIF + ENDDO +! write(155,*) ihsw,datain(1:16) + IF(IHSW .EQ. 0) THEN + READ(DATAIN(1:16),*) IDAY,IMO,IYR,HR,MIN + TIME=HR+MIN/60. + ELSE + READ(DATAIN(1:16),*) IDAY,IMO,IYR,TIME +! write(155,*) IDAY,IMO,IYR,TIME + ENDIF + IF(MOD(IYR,4) .EQ. 0) THEN + DAYJUL=IMTS(IMO,2)+IDAY + ELSE + DAYJUL=IMTS(IMO,1)+IDAY + ENDIF + RETURN + END + + SUBROUTINE ALLOCFL(MAXPT,MAXTYP,IUNIT,ITYP) + + USE BLKELTLD + + CHARACTER*8 ID + NELDS=200 + MAXPT=0 +!IPK JUN09 RESTORE MAXTYP1 + MAXTYP1=0 + NQLM=0 + 200 CONTINUE + + READ(IUNIT,'(A8)', END=500) ID +!IPK JUN09 ADD TO IF OPTIONS + IF(ID(1:2) .EQ. 'TT' .OR. ID(1:2) .EQ. 'TH' .OR. ID(1:2) .EQ. 'TE' .OR. ID(1:2) .EQ. 'TI' & + & .OR. ID(1:3) .eq. 'CLQ' .OR. ID(1:3) .eq. 'CLH' & + & .OR. ID(1:3) .eq. 'QEI' .OR. ID(1:3) .eq. 'QT ' & + & .OR. ID(1:3) .EQ. 'TIT' .OR. ID(1:3) .EQ. 'CTL') THEN +!IPK SEP14 ADD TYPE 4 (STAGE FLOW) OPTION +!IPK JUN09 RESTORE MAXTYP1 + MAXTYP1=MAXTYP1+1 +! MAXTYP1=MAXTYP1+1 +!IPK JUN09 IF(NQLM .GT. MAXQPT) MAXPT=NQLM + IF(NQLM .GE. MAXPT) MAXPT=NQLM+1 + NQLM=0 + GO TO 200 + ELSEIF(ID(1:6) .EQ. 'ENDDAT') THEN +!IPK JUN09 ADD TO NQLM + + IF(NQLM .GT. MAXPT) MAXPT=NQLM+1 + GO TO 500 + ELSE + NQLM=NQLM+1 + GO TO 200 + ENDIF + +500 CONTINUE +!IPK JUN09 + write(90,*) maxtyp,maxtyp1,maxpt,nelds + IF(MAXTYP1 .GT. MAXTYP) MAXTYP=MAXTYP1 + + ALLOCATE (TAE(MAXPT,MAXTYP),HAE(MAXPT,MAXTYP),DYE(MAXPT,MAXTYP),HDE(MAXPT,MAXTYP,3),ILAYRE(MAXPT,MAXTYP)) + ALLOCATE (NCLINE(NELDS),NHYE(NELDS),IYDATE(NELDS),NEST(NELDS),XYCEL(NELDS,2)) + TAE=0. + HAE=0. + HDE=0. + DYE=0. + XYCEL=0. + ILAYRE=0 + REWIND IUNIT + RETURN + END + \ No newline at end of file diff --git a/src/src83e/GETNEWFIL.F90 b/src/src83e/GETNEWFIL.F90 new file mode 100644 index 0000000..f94d4af --- /dev/null +++ b/src/src83e/GETNEWFIL.F90 @@ -0,0 +1,779 @@ + SUBROUTINE GETNEWFIL(IIN,IGFG,ITRIAN,ISWT) + + INCLUDE 'BFILES.I90' + +! WRITE CURRENT DATA TO A SCRATCH FILE + + IF(IACTVFIL .GT. 0 .AND. ISWT .NE. -1) THEN + IFILOUT=IACTVFIL+50 + WRITE(90,*) 'INGETNEWFIL IFILOUT',IFILOUT + CALL WRTFIL(IFILOUT) + CALL ZEROOUT + IACTVFIL=ITOTFIL + ELSEIF(IACTVFIL .EQ. 0) THEN + IACTVFIL=1 + ENDIF + IF(ISWT .EQ. 1) THEN + ITOTFIL=ITOTFIL+1 + FNAMKEP='TEST.1.ELE' + IACTVFIL=ITOTFIL + FNAMEOUT(IACTVFIL)='TEST.1.ELE' + WRITE(90,*) 'ITOTFIL,IACTVFIL',ITOTFIL,IACTVFIL + WRITE(90,'(A80)') (FNAMEOUT(KKK),KKK=1,3) + ELSE + FNAMKEP='TEST.1.ELE' + ENDIF + IF(ABS(ITRIAN) .EQ. 1) THEN + CALL READGFG(IIN,ITRIAN) + +! TEST FOR GFG FORMAT + ELSEIF(IGFG .EQ. 1) THEN + CALL READGFG(IIN,0) + +! TEST FOR rm1 FORMAT + + ELSEIF(IIN .EQ. 10) THEN + CALL READRM1(IIN) + +! TEST FOR rm1 FORMAT + +!ipk feb08 replace iin of 11 with 12 + ELSEIF(IIN .EQ. 12 .and. IGFG .EQ. 0) THEN + CALL READGEO(IIN) + + ELSEIF(IIN .EQ. 12 .and. IGFG .EQ. 2) THEN + CALL RDBIN(IIN) + + ENDIF + IF(ITRIAN .EQ. -1) RETURN + + IFILOUT=IACTVFIL+50 + WRITE(90,*) 'IFILOUT', IFILOUT + CALL WRTFIL(IFILOUT) + IACTVFIL=1 + CALL LOADFIL + + + CALL RESCAL + CALL HEDR + + + RETURN + END + +! Write data to a file + SUBROUTINE WRTFIL(IFILOUT) + + USE BLK1MOD + CHARACTER*80 ALINE + CHARACTER*10 FMT +! INCLUDE 'BLK1.COM' + + CLOSE (IFILOUT) + FMT(1:8)='TEMPFIL.' + WRITE(FMT(9:10),'(I2)') IFILOUT +! OPEN(IFILOUT,STATUS='scratch',FORM='binary') + WRITE(90,*) 'IFILOUT',IFILOUT +! OPEN(IFILOUT,STATUS='scratch',FORM='unformatted') + OPEN(IFILOUT,FILE=FMT,STATUS='UNKNOWN',FORM='BINARY') + + ISLP=0 + IPRT=1 + IPNN=1 + IPEN=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=10. + VERT=8. + XSALE=0. + YSALE=0. + XFACT=0. + YFACT=0. + AR=0. + ANG=0. + xadded=0. + yadded=0. + ntempin=0. + WRITE(90,*) 'IN WRTFIL', IFILOUT,NP,NE,IPRT + WRITE(IFILOUT) TITLE,NP,NE + WRITE(IFILOUT) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin + WRITE(90,*) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin + WRITE(IFILOUT) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + WRITE(90,*) 'IPP',IPP + IF(IPP .GT. 0) WRITE(IFILOUT) ALINE + + WRITE(IFILOUT) ((NOP(J,K),K=1,8),IMAT(J),THTA(J),J=1,NE) + WRITE(IFILOUT) & + (XUSR(J),YUSR(J),WD(J),WIDTH(J),SS1(J),SS2(J),WIDS(J), & + & WIDBS(J),SSO(J),BS1(J),J=1,NP) + + WRITE(IFILOUT) NLST + IF(NLST .GT. 0) THEN + WRITE(IFILOUT) (LLIST(J),J=1,NLST), & + & ((ILIST(J,I),I=1,LLIST(J)),J=1,NLST) + ENDIF + + WRITE(IFILOUT) NENTRY,NLAYD,NCLM + + IF(NENTRY .GT. 0) THEN + WRITE(IFILOUT) ((NEF(I,J),J=1,3),I=1,NENTRY) + ENDIF + + IF(NLAYD .GT. 0) THEN + WRITE(IFILOUT) (LAY(I),I=1,NP) + ENDIF + + IF(NCLM .GT. 0) THEN + WRITE(IFILOUT) ((ICCLN(I,J),J=1,350),I=1,NCLM) + ENDIF + REWIND IFILOUT + RETURN + END + + SUBROUTINE READRM1(IIIN) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*48 DLIN + + IIN=IIIN +! Read in header lines + + ISET=1 + WRITE(90,*) 'GOING TO HEADIN' + CALL HEADIN(IIN,ISET) + +! Read in existing elements + WRITE(90,*) 'GOING TO RDELEM' + CALL RDELEM(IIN) + +! Read in nodal coordinates + + WRITE(90,*) 'GOING TO RDCORD' + CALL RDCORD(IIN) + +! Close input file + + CLOSE(IIN) + +! Scale for plotting + + IF(NP .GT. 0) THEN + DO J=1,NP + IF (CORD(J,1) .GT. VDX) THEN + XMIN=MIN(XMIN,CORD(J,1)) + XMAX=MAX(XMAX,CORD(J,1)) + YMIN=MIN(YMIN,CORD(J,2)) + YMAX=MAX(YMAX,CORD(J,2)) + ENDIF + ENDDO + ENDIF + + RETURN + END + +! Read GEO file + SUBROUTINE READGEO(IIIN) + USE BLK1MOD + CHARACTER*1000 HEADER + CHARACTER*8 ID8 + CHARACTER*32 IJNK + CHARACTER*80 ALINE,DLIN +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' + + INTEGER*2 NOP2(MAXE,8) + + + IIN=IIIN + read(iin,err=100) header + if(header(1:6) .eq. 'RMAGEN') then + inopt=2 + else + inopt=1 + rewind iin + endif + read(iin) n1,m1 + rewind iin + write(90,*) 'Apparent nodes and elements from file are' + write(90,'(i15,i10)') n1,m1 + if(n1 .gt. maxp .or. m1 .gt. maxe) then +! +!...... Perhaps the file format is wrong, close and reopen +! + WRITE(DLIN,'(A32)') 'Parameter limits may be violated' + call symbl(0.5,4.5,0.20,dlin,0.0,32) + WRITE(DLIN,'(A35)') 'Retrying with alternate file format' + call symbl(0.5,4.2,0.20,dlin,0.0,35) + close (iin) + open(iin ,file=fnamkep,status='old',form='unformatted') + read(iin) n1,m1 + write(90,*) 'Revised nodes and elements from file are' + write(90,'(i15,i10)') n1,m1 + if(n1 .gt. maxp .or. m1 .gt. maxe) then + WRITE(DLIN,'(A31)') 'Parameter limits still violated' + call symbl(0.5,3.9,0.20,dlin,0.0,31) + WRITE(DLIN,'(A27)') 'Apparent nodes and elts are' + call symbl(0.5,3.6,0.20,dlin,0.0,27) + WRITE(DLIN,'(2i10)') n1,m1 + call symbl(0.5,3.3,0.20,dlin,0.0,20) + WRITE(DLIN,'(A24)') 'Press enter to terminate' + call symbl(0.5,4.5,0.20,dlin,0.0,24) + CALL GTCHARX(ijnk,ndig,5.0,4.0) +!cipk aug00 read(*,'(i1)') junk + call quit_pgm + endif + endif + rewind iin +! +! + if(inopt .eq. 2) then + read(iin,err=100) header + READ(IIN,ERR=100) & + & N1,M1,((CORD(J,K),K=1,2),ALPHA,WD(J),J=1,N1), & + & ((NOP(J,K),K=1,8),IMAT(J),THTA(J),I3,J=1,M1) & + & , (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,N1) + DO J=1,N1 + XUSR(J)=CORD(J,1) + YUSR(J)=CORD(J,2) + ENDDO +! + else + READ(IIN,ERR=100) & + & N1,M1,((CORDSN(J,K),K=1,2),ALPHA,WD(J),J=1,N1), & + & ((NOP2(J,K),K=1,8),IMAT(J),THTA(J),I32,J=1,M1) & + & , (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,N1) + DO J=1,N1 + DO K=1,2 + CORD(J,K)=CORDSN(J,K) + ENDDO + XUSR(J)=CORD(J,1) + YUSR(J)=CORD(J,2) + ENDDO + DO J=1,M1 +!ipk feb08 + ncorn(j)=0 + DO K=1,8 + NOP(J,K)=NOP2(J,K) +!ipk feb08 + if(nop(j,k) .gt. 0) ncorn(j)=k + ENDDO + ENDDO + endif + read(IIN,err=120,end=120) id8 + if(id8(1:6) .eq. 'part-2') then + read(IIN,err=104) (widbs(j),sso(j),j=1,n1) + read(IIN,err=120,end=120) id8 + endif + +! Add part 3 write for continuity lines + if(id8(1:6) .eq. 'part-3') then + +!ipk aug02 IF(NCLM .GT. 0) THEN + READ(IIN,ERR=104) NCLM,((ICCLN(I,J),J=1,350),I=1,NCLM) +!ipk aug02 ENDIF + read(IIN,err=120,end=120) id8 + endif +!IPK DEB02 Add part 4 write for lock and BS1 lines and reordering + if(id8(1:6) .eq. 'part-4') then + read(iin,err=104,end=120) (lock(j),bs1(j),j=1,n1) + read(iin,err=104,end=120) & + nlst,((ilist(j,k),k=1,maeln),llist(j),j=1,maxln) + endif + DO J=1,M1 +!ipk feb08 + ncorn(j)=0 + DO K=1,8 +!ipk feb08 + if(nop(j,k) .gt. 0) ncorn(j)=k + ENDDO + ENDDO + + GO TO 120 + + 100 READ(IIN,ERR=104) & + & N1,M1,((CORDSN(J,K),K=1,2),ALPHA,WD(J),J=1,N1), & + & ((NOP2(J,K),K=1,8),IMAT(J),THTA(J),I32,J=1,M1) + DO J=1,N1 + DO K=1,2 + CORD(J,K)=CORDSN(J,K) + ENDDO + XUSR(J)=CORD(J,1) + YUSR(J)=CORD(J,2) + ENDDO + DO J=1,M1 +!ipk feb08 + ncorn(j)=0 + DO K=1,8 + NOP(J,K)=NOP2(J,K) +!ipk feb08 + if(nop(j,k) .gt. 0) ncorn(j)=k + ENDDO + ENDDO + GO TO 120 + + 104 WRITE(90,*) 'Error reading binary geometry file' +!ipk jan98 CALL SETD(23) + call clscrn() + WRITE(aline,*) 'Error reading binary geometry file' + call symbl & + & (1.1,3.3,0.20,aline,0.0,80) + WRITE(aline,*) 'Press enter to exit' + call symbl & + & (1.1,3.0,0.20,aline,0.0,80) + ndig=1 + CALL GTCHARX(IJNK,NDIG,5.0,7.6) + CALL Quit_Pgm + STOP + + 120 CONTINUE + NP=N1 + NE=M1 + +! Close input file + + CLOSE(IIN) + +! Scale for plotting + + IF(NP .GT. 0) THEN + DO J=1,NP + IF (CORD(J,1) .GT. VDX) THEN + XMIN=MIN(XMIN,CORD(J,1)) + XMAX=MAX(XMAX,CORD(J,1)) + YMIN=MIN(YMIN,CORD(J,2)) + YMAX=MAX(YMAX,CORD(J,2)) + ENDIF + ENDDO + ENDIF + RETURN + + END + + SUBROUTINE READGFG(IUNIT,ISW) + + USE BLK1MOD + INCLUDE "BFILES.I90" +! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' + CHARACTER*1 ANS + CHARACTER*32 ANS32 + CHARACTER*3 ID + CHARACTER*77 DLIN + CHARACTER*150 DLIN1 + CHARACTER*80 LIND + DIMENSION NTMP(9),NTEMPLIN(200,10),ATT(9) + + REAL*8 CX,CY,VALS(7) + + MEL=MAXE + ylv=7.5 + IIN=IUNIT + IPRT=1 + IPNN=1 + IPEN=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=10. + VERT=8. + XSALE=0. + YSALE=0. + XFACT=0. + YFACT=0. + AR=0. + ANG=0. + xadded=0. + yadded=0. + ntempin=0. + KLIN=0 + IF(ABS(ISW) .EQ. 1) GO TO 500 + DO I=1,10000 + READ(IIN,'(A3,A77)') ID,DLIN + IF(ID .EQ. 'T1 ') THEN + TITLE(1:77)=DLIN + GO TO 10 + ENDIF + ENDDO + 10 CONTINUE + REWIND IIN + +! READ ELEMENT AND CCLINE DATA + + 20 CONTINUE + DO ICOUNTC=1,200000 + DO JJ=1,150 + DLIN1(JJ:JJ)=' ' + ENDDO + READ(IIN,'(A3,A150)', END=175) ID,DLIN1 + IF(ID .EQ. 'GE ' .or. ID .EQ. 'GO') THEN +! Count the number of variables + I=0 + ICOUNT=0 + 25 CONTINUE + IF(DLIN1(I+1:I+1) .NE. ' ') THEN + GO TO 30 + ELSE + I=I+1 + GO TO 25 + ENDIF + 30 I=I+1 + IF(I .EQ. 151) THEN + ICOUNT =ICOUNT+1 + GO TO 40 + ENDIF + IF(DLIN1(I:I) .EQ. ' ' .OR. DLIN1(I:I) .EQ. ',') THEN + ICOUNT=ICOUNT+1 + 35 CONTINUE + IF(I+1 .EQ. 151) GO TO 40 + IF(DLIN1(I+1:I+1) .EQ. ' ') THEN + I=I+1 + GO TO 35 + ELSE + GO TO 30 + ENDIF + ELSE + GO TO 30 + ENDIF + ENDIF + ENDDO + 40 CONTINUE + IF(ID .EQ. 'GO') THEN + KLIN=KLIN+1 + READ(DLIN1,*) (NTEMPLIN(KLIN,K),K=1,ICOUNT) + GO TO 20 + ENDIF + IF(ICOUNT .GT. 10) THEN + READ(DLIN1,*) J, (NTMP(K),K=1,9),THT + ELSE + READ(DLIN1,*) J, (NTMP(K),K=1,9) + ENDIF + + + IF (J .GE. MEL) THEN + CALL SETD(23) +!cipk aug00 + WRITE(lind,*) ' Element number exceeds MAXE in RDELEM' + call symbl (1.1,ylv-0.3,0.20,lind,0.0,80) + ndig=1 + WRITE(90,*) ' Element number exceeds MAXE in RDELEM' + WRITE(lind,6000) + CALL GTCHARX(ANS32,IJNK,5.0,4.0) + CALL Quit_Pgm + STOP + ENDIF +! +! Check to ensure there are no duplicate numbers in input stream +! of element connections +! + DO K=1,7 + IF(NTMP(K) .NE. 0) THEN + DO L=K+1,8 + IF(NTMP(K) .EQ. NTMP(L)) THEN + CALL SETD(23) + DO KK=1,8 + NOP(J,KK) = NTMP(KK) + ENDDO + IMAT(J)=NTMP(9) + call eltdisp(j) + DO KK=1,8 + NTMP(KK) = NOP(J,KK) + ENDDO + NTMP(9)=IMAT(J) + GO TO 45 + ENDIF + ENDDO + ENDIF + ENDDO + 45 CONTINUE + DO K=1,8 + NOP(J,K) = NTMP(K) + ND = NTMP(K) + IF (ND .GT. 0) THEN + INEW(ND) = 2 + NP = MAX(NP,ND) + ENDIF + ENDDO +! + NCN = 2 + IF (NOP(J,3) .NE. 0) NCN = 3 + IF (NOP(J,4) .NE. 0) NCN = 4 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .NE. 0) NCN = 5 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .EQ. 0) NCN = 6 + IF (NOP(J,6) .NE. 0) NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + NCORN(J) = NCN + IESKP(J) = 0 + IMAT(J) = NTMP(9) + THTA(J)=THT + IEM(J) = J + DO 50 K=2,NCN,2 + ND = NTMP(K) + IF (ND .GT. 0) THEN + IF(NCN .EQ. 5 .AND. K .EQ. 4) GO TO 50 + WD(ND)=0. + ENDIF + 50 CONTINUE + NE = MAX(J,NE) +! + GOTO 20 +! + 175 CONTINUE + + REWIND IIN + 70 CONTINUE + DO ICOUNTC=1,100000 + DO JJ=1,150 + DLIN1(JJ:JJ)=' ' + ENDDO + READ(IIN,'(A3,A150)', END=400) ID,DLIN1 + IF(ID .EQ. 'GNN' .OR. ID .EQ. 'GWN') THEN +! Count the number of variables + I=0 + ICOUNT=0 + 75 CONTINUE + IF(DLIN1(I+1:I+1) .NE. ' ') THEN + GO TO 80 + ELSE + I=I+1 + GO TO 75 + ENDIF + 80 I=I+1 + IF(I .EQ. 151) THEN + ICOUNT =ICOUNT+1 + GO TO 90 + ENDIF + IF(DLIN1(I:I) .EQ. ' ' .OR. DLIN1(I:I) .EQ. ',') THEN + ICOUNT=ICOUNT+1 + 85 CONTINUE + IF(I+1 .EQ. 151) GO TO 90 + IF(DLIN1(I+1:I+1) .EQ. ' ') THEN + I=I+1 + GO TO 85 + ELSE + GO TO 80 + ENDIF + ELSE + GO TO 80 + ENDIF + ENDIF + ENDDO + 90 CONTINUE + DO K=1,7 + VALS(K)=0. + ENDDO + READ(DLIN1,*) J,(VALS(K),K=1,ICOUNT-1) + IF(ID .EQ. 'GNN') THEN + CX=VALS(1) + CY=VALS(2) + BELEV=VALS(3) + NP = MAX(NP,J) + CORD(J,1) = CX + CORD(J,2) = CY + XUSR(J) = CX + YUSR(J) = CY + WD(J) = BELEV + INSKP(J)=0 + INEW(J) = 1 + GO TO 70 + ELSE + WDTHX=VALS(1) + SS1X=VALS(2) + SS2X=VALS(3) + WDSX=VALS(4) + WIDTH(J)=WDTHX + SS1(J)=SS1X + SS2(J)=SS2X + WIDS(J)=WDSX + GO TO 70 + ENDIF + + 400 CONTINUE + +! CHECKOUT THE CCLINE DATA + + KK=0 + IF(KLIN .GT. 0) THEN + NCLM=1 + IF(NTEMPLIN(1,1) .EQ. 1) THEN + DO K=1,KLIN + DO J=1,10 + IF(K .EQ. 1 .AND. J .EQ. 1) GO TO 410 + IF(NTEMPLIN(K,J) .LT. 0) THEN + NCLM=NCLM+1 + KK=0 + GO TO 420 + ELSEIF(NTEMPLIN(K,J) .EQ. 0) THEN + GO TO 420 + ELSE + KK=KK+1 + ICCLN(NCLM,KK)=NTEMPLIN(K,J) + ENDIF + 410 CONTINUE + ENDDO + 420 CONTINUE + ENDDO + NCLM=NCLM-1 + ENDIF + ENDIF + RETURN + +500 CONTINUE + IF(ISW .EQ. -1) THEN + NESV=NE + NPSV=NP + ENDIF + READ(IUNIT,*) NE,NCNTR,NATTR + IMIDS=0 + DO JJ=1,NE + READ(IUNIT,*) J,(NTMP(K),K=1,NCNTR),(ATT(K),K=1,NATTR) + IF(ISW .EQ. -1) J=J+NESV + IF (J .GE. MEL) THEN + CALL SETD(23) + WRITE(lind,*) ' Element number exceeds MAXE in RDELEM' + call symbl & + & (1.1,ylv-0.3,0.20,lind,0.0,80) + ndig=1 + WRITE(90,*) ' Element number exceeds MAXE in RDELEM' + WRITE(lind,6000) + CALL GTCHARX(ANS32,IJNK,5.0,4.0) + CALL Quit_Pgm + STOP + ENDIF + DO KK=1,3 + IF(ISW .EQ. -1) THEN + NOP(J,2*KK-1) = NTMP(KK)+NPSV + ELSE + NOP(J,2*KK-1) = NTMP(KK) + ENDIF + NOP(J,2*KK)=0 + ENDDO + IF(NATTR .GT. 0) THEN + IMAT(J)=ATT(1) + ELSE + IMAT(J)=1 + ENDIF + NCORN(J)=6 + IESKP(J)=0 + ENDDO + NE=J + CLOSE(IUNIT) + DO L=255,1,-1 + IF(FNAMKEP(L:L) .EQ. '.') THEN + FNAMKEP(L+1:L+4)='node' + OPEN(IUNIT,FILE=FNAMKEP,STATUS='OLD',ACTION='READ') + GO TO 510 + ENDIF + ENDDO +510 CONTINUE + + READ(IUNIT,*) NPPP,NDUM,NATTR + DO KK=1,NPPP + READ(IUNIT,*) J,CX,CY,(VALS(K),K=1,NATTR) + IF(ISW .EQ. -1) J=J+NPSV + IF(J .EQ. 0) THEN + J=NPPP + JZ=1 + ENDIF + BELEV=-9999. + WEL=0. + LOCK1=0 + IF(NATTR .GT. 0) BELEV=VALS(1) + IF (J .GE. MAXP) THEN + call clscrn() + WRITE(dlin,*) ' Node number exceeds MAXP in RDCORD',j + call symbl & + & (1.1,3.3,0.20,dlin,0.0,80) + WRITE(90,*) ' Node number exceeds MAXP in RDCORD' + WRITE(DLIN,*) ' Press enter to exit' + call symbl & + & (1.1,3.0,0.20,dlin,0.0,80) + ndig=1 + CALL GTCHARX(ANS32,ndig,5.0,4.0) + CALL Quit_Pgm + STOP + ENDIF + NP = MAX(NP,J) + XUSR(J) = CX + YUSR(J) = CY + CORD(J,1) = (XUSR(J)+XS)/TXSCAL + CORD(J,2) = (YUSR(J)+YS)/TXSCAL + WD(J) = BELEV + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. + WIDBS(J)=0. + SSO(J)=0. + INSKP(J)=0 + INEW(J) = 1 + LOCK(J)=LOCK1 + BS1(J)=0. + ENDDO + + CLOSE(IUNIT) + 6000 FORMAT(' Press enter to exit') + END + + + SUBROUTINE ZEROOUT + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + MNP = MAXP + MEL = MAXE + DO I=1,MEL + DO M=1,8 + NOP(I,M)=0 + ENDDO + IESKP(I)=-1 + IEM(I) = 0 + IMAT(I) = 0 + THTA(I)=0. + XC(I) = -1.E20 + YC(I) = -1.E20 + ENDDO + DO I=1,MNP + XUSR(I) = -1.D20 + YUSR(I) = -1.D20 + CORD(I,1) = -1.D20 + CORD(I,2) = -1.D20 + WD(I) = -9999. + LAY(I) = -9999 + WIDTH(I) = 0.0 + SS1(I) = 0.0 + SS2(I) = 0.0 + WIDS(I) = 0.0 + WIDBS(I)=0. + SSO(I)=0. + INSKP(I) = 1 + INEW(I) = 0 +!ipk mar02 + lock(i)=0 + bs1(I)=0. + ENDDO + NP=0 + NE=0 + RETURN + END + diff --git a/src/src83e/GETPGRP.F90 b/src/src83e/GETPGRP.F90 new file mode 100644 index 0000000..bda8585 --- /dev/null +++ b/src/src83e/GETPGRP.F90 @@ -0,0 +1,109 @@ + SUBROUTINE GETGRP + + USE BLK1MOD + + CHARACTER*8 IDSAV,ID + CHARACTER*72 DLINSAV,DLIN + + IDSAV=ID + DLINSAV=DLIN + +! ALLOCATE ARRAY SIZES + + IF(.NOT. ALLOCATED(IGRPNUM)) THEN + ALLOCATE (IGRPNUM(25,MAXE),MAXENT(25)) + IGRPNUM=0 + ENDIF +! +! NOW READ DATA TO FILE + + CALL GINPT(IGRP,ID,DLIN) + IF(ID(1:3) .EQ. 'TIT') THEN + +! READ TITLE + + READ(DLIN,'(A72)') HEDR + CALL GINPT(IGRP,ID,DLIN) + ENDIF + MAXIGRP=0 + + 301 READ(DLIN,'(I8)') IGRPA + CALL GINPT(IGRP,ID,DLIN) + NL=1 + NH=9 + + 401 CONTINUE + IF(ID(1:3) .EQ. 'NGP') THEN + READ(DLIN,'(9I8)') (IGRPNUM(IGRPA,I),I=NL,NH) + CALL GINPT(IGRP,ID,DLIN) + IF(IGRPNUM(IGRPA,NH) .NE. 0) THEN + NL=NL+9 + NH=NH+9 + GO TO 401 + ENDIF + ENDIF + +! SET MAXIMA FROM INPUT FILE + + IF(MAXIGRP .LT. IGRPA) MAXIGRP=IGRPA + MAXENT(IGRPA)=NH + + IF(ID(1:3) .EQ. 'GRP') GO TO 301 + CALL TOSER + ID=IDSAV + DLIN=DLINSAV + CALL PLOTOT(1) + RETURN + END + + SUBROUTINE WRTGP + + USE WINTERACTER + USE BLK1MOD + include 'd.inc' + + CHARACTER(LEN=256) :: FILTER + CHARACTER(LEN=96) :: FNAME + LOGICAL :: OPENED + + IGRPOUT=29 + INQUIRE(29, OPENED=OPENED) + if(.not. opened) then + Filter='TXT file -- *.txt|*.txt|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Group File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + OPEN(IGRPOUT,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + ELSE + RETURN + ENDIF + ENDIF + CALL TOPAR + REWIND IGRPOUT + WRITE(IGRPOUT,'(a)') 'TIT GROUP FILE' + + DO K=1,25 + IF(MAXENT(K) .GT. 0) THEN + WRITE(IGRPOUT,6001) K + LROWS=MAXENT(K)/9+1 + LASTCOL=MOD(MAXENT(K),9) + IF(LASTCOL .EQ. 0) THEN + IF(IGRPNUM(K,MAXENT(K)) .EQ. 0) THEN + LROWS=LROWS-1 + ENDIF + ENDIF + NL=-8 + DO LL=1,LROWS + NL=NL+9 + NH=NL+8 + WRITE(IGRPOUT,6002) (IGRPNUM(K,L),L=NL,NH) + ENDDO + ENDIF + ENDDO + 6001 FORMAT('NGP ',I8) + 6002 FORMAT('GRP ',9I8) + RETURN + END + \ No newline at end of file diff --git a/src/src83e/GETSTRESSFIL.F90 b/src/src83e/GETSTRESSFIL.F90 new file mode 100644 index 0000000..57e2f70 --- /dev/null +++ b/src/src83e/GETSTRESSFIL.F90 @@ -0,0 +1,175 @@ + SUBROUTINE GETSTRESSFIL + USE WINTERACTER + USE BLK1MOD + include 'd.inc' + + ALLOCATABLE WDTEMP(:) + CHARACTER*256 FILTER,FNAME + INTEGER IYRR,IMON,IDAY + REAL HOUR + LOGICAL OPENED + DATA IYRR/2015/,IMON/1/,IDAY/1/ + DATA HOUR/0.0/ + + IF(.NOT. ALLOCATED(WDTEMP)) THEN + + ALLOCATE (WDTEMP(NP)) + ENDIF + DO N=1,NP + WDTEMP(N)=WD(N) + ENDDO + +100 CONTINUE + + ISWT=-1 + + IWRTMP=0 + IF(IMP .GT. 0) THEN +! FIRST WRITE EXISTING MAP TO SCRATCH + OPEN(98,FORM='BINARY',STATUS='SCRATCH') + + CALL WRTMAP(98) + REWIND 98 + IWRTMP=1 + ENDIF + CALL GMAP + + CALL GRIDSB(ISWT) + + INQUIRE(104, OPENED=OPENED) + IF(OPENED) GO TO 200 + Filter='Output file -- *.dat|*.dat|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Stress File') + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + IOT=104 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') + ELSE + GO TO 500 + ENDIF +200 CONTINUE + CALL SETDT(IYRR,IMON,IDAY,HOUR) + WRITE(IOT,'(''DATE '',3I8,F8.3)') IYRR,IMON,IDAY,HOUR + DO J=1,NP + IF (INEW(J) .EQ. 1) THEN + WRITE(IOT,'(''WAVESS '',I8,F8.4)') J,WD(J) + ENDIF + ENDDO + WRITE(IOT,'(''ENDBLOCK'')') + FLUSH(IOT) + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to process another map file?'//& + CHAR(13)//' ','PROCESS ANOTHER?') +! +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) THEN + WRITE(IOT,'(''ENDDATA'')') + FLUSH(IOT) + GO TO 500 + ENDIF + GO TO 100 +! +! Delete all unused nodes +! + CALL DELETM(2) + +500 DO N=1,NP + WD(N)=WDTEMP(N) + ENDDO + DEALLOCATE (WDTEMP) + IF(IWRTMP .GT. 0) THEN + + CALL RDMAP(2,98,0,0) + CLOSE (98) + ENDIF + + RETURN + END + + SUBROUTINE SETDT(N1,N2,N3,R1) + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR + real :: R1 + character*3 :: sub + + call wdialogload(IDD_SETYRDT) + ierr=infoerror(1) + + CALL WDialogPutInteger(idf_integer1,n1) + CALL WDialogPutInteger(idf_integer2,n2) + CALL WDialogPutInteger(idf_integer3,n3) + CALL WDialogPutReal(idf_real1,r1) + + CALL WDialogSelect(IDD_setyrdt) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(idf_integer1,n1) + CALL WDialogGetInteger(idf_integer2,n2) + CALL WDialogGetInteger(idf_integer3,n3) + CALL WDialogGetReal(idf_real1,r1) + RETURN + ENDIF + ENDDO + RETURN + END + + SUBROUTINE GMAP + USE WINTERACTER + + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB,SUB1 + INTEGER IMP + + CALL WSelectFile(ID_STRING1,PromptOn,FNAME,'Load Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'mpb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='unformatted',action='read') + ELSEIF(SUB .EQ. 'mbb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='binary',action='read') + ELSEIF(SUB .EQ. 'rm1') then + imp=13 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'shp') then + IMP=113 + OPEN(113,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + SUB='DBF' + CALL ADDSUB(FNAME,SUB) + OPEN(114,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + ENDIF + ENDIF + CALL RDMAP(2,IMP,0,0) + CLOSE (IMP) + RETURN + END \ No newline at end of file diff --git a/src/src83e/GETTRIANG.F90 b/src/src83e/GETTRIANG.F90 new file mode 100644 index 0000000..06f8e7a --- /dev/null +++ b/src/src83e/GETTRIANG.F90 @@ -0,0 +1,139 @@ +! Last change: IPK 2 Feb 2003 6:25 pm + SUBROUTINE DELAUNAY1(XMAP1,YMAP1,NVERT) + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*80 LIND + CHARACTER*1 ANS + REAL*8 XMAP1(*),YMAP1(*) + DATA VDX9/-9.E9/,NEDGE/0/ + +! Get location of supertriangle + + iprt=0 + ngap=0 + + + + call supert(XMAP1,YMAP1,NVERT) + + NELTS=1 + + NVERTM=NVERT-3 + +! Sort points into ascending x order + + CALL SORTDB(XMAP1,NKEY,NVERTM) + +! Loop on the vertices + + YLV=7.5 + DO NN=1,NVERT-3 + + + if(mod(NN,2500) .eq. 0) then + ylv=ylv-0.3 + if(ylv .lt. 0.1) then + ylv=7.9 + call clscrn + endif + write(lind,6010) NN + 6010 format(i8,' points processed') + call symbl & + & (1.1,ylv,0.20,LIND,0.0,80) + endif + +! process next point + + N=NKEY(NN) + +! Skip out if inactive point + IF(N .EQ. 0) GO TO 500 + IF(XMAP1(N) .LT. VDX9) GO TO 500 + + IF(NN .LT. NVERTM) THEN + DO KK=NN+1,NVERTM + K=NKEY(KK) + IF(K .NE. 0) THEN + IF(XMAP1(N) .EQ. XMAP1(K)) THEN + IF(YMAP1(N) .EQ. YMAP1(K)) THEN + WRITE(45,*) 'IDENT',N,K + NKEY(KK)=0 + ENDIF + ELSE + GO TO 200 + ENDIF + ENDIF + 200 CONTINUE + ENDDO + ENDIF + +! Set edge buffers to zero + + IF(NEDGE .GT. 0) THEN + DO J=1,NEDGE + IEDGE(J,1)=0 + IEDGE(J,2)=0 + END DO + ELSE + DO J=1,100 + IEDGE(J,1)=0 + IEDGE(J,2)=0 + END DO + ENDIF + NEDGE=0 + +! test for point in circumcircle + + DO J=1,NELTS + CALL INSIDCIRC(XMAP1,YMAP1,J,N,ISWT) + +! If inside process edges + + IF(ISWT .EQ. 1) THEN + CALL PROCESS(J,NEDGE,NGAP) + ENDIF + END DO + +! Setup to form new triangles + + CALL SETEDG(NEDGE) + +! Now form triangles as needed + + DO J=1,NEDGE + IF(IEDGE(J,1) .NE. 0) THEN + CALL FORMT(XMAP1,YMAP1,J,N,NGAP,KK) + ENDIF + END DO + + NEDGE=0 + if(iprt .eq. 0) go to 500 + DO J=1,NELTS + IF(NOPEL(J,1) .GT. 0) THEN + WRITE(3,'(2i5,2i10,19x,''1'')') J,(NOPEL(J,K),K=1,3) + ENDIF + END DO + + + IF(NN .EQ. 1) THEN + write(41,'('' 9999'')') + do j=1,nvert + write(41,'(i10,2f20.4,F10.3)') j,XMAP1(j),YMAP1(j),VAL(J) + enddo + write(41,'('' 9999'')') + write(41,'('' 9999'')') + write(41,'('' 0 NENTRY'')') + write(41,'('' 0 NCLM'')') + WRITE(41,'(''ENDDATA'')') + ENDIF + 500 continue + END DO + +! Get rid of elements from super point + + CALL RIDPOINT(NVERT) + + RETURN + END SUBROUTINE diff --git a/src/src83e/GETWT.F90 b/src/src83e/GETWT.F90 new file mode 100644 index 0000000..1d21ee1 --- /dev/null +++ b/src/src83e/GETWT.F90 @@ -0,0 +1,238 @@ + SUBROUTINE TRIANINT(NMAP,M,ISWT,ITIME) + + USE BLKMAP + USE BLK1MOD + SAVE +! INCLUDE 'BLK1.COM' + + DIMENSION WGT(8) + REAL*8 XMINL,YMINL,XMAXL,YMAXL +! data itime/0/ + +! LOOK FOR MATCHING POINTS + + DO K=1,MAXPTS + DISQ=(XUSR(M)-XMAP(K))**2+(YUSR(M)-YMAP(K))**2 + IF(DISQ .LT. 1.) THEN + WD(M)=VAL(K) + FPN = WD(M)*10. + X = CORD(M,1) + Y = CORD(M,2) - .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.5) THEN + CALL RRED + CALL NUMBR(X,Y,0.1,FPN,0.0,-1) + endif + GO TO 300 + ENDIF + ENDDO + +! Search for element that has circumcircle around the node + + IF(ISWT .NE. 0) THEN + IF(ITIME .EQ. 0) NSTART=1 + ELSE + NSTART=1 + ENDIF + DO N=NSTART,NELTS + IF(NOPEL(N,1) .EQ. 0) GO TO 200 + if(RADS(N) .eq. 0.) then + CALL CCENTRE(XMAP(NOPEL(N,1)),XMAP(NOPEL(N,2)),XMAP(NOPEL(N,3)) & + &,YMAP(NOPEL(N,1)),YMAP(NOPEL(N,2)),YMAP(NOPEL(N,3)) & + &,XCEN(N),YCEN(N),RADS(N)) + endif + + IF(RADS(N)+XCEN(N) .GE. XUSR(M)) THEN + NSTART=N + GO TO 210 + ENDIF + 200 CONTINUE + ENDDO + 210 CONTINUE + WRITE(155,*) M,NSTART + DO N=NSTART,NELTS + IF(NOPEL(N,1) .EQ. 0) GO TO 250 + if(RADS(N) .eq. 0.) then + CALL CCENTRE(XMAP(NOPEL(N,1)),XMAP(NOPEL(N,2)),XMAP(NOPEL(N,3)) & + &,YMAP(NOPEL(N,1)),YMAP(NOPEL(N,2)),YMAP(NOPEL(N,3)) & + &,XCEN(N),YCEN(N),RADS(N)) + endif + xminl=min(XMAP(NOPEL(N,1)),XMAP(NOPEL(N,2)),XMAP(NOPEL(N,3))) + xmaxl=max(XMAP(NOPEL(N,1)),XMAP(NOPEL(N,2)),XMAP(NOPEL(N,3))) + yminl=min(YMAP(NOPEL(N,1)),YMAP(NOPEL(N,2)),YMAP(NOPEL(N,3))) + ymaxl=max(YMAP(NOPEL(N,1)),YMAP(NOPEL(N,2)),YMAP(NOPEL(N,3))) +! IF(M .EQ. 6316) THEN +! WRITE(156,'(2I6,6F15.2)') M,N,XUSR(M),XMINL,XMAXL,YUSR(M),YMINL,YMAXL +! ENDIF + if(xusr(m) .lt. xminl-0.01 .or. xusr(m) .gt. xmaxl+0.01) then + go to 250 + elseif(yusr(m) .lt. yminl-0.01 .or. yusr(m) .gt. ymaxl+0.01) then + go to 250 + endif +! IF(M .EQ. 6316) WRITE(156,*) 'PASSED X AND Y TEST',N + + DISQ=(XUSR(M)-XCEN(N))**2+(YUSR(M)-YCEN(N))**2 + + IF(DISQ .LE. RADS(N)**2*1.0001) THEN + +! IF(M .EQ. 6316) write(156,*) m,n,disq,rads(n)**2,xusr(m),xcen(n) + +! We have a candidate + + CALL GETWT(N,XUSR(M),YUSR(M),WGT,1) + DO K=1,3 + IF(WGT(K) .LT. -1E-4 .OR. WGT(K) .GT. 1.0001) THEN + WRITE(142,*) 'REJECT',m,n,disq,rads(n)**2,wgt(1),wgt(2),wgt(3) + GO TO 250 + ENDIF + ENDDO + WD(M)=WGT(1)*VAL(NOPEL(N,1))+WGT(2)*VAL(NOPEL(N,2))+WGT(3)*VAL(NOPEL(N,3)) + FPN = WD(M)*10. + X = CORD(M,1) + Y = CORD(M,2) - .11 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.5) THEN + CALL RRED + CALL NUMBR(X,Y,0.1,FPN,0.0,-1) + endif + GO TO 300 + ENDIF + 250 CONTINUE + ENDDO + 300 CONTINUE + ITIME=1 + + RETURN + END + + + SUBROUTINE GETWT(N,XSW,YSW,WGT,ISWT) + +!- +!......SUBROUTINE TO EVALUATE FUNCTION AT GRID POINTS +!- +!- N = ELEMENT NUMBER +!_ XSW = X COORDINATE OF DESIRED POINT +!_ YSW = Y COORDINATE OF DESIRED POINT +! WGT(8) = ARRAY OF WEIGHTING FUNCTIONS +! ISWT = SWITCH FOR CHOICE BETWEEN LINEAR AND QUADRATIC WEIGHTING +! = 1 FOR LINEAR +! = 2 FOR QUADRATIC +! FROM COMMON +! NOP = LIST OF NODAL CONNECTIONS AROUND AN ELEMET +! CORD = REAL*8 ARRAY OF NODAL COORDINATES +! + USE BLKMAP + USE BLK1MOD + REAL*8 XN,DNX,DNY,XSW,YSW + DOUBLE PRECISION XG,YG,XK,YK,XP,YP +! INCLUDE 'BLK1.COM' +!- + DIMENSION X(9),Y(9),WGT(8) +!- + DATA TOL/0.01/ +!- + +!- +!......DETERMINE ELEMENT TYPE +!- +!IPKOCT93 ADD + if(n .eq. 1910) then + aaa=0 + endif + NCN=6 + IT=2 +!- +!......ESTABLISH LOCAL COORDINATES FOR EACH NODE POINT OF ELEMENT +!- + K1=NOPEL(N,1) + X(1)=0. + Y(1)=0. + DO 300 K=3,NCN,2 + K2=NOPEL(N,K/2+1) + X(K)=XMAP(K2)-XMAP(K1) + Y(K)=YMAP(K2)-YMAP(K1) + 300 END DO + X(2)=X(3)/2. + Y(2)=Y(3)/2. + X(4)=(X(3)+X(5))/2. + Y(4)=(Y(3)+Y(5))/2. + X(6)=X(5)/2. + Y(6)=Y(5)/2. + xminl=min(x(1),x(3),x(5)) + yminl=min(y(1),y(3),y(5)) + xmaxl=max(x(1),x(3),x(5)) + ymaxl=max(y(1),y(3),y(5)) + + +!- +!......ESTABLISH LOCAL COORDINATES OF DESIRED POINT +!- + XP=XSW-XMAP(K1) + YP=YSW-YMAP(K1) + + if(xp .lt. xminl .or. xp .gt. xmaxl) then + wgt(1)=2.0 + return + elseif(yp .lt. yminl .or. yp .gt. ymaxl) then + wgt(1)=2.0 + return + endif + XG=0. + YG=0. +!- +!......ITERATE TO FIND LOCAL COORDINATE +!- + DO 400 ITER=1,10 + DXKDX=0. + DXKDY=0. + DYKDX=0. + DYKDY=0. + XK=-XP + YK=-YP + DO 350 K=2,NCN + XK=XK+XN(IT,K,XG,YG)*X(K) + YK=YK+XN(IT,K,XG,YG)*Y(K) + DXKDX=DXKDX+DNX(IT,K,XG,YG)*X(K) + DYKDX=DYKDX+DNX(IT,K,XG,YG)*Y(K) + DXKDY=DXKDY+DNY(IT,K,XG,YG)*X(K) + DYKDY=DYKDY+DNY(IT,K,XG,YG)*Y(K) + 350 END DO + DET=DXKDX*DYKDY-DXKDY*DYKDX + DX=(-DYKDY*XK+DXKDY*YK)/DET + DY=( DYKDX*XK-DXKDX*YK)/DET + XG=XG+DX + YG=YG+DY + IF(ABS(DX).LT.TOL .AND. ABS(DY).LT.TOL) GO TO 420 + 400 END DO +!- +!......NOW GET WEIGHTING FUNCTIONS FOR QUAD FUNCTION +!- + 420 CONTINUE + DO K=1,NCN + WGT(K)=XN(IT,K,XG,YG) + END DO + + IF(ISWT .EQ. 1) THEN +!- +!- REDUCE TO LINEAR FUNCTION BY ADDING TERMS +!- + DO K=2,NCN,2 + WGT(K-1)=WGT(K-1)+WGT(K)/2. + IF(K .LT. NCN) THEN + WGT(K+1)=WGT(K+1)+WGT(K)/2. + ELSE + WGT(1)=WGT(1)+WGT(K)/2. + ENDIF + ENDDO +!- +!- THEN COMPACT ARRAY +!- + DO K=1,NCN/2 + WGT(K)=WGT(2*K-1) + ENDDO + + ENDIF + + RETURN + END diff --git a/src/src83e/GINPT.F90 b/src/src83e/GINPT.F90 new file mode 100644 index 0000000..9ee5ac7 --- /dev/null +++ b/src/src83e/GINPT.F90 @@ -0,0 +1,47 @@ + SUBROUTINE GINPT(irm2,ID,DLIN) + CHARACTER ID*8,DLIN*72 + 100 CONTINUE + READ(irm2,7000) ID,DLIN + write(90,7000) id,dlin +!ipk jul03 + call to_upper(id) + 7000 FORMAT(A8,A72) + do i=1,8 + if(id(i:i) .eq. char(9)) go to 200 + enddo + do i=1,72 + if(dlin(i:i) .eq. char(9)) go to 200 + enddo + IF(ID(1:1) .EQ. ':') GO TO 100 + IF(ID(1:1) .EQ. ';') GO TO 100 + IF(ID(1:3) .EQ. 'com') GO TO 100 + IF(ID(1:3) .EQ. 'COM') GO TO 100 + IF(ID(1:3) .EQ. 'Com') GO TO 100 + IF(ID(1:8) .EQ. ' ') GO TO 100 + RETURN + 200 continue + write(*,*) 'Error Tab character found in the following line' + write(90,*) 'Error Tab character found in the following line' + write(90,7000) id,dlin + write(*,7000) id,dlin + stop + END + + + SUBROUTINE TO_UPPER(STR) + + CHARACTER*(*) STR + CHARACTER*1 CH + + L = LEN(STR) + + DO I=1,L + CH = STR(I:I) + IF ( ICHAR(CH) .GT. 96 .AND. ICHAR(CH) .LE. 122) THEN + STR(I:I) = CHAR(ICHAR(CH)-32) + ENDIF + ENDDO + + END + + diff --git a/src/src83e/GOUTLIN.F90 b/src/src83e/GOUTLIN.F90 new file mode 100644 index 0000000..82de04a --- /dev/null +++ b/src/src83e/GOUTLIN.F90 @@ -0,0 +1,127 @@ + SUBROUTINE GOUTLIN + + USE WINTERACTER + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' + + CHARACTER(LEN=255) :: FNAME,FILTER + CHARACTER(LEN=4) :: SUB + LOGICAL OPENED + CHARACTER*1 IFLAG,ANS(10) +! DIMENSION XOUT(1000),YOUT(1000) + DATA ANS/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + + IF(.NOT. ALLOCATED(XOUT)) THEN + ALLOCATE (XOUT(5000,10),YOUT(5000,10)) + ENDIF + N=0 + IOUTOUT=25 + INQUIRE(25, OPENED=OPENED) + if(.not. opened) then + Filter='OUTLINE file -- *.dat|*.dat|POLY file -- *.poly|*.poly|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Outline File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(IOUTOUT,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + ELSE + GO TO 1 + ENDIF + ENDIF + + 1 CONTINUE + + IF(SUB(1:3) .EQ. 'dat') THEN + IOUTSW=0 + ELSE + IOUTSW=1 + ENDIF + +!IPK GET STRING OF MAP COORDINATES + +! +! Draw box around selections +! + 2 CONTINUE + + NHTPSV=NHTP + NMESSV=NMESS + NBRRSV=NBRR + + NHTP=0 + NBRR=1 + NMESS=45 + CALL HEDR +! +! Get answer +! +! 3 call xyloc(XPT,YPT,ANS,IBOX) + 3 call xyloc(XPT,YPT,IFLAG,IBOX) +! + IF(IRMAIN .NE. 1 .and. ibox .ne. 10) THEN + + N=N+1 + XTMP = XPT*TXSCAL - XS + YTMP = YPT*TXSCAL - YS + IF(IOUTSW .EQ. 0) THEN + WRITE(IOUTOUT,*) XTMP,YTMP + ELSE + XOUT(N,1)=XTMP + YOUT(N,1)=YTMP + ENDIF + GO TO 3 + + ENDIF + IF(IOUTSW .EQ. 1) THEN + NDIM=2 + NZERO=0 + NONE=1 + WRITE(IOUTOUT,*)N,NDIM,NZERO,NZERO + DO I=1,N + WRITE(IOUTOUT,*) I,XOUT(I,1),YOUT(I,1) + ENDDO + WRITE(IOUTOUT,*) N,NZERO + DO I=1,N-1 + WRITE(IOUTOUT,*) I,I,I+1 + ENDDO + WRITE(IOUTOUT,*) N,N,NONE + + WRITE(IOUTOUT,*) NZERO + ENDIF + NHTP=NHTPSV + NMESS=NMESSV + NBRR=NBRRSV + CALL HEDR + + + RETURN + END + + SUBROUTINE GETSUB4(FNAME,SUB) + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=4) :: SUB + INTEGER ,EXTERNAL :: LENSTR + INTEGER :: LNNAM,K + + LNNAM=LENSTR(FNAME) + SUB=' ' + DO K=LNNAM,1,-1 + IF(FNAME(K:K) .EQ. '.') THEN + IF(LNNAM .GT. K+3) THEN + SUB=FNAME(K+1:K+4) + ELSEIF(LNNAM .GT. K+2) THEN + SUB(1:3)=FNAME(K+1:K+3) + SUB(4:4)=' ' + ELSE + SUB=' ' + ENDIF + GO TO 110 + ENDIF + ENDDO +110 CONTINUE + RETURN + END diff --git a/src/src83e/GRIDSB.F90 b/src/src83e/GRIDSB.F90 new file mode 100644 index 0000000..fc0f780 --- /dev/null +++ b/src/src83e/GRIDSB.F90 @@ -0,0 +1,872 @@ +!IPK LAST UPDATE FEB 11 2002 ADD LOCK AS VARIABLE +!ipk last update Feb 10 1997 + SUBROUTINE GRIDSB(ISWTIN) +! +! Routines to control interpolation of nodal elevations +! + USE WINTERACTER + USE BLKMAP + USE BLK1MOD + + include 'd.inc' + +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' + +!iPK APR94 + COMMON /RECOD/ IRECD,TSPC + + +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! +!IPKJAN94 INTEGER*2 LISTM +! INTEGER LISTM +!ipk feb94 add ARF then remove may97 + +! DIMENSION LISTM(1000),listt(1600,4),nlf(4),icomp(4),xnear(4) +!ipk feb03 common /mapc/imap(maxpl),NCRS(MAXPL) +!ipk sep97 add NCRS above +! +!ipknov93 CHARACTER*1 ANS,ANSW(10) + CHARACTER*1 ANS,ANSW(10),IFLAG + CHARACTER*63 STRELS + DATA STRELS/' You have tried set to set elevation with no mapfile"'/ +! + DATA ANSW/'m','a','f','s','k','u','t','w','h','q'/ +!JUN08 DATA ISWTAGN/0/ +!ipk feb94 add DATA and FUNCTION below +! DATA ARF/-180.,-90.,0.,90.,180./ +! ANGN(K,L)= +! + ATAN2((CMAP(K,2)-CORD(L,2)),(CMAP(K,1)-CORD(L,1)))*57.296 +! +! Draw box around selections +! +!IPK SEP97 +100 CONTINUE + IDONET=0 + NHTP = 9 + NMESS = 0 + NBRR = 0 + IF(ISWTIN .EQ. -1) GO TO 190 + CALL HEDR +! +! Get answer +! + 110 call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(ANS .EQ. 'c') THEN + if(ibox .eq. 0) go to 110 + ANS=ANSW(IBOX) + ENDIF + IF(ANS .EQ. 'm') THEN +! +! This option allows changes to bottom elevations +! + CALL ADDPTH + IF(IRMAIN .EQ. 1) RETURN + GO TO 100 + + ELSEIF (ANS .EQ. 'a') THEN +! +! All nodes +! + ISWT = -1 + DO N=1,NP + IF(INEW(N) .EQ. 1) WD(N)=-9999. + ENDDO + ELSEIF(ANS .EQ. 'f') THEN +! +! Fill nodes +! + ISWT = 0 + ELSEIF(ANS .EQ. 's') THEN +! +! Single node at a time +! + ISWT = 1 + +!ipk feb02 add lock/unlock and remove cdata + + ELSEIF(ANS .EQ. 'k') THEN +! +! lock node +! +! Get M from mouse +! + 115 CONTINUE + NHTP=0 + NMESS=21 + NBRR=3 + CALL HEDR + IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,M,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + if(iflag .eq. 'q') go to 100 + lock(m)=1 + go to 115 + ELSEIF(ANS .EQ. 'u') THEN +! +! unlock node +! +! Get M from mouse +! + 120 CONTINUE + NHTP=0 + NMESS=21 + NBRR=3 + CALL HEDR + IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,M,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + if(iflag .eq. 'q') go to 100 + lock(m)=0 + go to 120 + ELSEIF(ANS .EQ. 't') THEN +! +! Create data for layers +! + CALL ADDLAY + IF(IRMAIN .EQ. 1) RETURN + GO TO 100 + ELSEIF(ANS .EQ. 'w') THEN +! +! This option allows changes to nodal widths +! + CALL ADDWID + IF(IRMAIN .EQ. 1) RETURN + GO TO 100 +! +! Call to help screen +! + ELSEIF(ANS .EQ. 'h') THEN + CALL HELPS(4) + IF(IRMAIN .EQ. 1) RETURN + GO TO 100 +! + ELSEIF(ANS .EQ. 'q') THEN +! +! Writeout and return +! + CALL WRTOUT(0) + RETURN + ENDIF + +190 CONTINUE + + IF(IMP .EQ. 0) THEN + CALL SYMBL(0.,7.25,0.20,STRELS,0.,63) + go to 100 + endif +! +! Establish size for range +! + call setrng(xnears,nmap) + + ITIME=0 + ICOUNTF=0 + MM=0 + 200 MM=MM+1 +! write(90,*) 'gridsb-111',mm,np,iswt,inew(mm) + IF(MM .LE. NP) THEN +! +! Decode which alternative we are processing +! ipk feb 03 determine interpolation method +! + IF(MM .EQ. 1 .AND. ISWTAGN .EQ. 0) THEN + + IF(IRECD .EQ. 2) THEN + iswtintp=0 + iswtagn=0 + go to 210 + ENDIF + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to interpolate '//& + CHAR(13)//'from the triangulated map file?' ,& + 'Select Interpolation method?') +! If answer 'Yes' set interpolate switch to 1 +! + IF (WInfoDialog(4) .EQ. 2) then + iswtintp=0 + ELSE + iswtintp=1 + ENDIF + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Ask this question again?'//& + CHAR(13)//' ' ,& + 'Ask again?') +! If answer 'Yes' set again switch to 0 +! + IF (WInfoDialog(4) .EQ. 2) then + iswtagn=1 + ELSE + iswtagn=0 + ENDIF + ENDIF + + 210 CONTINUE + + IF(iswtintp .eq. 1) then + if(iswt .ne. 1) then + +! Sort the x-coordinates + + call sortdb(xusr,ncrs,np) + else + ncrs(mm)=mm + endif + m=ncrs(mm) + else + m=mm + endif +! IPK OCT 2 1991 + IF(ISWT .EQ. 1) THEN +! Single node at a time ISWT = 1 +! +! Get M from mouse and set MM to NP +! + NHTP=0 + NMESS=21 +!ipk jun08 NBRR=0 + NBRR=1 + CALL HEDR + IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + if(iflag .eq. 'q') go to 100 + M=INODE + MM=NP + endif + IF(INEW(M) .EQ. 0) GO TO 200 +! IPK END OCT 2 1991 + + IF(ISWT .EQ. -1) THEN +! All nodes ISWT = -1 +!ipk feb02 + if(lock(m) .eq. 1) go to 200 + + ELSEIF(ISWT .EQ. 0) THEN +! Fill nodes ISWT = 0 +!ipk feb02 + IF(WD(M) .GT. -9000. .or. lock(m) .eq. 1) go to 200 + + ENDIF +! write(90,*) 'gridsb-138', m,mm,iswt,wd(m),xnears + + IF(ISWTINTP .EQ. 0) THEN + if(lock(m) .eq. 0) CALL SETELV(XNEARS,NMAP,M,ISWT) + ELSE + if(nelts .eq. 0) then + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'No triangulated exists'//& + CHAR(13)//'Do you wish to triangulate now?' ,& + 'NO TRIANGULATION AVAILABLE?') +! If answer 'Yes' set triangulate now +! + IF (WInfoDialog(4) .EQ. 2) then + return + ELSE + call triang + IDONET=1 + ENDIF + + endif + if(lock(m) .eq. 0) CALL TRIANINT(NMAP,M,ISWT,ITIME) + ENDIF + +! write(90,*) 'gridsb-141', m,iswt,wd(m) + if(wd(m) .lt. -9997.) THEN + icountf=icountf+1 + WD(M)=-9998. + ENDIF + GO TO 200 + ENDIF + IF(IDONET .EQ. 1) THEN + CALL RDMAP(2,99,0,0) ! XXXXX + CLOSE(99) + ENDIF + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to plot contours?'//& + CHAR(13)//' ','PLOT CONTOURS?') +! +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) THEN + go to 220 + ENDIF +215 menus=13 + call conout(menus) + MENUS=12 + CALL CONOUT(MENUS) + +!ipkjan94 IF(ISWT .EQ. -1) GO TO 210 +220 if(icountf .gt. 0) then + + CALL FMESS(ICOUNTF,ISWTT) +! +! If answer 'Yes', use search for adjacent nodes +! + IF(ISWTT .EQ. 1) then + call fillin(icountf) + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to plot contours again?'//& + CHAR(13)//' ','PLOT CONTOURS?') +! +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) THEN + IF(ICOUNTF .GT. 0) GO TO 220 + ELSE + GO TO 215 + ENDIF + END IF + endif + IF(ISWTIN .EQ. -1) RETURN + IF(ISWT .EQ. 1) THEN +!ipk jun08 CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + if(iflag .eq. 'q') go to 100 + M=INODE + MM=NP-1 + GO TO 200 + ELSEIF(ISWT .EQ. -1) THEN + GO TO 100 + ENDIF +!ipk jun08 IF(ABS(ISWT) .EQ. 1) GO TO 100 + RETURN + END +!ipk jul98 revise call +!IPK SUBROUTINE GRIDIN(I,SOLN,LISTM,NLG) + SUBROUTINE GRIDIN(XZ,YZ,SOLN,LISTM,NLG) +! +! Routine to interpolate values from map to node points +! +! I is the location in the CORD array to be interpolated +! SOLN is the interpolated value developed +! NLG is the number of entries in the map array + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +!IPK JAN94 INTEGER*2 LISTM,NLIST,NKEY +!IPK DEC09 INTEGER LISTM,NLIST,NKEY + INTEGER LISTM,NLIST + DIMENSION LISTM(*) + DIMENSION NLIST(1000),ADIST(1000),WT(1000) +! +! Function statements +! + DIST(K,X,Y)=SQRT((CMAP(K,1)-X)**2+(CMAP(K,2)-Y)**2) +!IPK FEB97 ANG(K,X,Y)=ATAN2((CMAP(K,2)-Y),(CMAP(K,1)-X))*57.296 + ANG(K,X,Y)=ATAN2((CMAP(K,1)-X),(CMAP(K,2)-Y))*57.296 +! +! Initialize +! + TOL=120. +! DO KK=1,NLG +! WRITE(90,*) 'LISTM',KK,LISTM(KK) +! ENDDO +! +! Form list of distances from I to data locations +! + NTMP=0 + IPAS=1 +!IPK JUL98 X=CORD(I,1) +!PK JUL98 Y=CORD(I,2) + X=XZ + Y=YZ + 140 CONTINUE + DO 150 KK=1,NLG + K=LISTM(KK) + IF(K .EQ. NTMP) THEN + ADIST(KK)=-VOID + ELSE + ADIST(KK)=DIST(K,X,Y) + ENDIF + 150 END DO +! +! Sort order for nearest points +! + CALL SORT(ADIST,NKEY,NLG) + do nnnn=1,nlg + nn=nkey(nnnn) + nzz=listm(nn) +! WRITE(90,*) NZZ,X,Y,cmap(nzz,1),cmap(nzz,2) +! ATMP=ANG(NZZ,X,Y) +! write(90,*) nnnn,adist(nnnn),val(nzz),ATMP + enddo +! read(*,*) aaa + KK=1 +! +! Search through sorted list +! + INIT=1 + 180 DO 260 K=1,NLG + NN=NKEY(K) + IF(NN .EQ. 0) GO TO 260 + N=LISTM(NN) +! +! Initialize +! + IF(N .EQ. NTMP) GO TO 260 + IF(INIT .EQ. 1) THEN + NLIST(1)=N + YY=(CMAP(N,2)-Y) + XX=(CMAP(N,1)-X) + IF(YY .EQ. 0. .AND. XX .EQ. 0.) THEN + RANGEF=0. + RANGEB=360. + ELSE + RANGEF=ANG(N,X,Y) + RANGEB=ANG(N,X,Y)+360. + ENDIF + INIT=2 + GO TO 260 + ENDIF +! +! Skip out if already processed +! + YY=(CMAP(N,2)-Y) + XX=(CMAP(N,1)-X) + IF(YY .EQ. 0. .AND. XX .EQ. 0.) THEN + ANGLE=0. + ELSE + ANGLE=ANG(N,X,Y) + ENDIF + 200 CONTINUE +! write(90,*) 'angls',n,angle,rangef,rangeb,val(n) +! +! Test if angle greater than high value +! + IF(ANGLE .GT. RANGEF) THEN +! +! Test if the new point is within the allowable range +! + IF(ANGLE .LT. RANGEF+TOL) THEN +! +! Process this point +! + RANGEF=ANGLE + KK=KK+1 + NLIST(KK)=N + NKEY(K)=0 +! +! Test if we now have enough points to exit +! + IF(RANGEF+TOL .GT. RANGEB) THEN + GO TO 300 + ELSE + GO TO 180 + ENDIF +! +! Test if angle lies inside the already spanned area +! If so it cannot be used +! + ELSEIF(ANGLE .GT. RANGEB) THEN + NKEY(K)=0 +! +! Test if it close enough to the low value +! + ELSEIF(ANGLE .GT. RANGEB-TOL) THEN +! +! Process this point +! + RANGEB=ANGLE + KK=KK+1 + NLIST(KK)=N + NKEY(K)=0 +! +! Test if we have enough points to exit +! + IF(RANGEF+TOL .GT. RANGEB) THEN + GO TO 300 + ELSE + GO TO 180 + ENDIF +! +! Not a usable point at this time, move on to next point +! + ELSE + GO TO 260 +! +! Increase angle by 360 and test again +! + ENDIF + ELSE + ANGLE=ANGLE+360. + GO TO 200 + ENDIF + 260 END DO +! +! We have finished loop without completing polygon +! + GO TO 500 +! +! Process least squares fit on this list +! + 300 CONTINUE +! WRITE(90,*) 'least squares list',KK,x,y +! WRITE(90,*) (NLIST(N),N=1,KK) +! do n=1,kk +! write(90,*) nlist(n),cmap(nlist(n),1),cmap(nlist(n),2) +! + ,val(nlist(n)),dist(nlist(n),x,y) +! enddo +!ipk feb97 changes to refine processing +! +! Check if points are close together relative to the centre point +! +! write(90,*) kk,x,y,nlg + do n=1,kk + l=nlist(n) + dc=dist(l,x,y) + xx=cmap(l,1) + yy=cmap(l,2) + if(n .lt. kk) then + do m=n+1,kk + ll=nlist(m) + dr=dist(ll,xx,yy) + if(dr .lt. 0.1*dc) then + if(kk .gt. 3) then + ds=dist(ll,x,y) + if(ds .lt. dc) then + ndrp=n + else + ndrp=m + endif +! +! drop this point +! + do mm=ndrp,kk-1 + nlist(mm)=nlist(mm+1) + enddo + kk=kk-1 + go to 300 + else + go to 310 + endif + endif + enddo + endif + enddo + 310 continue +!ipk feb97 end changes for processing +! WRITE(90,*) '310',kk +! WRITE(90,*) (NLIST(N),N=1,KK) +!ipk feb97 chnage to add weighting + do n=1,kk +!ipk jul98 if(dist(nlist(n),CORD(I,1),CORD(I,2)) .gt. 0.) then +!ipk jul98 wt(n)=1./dist(nlist(n),CORD(I,1),CORD(I,2)) + if(dist(nlist(n),XZ,YZ) .gt. 0.) then + wt(n)=1./dist(nlist(n),XZ,YZ) + else + soln=val(nlist(n)) + return + endif + enddo +!IPK JUL98 CALL ALSQ(KK,NLIST,I,SOLN,WT) + CALL ALSQ(KK,NLIST,XZ,YZ,SOLN,WT) +!ipk feb97 end changes +! +! final value is SOLN +! + RETURN + 500 TOL=TOL+25. + IF(TOL .GT. 180.) GO TO 550 + IF(RANGEF+TOL .GT. RANGEB) THEN + GO TO 300 + ENDIF + GO TO 180 + 550 CONTINUE +!c write(90,*) ' in trouble split',rangef,rangeb + SPLIT=(RANGEF+RANGEB)/2.-180. + AMIN=180. + DO 600 N=1,KK + IF(NLIST(N) .EQ. NTMP) GO TO 600 + YY=(CMAP(NLIST(N),2)-Y) + XX=(CMAP(NLIST(N),1)-X) + IF(YY .EQ. 0. .AND. XX .EQ. 0.) THEN + ANGL=0. + ELSE + ANGL=ANG(NLIST(N),X,Y) + ENDIF + IF(IPAS .EQ. 2) GO TO 600 +! +! Find line closest to split +! + IF(ABS(SPLIT-ANGL) .LT. AMIN) THEN + AMIN=ABS(SPLIT-ANGL) +! write(90,*) 'ntmp reset',ntmp,nlist(n),amin,split + NTMP=NLIST(N) + ENDIF + ANGLP=ANGL-360. + IF(ABS(SPLIT-ANGLP) .LT. AMIN) THEN + AMIN=ABS(SPLIT-ANGLP) + NTMP=NLIST(N) + ENDIF +! 580 WRITE(90,*) NLIST(N),ANGL + 600 END DO + IF(IPAS .EQ. 1) THEN + IPAS=2 + X=CMAP(NTMP,1) + Y=CMAP(NTMP,2) + TOL=120. + write(90,*) 'INTERP FOR ',xz,yz,' MOVED TO',x,y,ntmp + GO TO 140 + ENDIF + WRITE(90,*) 'ERROR NO POLYGON RANGEF,RANGEB',RANGEF,RANGEB,SPLIT + WRITE(90,*) 'OPPOSITE NODE AND ANGULAR DIFF',NTMP,AMIN + SOLN=-9998. + RETURN + END +! +! FUNCTION ANG(K,X,Y) +! +! INCLUDE 'BLK1.COM' +! +! YY=(CMAP(K,2)-Y) +! XX=(CMAP(K,1)-X) +! IF(YY .EQ. 0. .AND. XX .EQ. 0.) THEN +! ANG=0. +! ELSE +! ANG=ATAN2(YY,XX)*57.296 +! ENDIF +! RETURN +! END + + SUBROUTINE SORT(A,NKEY,N) +!*********************************** .....SORT..... +!- +!......SORT IS A SIMPLE SHELL SORT ROUTINE +!- +! SHELL SORT + SAVE +! +!IPK JAN94 INTEGER*2 NKEY + DIMENSION A(*),NKEY(1) + IF(N.LT.2) RETURN + DO 90 J=1,N + NKEY(J)=J + 90 END DO + ID = N + 100 ID = ID / 2 + 110 IB = 1 + 120 GO TO 200 + 130 IB = IB + 1 + IF( IB .LE. ID ) GO TO 200 + IF( ID .GT. 1 ) GO TO 100 + RETURN + 200 I = IB + 210 K = I + ID + 220 IF( A(NKEY(I)) .LE. A(NKEY(K)) ) GO TO 250 + NKT = NKEY(K) + NKEY(K) = NKEY(I) + J = I + 230 K = J - ID + IF( K .LT. 1 ) GO TO 240 + IF( A(NKT) .GT. A(NKEY(K)) ) GO TO 240 + NKEY(J) = NKEY(K) + J = K + GO TO 230 + 240 NKEY(J) = NKT + 250 I = I + ID + IF( I + ID .LE. N ) GO TO 210 + GO TO 130 + END +!ipk feb97 add weighting +!iok jul98 SUBROUTINE ALSQ(NPTS,NLIST,I,SOLN,WT) + SUBROUTINE ALSQ(NPTS,NLIST,xx,yy,SOLN,WT) +! +! Least squares routine +! +! INCLUDE 'PARAM.COM' + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' +!IPK JAN94 INTEGER*2 NLIST + REAL*8 A,R,B,S,X,Y,ATR,ATR2,BTR,C,T,X3,X2,X1 + DIMENSION A(3,3),R(3),B(2,2),S(2),wt(*) + DIMENSION NLIST(*) +! +! Initialize matrices +! +!ipk jul98 X=CORD(I,1) +!ipk jul98 Y=CORD(I,2) + X=XX + Y=YY +! write(*,*) (nnn,cmap(nnn,1),cmap(nnn,2),nnn=1,16) +! write(*,*) (nlist(n),n=1,npts) + DO 160 K=1,3 + R(K)=0. + DO 150 J=1,3 + A(J,K)=0. + 150 CONTINUE + 160 END DO +! +! Form A and R matrices +! + DO 200 N=1,NPTS + KK=NLIST(N) +! write(*,*) cmap(kk,1),cmap(kk,2),val(kk) +!ipk feb97 add weighting + A(1,1)=A(1,1)+1.0*wt(n) + A(1,2)=A(1,2)+CMAP(KK,1)*wt(n) + A(1,3)=A(1,3)+CMAP(KK,2)*wt(n) + A(2,2)=A(2,2)+CMAP(KK,1)**2*wt(n) + A(2,3)=A(2,3)+CMAP(KK,1)*CMAP(KK,2)*wt(n) + A(3,3)=A(3,3)+CMAP(KK,2)**2*wt(n) + R(1)=R(1)+VAL(KK)*wt(n) + R(2)=R(2)+CMAP(KK,1)*VAL(KK)*wt(n) + R(3)=R(3)+CMAP(KK,2)*VAL(KK)*wt(n) +!ipk feb97 end addition of weighting + 200 END DO +! read(*,*) al +! +! Solve equations +! + ATR=A(1,2)/A(1,1) + ATR2=A(1,3)/A(1,1) + B(1,1)=A(2,2)-ATR*A(1,2) + B(1,2)=A(2,3)-ATR*A(1,3) + S(1)=R(2)-ATR*R(1) + B(2,2)=A(3,3)-ATR2*A(1,3) + S(2)=R(3)-ATR2*R(1) + BTR=B(1,2)/B(1,1) + C=B(2,2)-BTR*B(1,2) + T=S(2)-BTR*S(1) + X3=T/C + X2=S(1)/B(1,1)-BTR*X3 + X1=R(1)/A(1,1)-ATR*X2-ATR2*X3 +! +! Substitute to get interpolated value +! + SOLN=X1+X2*X+X3*Y + RETURN + END +! +!ipksep97 new routine for soring map lines +! + SUBROUTINE SORTMAP(A,NKEY,N,IMAP) +!*********************************** .....SORT..... +!- +!......SORT IS A SIMPLE SHELL SORT ROUTINE +!- +! SHELL SORT + SAVE +! +!IPK JAN94 INTEGER*2 NKEY + DIMENSION A(*),NKEY(1),IMAP(*) + DATA VOID/1.E35/ + IF(N.LT.2) RETURN + DO 90 J=1,N + NKEY(J)=J + IF(IMAP(J) .LT. 0) A(J)=VOID + 90 END DO + ID = N + 100 ID = ID / 2 + 110 IB = 1 + 120 GO TO 200 + 130 IB = IB + 1 + IF( IB .LE. ID ) GO TO 200 + IF( ID .GT. 1 ) GO TO 100 + RETURN + 200 I = IB + 210 K = I + ID + 220 IF( A(NKEY(I)) .LE. A(NKEY(K)) ) GO TO 250 + NKT = NKEY(K) + NKEY(K) = NKEY(I) + J = I + 230 K = J - ID + IF( K .LT. 1 ) GO TO 240 + IF( A(NKT) .GT. A(NKEY(K)) ) GO TO 240 + NKEY(J) = NKEY(K) + J = K + GO TO 230 + 240 NKEY(J) = NKT + 250 I = I + ID + IF( I + ID .LE. N ) GO TO 210 + GO TO 130 + END + subroutine fillin(icountf) + USE BLKMAP + USE BLK1MOD + USE BLK2MOD + DIST(N,M)=(cord(n,1)-cord(m,1))**2+(cord(n,2)-cord(m,2))**2 + CALL KCON(0) + MCOUNT=0 + MCOUNTF=0 + DO N=1,NP + IF(WD(N) .LT. -9997. .and. WD(N) .GT. -9998.5) THEN + MCOUNT=MCOUNT+1 + DISTCUR=1.E20 + NADJCT=0 + DO K=1,NDELM(N) + J=NECON(N,K) + DO I=1,NCORN(J) + NC=NOP(J,I) + IF(NC .NE. 0 .AND. NC .NE. N) THEN + IF(WD(NC) .GT. -9997.) THEN + distance=dist(n,nc) + if(distance .lt. distcur) then + distcur=distance + nadjct=nc + endif + ENDIF + ENDIF + ENDDO + ENDDO + if(nadjct .gt. 0) then + wd(n)=wd(nadjct) + else + mcounfT=mcountf+1 + ENDIF + if(mcount .eq. icountf) THEN + ICOUNTF=MCOUNTF + return + ENDIF + endif + enddo + ICOUNTF=MCOUNTF + return + end + + SUBROUTINE FMESS(N1,N2) + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,IERR +! real :: + character*3 :: sub + + call wdialogload(IDD_FBED) + ierr=infoerror(1) + + CALL WDialogPutInteger(idf_integer1,n1) + + + CALL WDialogSelect(IDD_FBED) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + N2=1 + RETURN + ELSEIF(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + N2=0 + RETURN + ENDIF + ENDDO + RETURN + END + \ No newline at end of file diff --git a/src/src83e/HEDR.F90 b/src/src83e/HEDR.F90 new file mode 100644 index 0000000..f74ad71 --- /dev/null +++ b/src/src83e/HEDR.F90 @@ -0,0 +1,334 @@ +!IPk last updated July 15 1998 +!IPk last updated Nov 18 1997 +!IPk last updated Oct 31 1996 fix bug in map option +!IPK LAST UPDATED OCT 16 1996 +!IPk last updated Oct 14 1996 +!IPk last updated Oct 25 1995 + SUBROUTINE HEDR + SAVE + +! Routine to draw NSIZ header boxes at top of page with the HEAD label + + CHARACTER*80 TITLE + CHARACTER*24 HLABL + CHARACTER*1 ALABL(10) + CHARACTER*40 MPDUM + + COMMON /SSIZE/ HSIZE + + COMMON /BLKA1/ TITLE,HLABL,ALABL,MPDUM + +!IPk oct 95 lines defining MPDUM added +!ipk jan01 Expand IPSW to 10 + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout +!IPk feb94 HEAD array and NHEDL enlarged +!IPk oct96 HEAD AND NHEDL MESS, ENLARGED + + common /cols/ ibakk,icolr,iblkk + + CHARACTER*8 HED(10),HEAD(10,16) + CHARACTER*47 MESOUT,MESS(48) +!ipk lan01 add to MESS +!ipk jan99 add to MESS +!ycw mar97 change HEADR(5,5) to HEADR(6,7) +!ipk add extra headr + CHARACTER*8 HEADR(6,10) + DIMENSION NHEDL(16) + DIMENSION X(5),Y(5),IRV(10) +!IPk feb 94 this statement reconstructed +!IPK OCT 96 THIS STATMENT DONE AGAIN + DATA HEAD/ ' (e)lts ','(n)odes ','(o)rder ',' (h)elp ',' ',& +'cc(l)ine',' csec(t)',' (z)oom ',' (r)draw',' (q)uit ','(n)od bk',& !1/2 +' (e)l bk',& +'re(f)ine','spli(t) ','c(l)ean ',5*' ','pr(l)st ','get(g)rp'& ! 2/3 +,'(p)rgrp ','c(o)ptnd','cop(t)el',' (h)elp ',' ',' (z)oom ',' (r)draw',' (q)uit'& !3 +,' (a)dd ',' (m)ove ',' (d)el ',' (f)ind ',' (g)line',' (e)lev '& !4 +,' (h)elp ',' (z)oom ',' (r)draw',' (q)uit ',' (m)ap ',' (o)utln'& !4/5 +,' (e)lts ','(n)odes ',' ne(t)w ',' t(y)pe ','cc(l)ine',' (d)ata '& !5 +,'(b)elev ',' d(r)aw ',' (s)el ',' (j)oin ',' (f)ind ',' (g)blok'& !5/6 +,' (t)ype ',' f(i)ll ',' (h)elp ',' (z)oom ',' (r)draw',' (q)uit '& !6 +,' (d)el ','r(e)fin ',' (n)umb ',' (a)ll ','rectn(g)','(t)riang'& !7 +,' (h)elp ',' (z)oom ',' (r)draw',' (q)uit ',' (f)our ','two(l)g '& !7/8 +,'two(s)h ','spli(t) ','re(v)rs ','clea(n) ',' ','s(m)plfy',' ',' (q)uit '& !8 +,'(m)an/el','(a)ll/el','(f)il/el','(s)in/el',' loc(k) ','(u)nlock'& !9 +,'(t)hree ','man/(w)d',' (h)elp ','(q)uit ','al(l)mid','cen(m)id'& !9/10 +,'sin(g)le','un(u)sed',' (f)ill ',' (j)oin ',' (h)elp ',' (z)oom '& !0 +,' (r)draw',' (q)uit ','a(s)ave ','(b)save ','(m)save ',' (p)save'& !10/11 +,2*' ',' (h)elp ',' (z)oom ',' (r)draw',' (q)uit ',' z(e)ro '& !11/12 +,' (o)ne ',' (t)wo ','t(h)ree ',' (f)our ',' f(i)ve ',' (s)ix '& !12 +,' se(v)en',' ei(g)ht',' (q)uit ',' (w)idth',' ss(1) ',' ss(2) '& !12/13 +,'strw(d) ','str(e)lv','str(s)lp',' (b)s1 ',' (z)oom ',' (r)draw'& !13 +,' (q)uit ','(d)elete','s(e)t999','se(t)elv','set(l)ay',' loc(k) ','(u)nlock','(f)orm-t',' (z)oom ',' (r)draw'& !13/14 +,' (q)uit ','(d)elete','r(e)fin ','se(t)yp ','s(m)plfy','form(g)p','elev und',' ',' (z)oom ',' (r)draw'& !14/15 +,' (q)uit ','(m)an/el','(a)ll/el','(f)il/el',' ',' ',' '& !15/16 +,' ',' ',' (h)elp ','(q)uit '/ + + +!IPk apr95 changed structure of messages added 3 more entries + + + DATA MESS /'Enter node to search for',' Enter material type',& ! 1,2 + 'Enter element to search for ',& ! 3 + 'Enter numbr of layers ',& ! 4 + 'Enter width ',& ! 5 + 'Click mouse at end of line ',& ! 6 + 'Enter nmbr of nodes in line ',& ! 7 + 'Click at corners of block ',& ! 8 + 'Enter nmbr of elts in x-dir ',& ! 9 + 'Enter nmbr of elts in y-dir ',& ! 10 + 'Click to move boundaries or (q)uit to save ',& ! 11 + 'Click on elements', 'Enter starting list number ',& ! 12,13 + 'Enter bottom elevation', 'Click on node ',& ! 14,15 + 'Click location of new node', 'Click at node to move ',&! 16,17 + 'Click at node to delete ',& ! 18 + 'Type 1 to use all nodes else type 0 ',& ! 19 + 'Enter element to select','Click location of node',& ! 20,21 + 'Enter ss1','Enter ss2','Enter strwid','Enter storage elevation',& ! 22,23,24,25 + 'Click mouse on node','click mouse on next node',& ! 26,27 + 'ERROR - Midside node selected - Select node again',& ! 28 + 'Plotting a selected cross section',& ! 29 + 'Click two locations to form a cross section',&! 30 + 'Click to adjust the cross section',& ! 31 + 'Compute cross section parameters',& ! 32 + 'Click a node for the cross section',& ! 33 + + 'Click two locations to form the width','Click to adjust the line','Click two locations to form left slope',& ! 34 35 36 + 'Click two locations to form right slope','Click a location'& ! 37 38 + ,'Enter storage elevation','Enter storage slope',& ! 39 40 + 'Click at two locations to determine distance'& ! 41 + ,'Enter continuity line number use 0 to end','Click at location on image to define register point'& ! 42 43 + ,'Enter 1-d cross-section bed slope','Click at location to define outline point'& ! 44 45 + ,' ','Click two locations to define move'& ! 46 47 + ,'Click locations to form outline'/ ! 48 + ! last line Jan 2001 +! line above added Jan 1999 + DATA HEADR /& + ' (q)uit ',5*' ',& + ' (r)draw',' (q)uit ',4*' ',& + ' (z)oom ',' (r)draw', ' (q)uit ',3*' ',& + ' (n)ext ',' (z)oom ', ' (r)draw',' (q)uit ',2*' ',& + ' (b)ack ',' cn(n)ect', ' (z)oom ',' (r)draw',' (q)uit ',' ',& + ' (l)ine ',' (d)rawcs', ' (z)oom ',' (r)draw',' (q)uit ',' ',& + ' (d)ist ',' (w)idth', ' (1)slop',' (2)slop',' b(e)lev',' (q)uit',& + ' (d)el ',' (z)oom ', ' (r)draw',' (q)uit ',2*' ',& + ' s(a)ve ',' (z)oom ', ' (r)draw',' (q)uit ',2*' ',& + ' u(n)do ',' (c)ancl', ' (z)oom ',' (r)draw',' (q)uit ',1*' '/ + DATA IRV/1 , 2 , 5 , 3 , 4 , 7 , 10 , 6 , 9, 5/ + DATA NHEDL/10,5,10,10,10,10,10,10,10,10,10,10,10,10,10,10/ +! DATA IBAKK/12/,ICOLR/11/ + IF(NHTP .NE. 0) THEN + +! Clear upper box area + + CALL CLRBOX + +! Copy appropriate heading for output + + NSIZ=NHEDL(NHTP) + DO 120 N=1,NSIZ + HED(N)=HEAD(N,NHTP) + 120 CONTINUE + +! Draw box around selections with colour +! + Y(1)=7.5 + Y(2)=7.5 + Y(3)=7.995 + Y(4)=7.995 + Y(5)=7.5 + XPT=0. + DO 150 I=1,NSIZ + X(1)=XPT + X(4)=XPT + X(5)=XPT +! XPT=XPT+1.0 + XPT=XPT+HSIZE/10. + X(2)=XPT + X(3)=XPT + IF(I .EQ. 10) THEN + IBLK=IBAKK +!IPK OCT96 ADD COLOR OPTIONS + ELSEIF((NHTP .EQ. 5 .AND. IPSW(IRV(I)) .EQ. 1) .OR. & + (NHTP .EQ. 12 .AND. ICOLON(I) .EQ. 1)) THEN + IBLK=iblkk + ELSE + IBLK=IBAKK + ENDIF + CALL POLYFL(X,Y,5,IBLK) + CALL RBLACK + CALL PLOTT(X(1),Y(1),3) + CALL PLOTT(X(2),Y(2),2) + CALL PLOTT(X(3),Y(3),2) + CALL PLOTT(X(4),Y(4),2) + CALL PLOTT(X(1),Y(1),2) + 150 CONTINUE + XSY=0. + YSY=7.65 + DO 200 N=1,NSIZ +!ipk mar01 + CALL SYMBL(XSY,YSY,0.20,HED(N),0.0, 8) +! XSY=XSY+1.0 + XSY=XSY+HSIZE/10. + 200 CONTINUE + ENDIF + IF(NMESS .GT. 0) THEN + +! Clear upper box area + + CALL CLRBOX + +! Write out message + + MESOUT=MESS(NMESS) +!ipk mar01 + CALL SYMBL(0.,7.65,0.20,MESOUT,0.,47) + + ENDIF + IF(NBRR .NE. 0) THEN + +! Put box on right + +! Draw box around selections + + NBX=NBRR + if(NBX.gt.5) NBX=NBRR-1 !ycw mar97 + IF(NBX .GT. 6) NBX=4 + if(nbrr .eq. 10) NBX=5 +! XLEFT=10-NBX + XLEFT=(10-NBX)*HSIZE/10. + DO 250 K=1,NBX + X(1)=XLEFT + X(4)=XLEFT + X(5)=XLEFT +! XLEFT=XLEFT+1.0 + XLEFT=XLEFT+HSIZE/10. + X(2)=XLEFT + X(3)=XLEFT + IBLK=IBAKK + CALL POLYFL(X,Y,5,IBLK) + CALL RBLACK + CALL PLOTT(X(1),Y(1),3) + CALL PLOTT(X(2),Y(2),2) + CALL PLOTT(X(3),Y(3),2) + CALL PLOTT(X(4),Y(4),2) + CALL PLOTT(X(1),Y(1),2) +!ipk mar01 + CALL SYMBL(XLEFT-1.,7.65,0.20,HEADR(K,NBRR),0.0,8) + 250 CONTINUE +! ENDIF + ENDIF + RETURN + END + + + +! Get xy location of cursor in screen coordinates (inches) + + + subroutine xyloc(xscrn,yscrn,iflag,ibox) + save + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + CHARACTER*80 TITLE + CHARACTER*24 HLABL + CHARACTER*1 ALABL(10) + CHARACTER*40 MPDUM + + COMMON /SSIZE/ HSIZE + + COMMON /BLKA1/ TITLE,HLABL,ALABL,MPDUM +!IPk oct 95 lines defining MPDUM added + +!ipk jan01 Expand IPSW to 10 + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + + character*1 iflag + common /blktek/ xmin, xmax, ymin, ymax,& + xpiv, ypiv, cthet, sthet,& + xscal, yscal, theta, thetdg,& + pgscl,scrnx,scrny,ix,iy + +! IRDISP= 0 means no redisplay + + irdisp=0 + 100 continue +! iy=ymax +! write(90,*) 'to tekgin nhtp',nhtp + call tekgin(xscrn,yscrn,iflag) +! write(90,*) 'back tekgin nhtp',nhtp,xscrn,yscrn,IRDISP +! write(90,'(a)') 'iflag',iflag + + if(iflag .eq. 'P') then + call hedr +!IPk nov97 add (0) + call plotot(0) + call hedr +!ipk may01 + irdisp=1 + go to 100 + endif + + +!IPk mar94 if(yscrn .gt. 7.0 .and. iflag .eq. 'c') then + if(yscrn .gt. 7.5 .and. iflag .eq. 'c') then +! ibox=ifix(xscrn+0.9999) + ibox=ifix(xscrn*10./HSIZE+0.9999) + iflag='c' + elseif(iflag .eq. 'M') then + irmain = 1 + elseif(iflag .ne. 'c') then + ibox=1 + else + ibox=0 + endif + if(irmain .eq. 1) return + +! Check for zoom command + + if(nhtp .eq. 2 .or. nhtp .eq. 5 .or. nhtp .eq. 12 .or.& + nhtp .eq. 8 .or. nhtp .eq. 9) then + return + elseif(nhtp .eq. 0 .and. (nbrr .eq. 0 .or. nbrr .eq. 2& + .or. nbrr .eq. 7)) then + return + elseif(ibox .eq. 8 .or. iflag .eq. 'z') then + n1=nhtp + n2=nbrr + nhtp=0 + nbrr=0 + CALL ZOOM + nhtp=n1 + nbrr=n2 +!ipk may01 + irdisp=1 + if(irmain .eq. 1) return + call hedr + IF(N2 .EQ. 10) CALL PLTPT + go to 100 + elseif(ibox .eq. 9 .or. iflag .eq. 'r') then + +! Save display parameters + + n1=nhtp + n2=nmess + n3=nbrr + CALL RDRW(0) + if(n2 .eq. 11) call pltpt +!ipk may01 + irdisp=1 + if(irmain .eq. 1) return + +! Restore display parameters + + nhtp=n1 + nmess=n2 + nbrr=n3 + call hedr + go to 100 + endif + + return + + end diff --git a/src/src83e/HELPS.F90 b/src/src83e/HELPS.F90 new file mode 100644 index 0000000..3d45694 --- /dev/null +++ b/src/src83e/HELPS.F90 @@ -0,0 +1,99 @@ +!ipk last update Nov 18 1997 +! + SUBROUTINE HELPS(NTPIN) + USE WINTERACTER +! +! Master routine controlling the help facility +! +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' +! + CHARACTER(LEN=256) :: FILTER + CHARACTER*32 ANS + CHARACTER*78 AHP + character*55 strels +! INTEGER*2 IPAG +! INTEGER*2 NT + DIMENSION NPOS(11),NFIN(10) + LOGICAL*4 EXST + + INQUIRE(FILE=DIRECT,EXIST=EXST) + IF(.not. EXST) THEN + CALL CLSCRN +! WRITE(strels,6000) +! 6000 format( 'Help files not available, press enter to return to menu') +! CALL SYMBL(0.2,7.0,0.25,STRELS,0.0,55) +! NDIG=1 +! call gtcharx(ans,ndig,6.0,7.0) + + Filter='HTM file -- *.htm|*.htm|' + +! CALL WSelectFile(FILTER,PromptOn,DIRECT,'Help files not available - BROWSE') + + CALL WSelectFile(FILTER,LoadDialog+MustExist,DIRECT,'Help files not available - BROWSE') + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + GO TO 200 + ELSE + CALL PLOTOT(1) + RETURN + ENDIF + ENDIF +! +! Write list of options and request choice +! + 200 CONTINUE +! +! Decode choice and open appropriate file +! + IF(NTPIN .EQ. 0) THEN + if(nhtp .lt. 3) then + call WHelpfile(DIRECT) + elseif(nhtp .eq. 3) then + call WHelpfile(DIRECT,'REORDER') + elseif(nhtp .eq. 4) then + call WHelpfile(DIRECT,'NODE') + elseif(nhtp .eq. 5) then + call WHelpfile(DIRECT,'REDRAW') + elseif(nhtp .eq. 6) then + call WHelpfile(DIRECT,'ELEMENT') + elseif(nhtp .eq. 7) then + call WHelpfile(DIRECT,'SELECT') + elseif(nhtp .eq. 8) then + call WHelpfile(DIRECT,'REFINE') + elseif(nhtp .eq. 9) then + call WHelpfile(DIRECT,'ELEVATION') + elseif(nhtp .eq. 10) then + call WHelpfile(DIRECT,'DELETE') + elseif(nhtp .eq. 11) then + call WHelpfile(DIRECT,'SAVE') + elseif(nhtp .eq. 12) then + call WHelpfile(DIRECT,'MAP') + elseif(nhtp .eq. 13) then + call WHelpfile(DIRECT,'WIDTH') + elseif(nhtp .eq. 14) then + call WHelpfile(DIRECT,'POLNODE') + elseif(nhtp .eq. 15) then + call WHelpfile(DIRECT,'POLELEM') + endif + ELSEIF(NTPIN .EQ. 1) THEN + call WHelpfile(DIRECT,'FILE') + ELSEIF(NTPIN .EQ. 2) THEN + call WHelpfile(DIRECT,'ELEMENT') + ELSEIF(NTPIN .EQ. 3) THEN + call WHelpfile(DIRECT,'NODE') + ELSEIF(NTPIN .EQ. 4) THEN + call WHelpfile(DIRECT,'ELEVATION') + ELSEIF(NTPIN .EQ. 5) THEN + call WHelpfile(DIRECT,'REORDER') + ELSEIF(NTPIN .EQ. 6) THEN + call WHelpfile(DIRECT,'SELECT') + ELSEIF(NTPIN .EQ. 7) THEN + call WHelpfile(DIRECT,'DELETE') + ELSEIF(NTPIN .EQ. 8) THEN + call WHelpfile(DIRECT,'SAVE') + + ENDIF + RETURN + END diff --git a/src/src83e/INITSIZ.f90 b/src/src83e/INITSIZ.f90 new file mode 100644 index 0000000..8aef61d --- /dev/null +++ b/src/src83e/INITSIZ.f90 @@ -0,0 +1,162 @@ + SUBROUTINE INITSIZ(IIN1,N1,M1,K1) + + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD + USE BLKMAP + + INCLUDE 'D.INC' + + IF(K1 .EQ. 0) THEN + MAXPL=200000 + MAXP=200000 + MAXE=120000 + MAXSTO=2 + MAXLIN=3000 + MAXECON=60 + MAXECON1=30 + MAXLN=20 + MAELN=300 + RETURN + ENDIF + IMIDS=0 + IF(IIN1 .EQ. 10. .AND. IGFG .EQ. 0 .AND. ITRIAN .EQ. 0) THEN + CALL RDRM1(IIN1,N1,M1,IMIDS) + ENDIF + IF(ITRIAN .EQ. 0) NMIDS=1 + iqsw(1)=1 + iqsw(2)=0 + CALL WMenuSetState(ID_ITYPN,ItemChecked,1) + + IF(N1 .GT. MAXP .OR. M1 .GT. MAXE .AND. IMIDS .EQ. 0) then + + CALL WMessageBox(YesNo, QuestionIcon, 1,'Do you wish to add 20,000 nodes and elements to the limit (YES) or reset sizes (NO)','LIMITS EXCEEDED') + + IF (WInfoDialog(4) .ne. 2) then +! yes + MAXP=N1+20000 + MAXE=M1+20000 + ELSE + CALL RESETSIZ + ENDIF + ELSEIF((N1 .GT. MAXP/3 .OR. M1 .GT. MAXE) .AND. IMIDS .EQ. 1) then + CALL WMessageBox(YesNo, QuestionIcon, 1,'This is a large unfilled network, do you wish to reset sizes?','LIMITS EXCEEDED') + IF (WInfoDialog(4) .ne. 2) then +! yes + CALL RESETSIZ + ENDIF + + endif + + ALLOCATE (CORD(MAXP,2),XUSR(MAXP),YUSR(MAXP),XC(MAXE),YC(MAXE)& + ,NOP(MAXE,8),IMAT(MAXE),THTA(MAXE),IMATL(MAXE),CORDSN(MAXP,2)& + ,WD(MAXP) ,WD1(MAXP),INSKP(MAXP), IESKP(MAXE),NCORN(MAXE)& + ,WIDTH(MAXP), SS1(MAXP), SS2(MAXP), WIDS(MAXP)& + ,IJUN(MAXP),INEW(MAXP),IEM(MAXE),LINTYP(MAXLIN),NEFLAG(MAXP),NEF(MAXP,3),LAY(0:MAXP+1),WTLAY(0:MAXP+1,9)& + ,WIDBS(MAXP),SSO(MAXP),NODDEL(MAXP),IELDEL(MAXE)& + ,NOPSV(MAXE,8),nefsv(MAXP,3),IMATSV(MAXE),LOCK(MAXP),BS1(MAXP),EDIF(0:MAXP),IGRPSER(MAXE),IOD(MAXP)) + + IJUN=0 + lay=0 + IGRPSER=1 + + ALLOCATE (NRIVCR1(MAXP),WTRIVCR1(MAXP),NRIVCR2(MAXP),WTRIVCR2(MAXP)) + + + ALLOCATE (xusrsto(MAXP,MAXSTO),yusrsto(MAXP,MAXSTO),wdsto(MAXP,MAXSTO),& + WIDTHsto(MAXP,MAXSTO), SS1sto(MAXP,MAXSTO), SS2sto(MAXP,MAXSTO), WIDSsto(MAXP,MAXSTO)& + ,WIDBSsto(MAXP,MAXSTO),SSOsto(MAXP,MAXSTO),bs1sto(MAXP,MAXSTO)& + ,nopsto(MAXE,8,MAXSTO),imatsto(MAXE,MAXSTO),thtasto(MAXE,MAXSTO)) + + ALLOCATE (ICCLNSTO(50,350,MAXSTO)& + ,NPSTO(MAXSTO),NESTO(MAXSTO),NLSTSTO(MAXSTO),NCLMSTO(MAXSTO)) + + ALLOCATE (ILISTSTO(MAXLN,MAELN,MAXSTO),LLISTSTO(MAXLN,MAXSTO)) + + + ALLOCATE (MLIST(MAXE),ENXT(MAXE),NDELM(MAXP),LIST(MAXP) & + ,NINC(MAXP),NELIM(MAXE)) + + ALLOCATE (ICON(MAXE,MAXECON)) + + ALLOCATE (NECON(MAXP,MAXECON)) + + ALLOCATE (MSN(MAXP),ICN(MAXP)) + + ALLOCATE (ILIST(MAXLN,MAELN),LLIST(MAXLN)) + + RETURN + END + + SUBROUTINE RESETSIZ + + USE WINTERACTER + USE BLK1MOD + USE BLKMAP + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: NTYP,NLOCC + + + call wdialogload(IDD_MLIMITS) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_MLIMITS) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,MAXP) + CALL WDialogPutINTEGER(IDF_INTEGER2,MAXE) + CALL WDialogPutINTEGER(IDF_INTEGER3,MAXPL) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,MAXP) + CALL WDialogGetINTEGER(IDF_INTEGER2,MAXE) + CALL WDialogGetINTEGER(IDF_INTEGER3,MAXPL) + + GO TO 100 + ENDIF + + enddo + + 100 CONTINUE + return + end + + SUBROUTINE SETGFGTRIAN(I1,I2,N2,M2) + USE BLK1MOD +! Define a common block with file names etc + + INCLUDE 'BFILES.I90' + CHARACTER (LEN=255) :: FNAMTMP + IGFG=I1 + ITRIAN=I2 + IF(ITRIAN .EQ. 1) THEN + READ(10,*) M2 + REWIND (10) + itunit=14 + FNAMTMP=FNAMKEP + DO L=255,1,-1 + IF(FNAMTMP(L:L) .EQ. '.') THEN + FNAMTMP(L+1:L+4)='node' + OPEN(ITUNIT,FILE=FNAMTMP,STATUS='OLD',ACTION='READ') + READ(ITUNIT,*) N2 + CLOSE(ITUNIT) + RETURN + ENDIF + ENDDO + ENDIF + RETURN + END \ No newline at end of file diff --git a/src/src83e/INOUT.F90 b/src/src83e/INOUT.F90 new file mode 100644 index 0000000..0d054db --- /dev/null +++ b/src/src83e/INOUT.F90 @@ -0,0 +1,2524 @@ +!IPK LAST UPDATE SEP 23 2015 ADD OPTION FOR SURFER FORMAT MAPS +!IPK LAST UPDATE FEB 11 2002 ADD LOCK AS VARIABLE AND READ NEW MAP FILE +!ipk jan99 fix restart file +! +! +!**************************************************************** +! + SUBROUTINE WRTOUT(IFOM) +!ipk oct95 IFO replaced by IFOM because the value changes +! +! Write out updated data +! +! IFO = 0 write to backup +! IFO = 1 write to output in ASCII +!IPK MAR94 add a line +! IFO = -1 write to ASCII in emergency +! IFO = 2 write to output as binary +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*55 FMTT + CHARACTER*39 FMTU +!IPK JUL98 + CHARACTER*8 ID8 + CHARACTER*60 LIND + CHARACTER*32 IJNK +! + DATA ISET /2/,ZERO/0.0/ +!ipk oct95 copy IFO from IFOM +!ipk feb99 IOT=20 +!ipk feb99 IOT1=22 + + IF((IFOM .EQ. 2 .AND. IOT1 .EQ. 0) .OR. & + & (IFOM .EQ. 1 .AND. IOT .EQ. 0)) THEN + CALL CLRBOX + WRITE(LIND,*) 'You have attempted to save without opening save f& + &ile' + CALL SYMBL(0.2,7.80,0.20,LIND,0.0,60) + WRITE(LIND,*) 'Press return to continue' + CALL SYMBL(0.2,7.55,0.20,LIND,0.0,60) + CALL GTCHARX(IJNK,NDIG,5.0,7.6) + CALL CLRBOX + RETURN + ENDIF + IFO=IFOM + + IF(IFO .GT. 0) THEN +! +! Check connectivity before saving +! + CALL CHKCON(IREP) + IF(IREP .EQ. 0) RETURN + ENDIF +! +! Setup 1-D + IOD=2 + DO N=1,NE + IF(NCORN(N) .LT. 6) THEN + IF(NCORN(N) .EQ. 5) THEN + NCN=3 + ELSE + NCN=NCORN(N) + ENDIF + DO K=1,NCN + INODE=NOP(N,K) + IF(INODE .GT. 0) IOD(INODE)=1 + ENDDO + ELSE + DO K=1,8 + INODE=NOP(N,K) + IF(INODE .GT. 0) then + IF(IOD(INODE) .EQ. 2) IOD(INODE)=0 + ENDIF + ENDDO + ENDIF + ENDDO + DO J=1,NP + IF(IOD(J) .EQ. 0) THEN + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. + WIDBS(J)=0. + SSO(J)=0. + BS1(J)=0. + ENDIF + ENDDO +!IPK MAR94 add a line + IFO = ABS(IFO) + if((ifo .eq. 1 .and. igfgsw .eq. 0) .or. ifo .ne. 1) then + if(itrianout .eq. 0) CALL HEADIN(IFO,ISET) + endif + IF(IFO .EQ. 0 ) THEN + WRITE(IBAK) ((NOP(J,K),K=1,8),IMAT(J),THTA(J),J=1,NE) + WRITE(IBAK) & + & (XUSR(J),YUSR(J),WD(J),WIDTH(J),SS1(J),SS2(J),WIDS(J), & + & WIDBS(J),SSO(J),BS1(J),J=1,NP) +!IPK MAR02 add BS1 +!IPK JUL98 + (XUSR(J),YUSR(J),WD(J),WIDTH(J),SS1(J),SS2(J),WIDS(J) + WRITE(IBAK) NLST + IF(NLST .GT. 0) THEN + WRITE(IBAK) (LLIST(J),J=1,NLST), & + & ((ILIST(J,I),I=1,LLIST(J)),J=1,NLST) + ENDIF +!IPK JAN01 + WRITE(IBAK) NENTRY,NLAYD,NCLM + IF(NENTRY .GT. 0) THEN + WRITE(IBAK) ((NEF(I,J),J=1,3),I=1,NENTRY) + ENDIF + IF(NLAYD .GT. 0) THEN + WRITE(IBAK) (LAY(I),I=0,NP),((WTLAY(I,J),J=1,9),I=0,NP) + ENDIF +!IPK JAN01 + IF(NCLM .GT. 0) THEN + WRITE(IBAK) ((ICCLN(I,J),J=1,350),I=1,NCLM) + ENDIF + IF(IBAK .EQ. 21) THEN + CLOSE (IBAK) + OPEN(IBAK,FILE='ELT.BAK',STATUS='UNKNOWN',FORM='UNFORMATTED',IOSTAT=iost) + if(iost .gt. 0) then + OPEN(IBAK,FILE='ELT1.BAK',STATUS='UNKNOWN',FORM='UNFORMATTED',IOSTAT=iost) + if(iost .gt. 0) then + OPEN(IBAK,FILE='ELT2.BAK',STATUS='UNKNOWN',FORM='UNFORMATTED',IOSTAT=iost) + if(iost .gt. 0) then + write(*,*) 'ERROR UNABLE TO OPEN ELT.BAK FILE' + write(*,*) 'PRESS RETURN TO END' + read(*,'(I5)') junk + STOP + endif + ENDIF + ENDIF +! OPEN(IBAK,FILE='ELT.BAK',STATUS='UNKNOWN',FORM='BINARY') + ENDIF + + ELSEIF(IFO .EQ. 2) THEN + if(igfgswb .eq. 0) then +!ipk may02 REWIND IOT1 + WRITE(IOT1) & + & NP,NE,(XUSR(J),YUSR(J),ZERO,WD(J),J=1,NP), & + & ((NOP(J,K),K=1,8),IMAT(J),THTA(J),IEM(J),J=1,NE), & + & (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,NP) +!IPK JUL98 + ID8='part-2 ' + WRITE(IOT1) ID8 + WRITE(IOT1) (WIDBS(J),SSO(J),J=1,NP) + +!IPK JAN01 Add part 3 write for continuity lines + IF(NCLM .GT. 0) THEN + ID8='part-3 ' + WRITE(IOT1) ID8 + WRITE(IOT1) NCLM,((ICCLN(I,J),J=1,350),I=1,NCLM) + ENDIF +!IPK JAN01 Add part 4 write for continuity lines + ID8='part-4 ' + WRITE(IOT1) ID8 +!ipk mar02 add BS1 + write(iot1) (lock(j),bs1(j),j=1,np),& + nlst,((ilist(j,k),k=1,maeln),llist(j),j=1,maxln) + else + call wrtbin + endif + ELSE + if(igfgsw .eq. 0 .and. itrianout .eq. 0) then + IOF=IOT + + JJ=0 + DO 10 J=1,NE + IF (IMAT(J) .NE. 0) THEN + JJ=JJ+1 + IF(IECHG .EQ. 0) IEM(JJ)=JJ + + if(np .lt. 100000) then + WRITE(IOF,'(10I5,F10.3,I5)') & + & J, (NOP(J,K),K=1,8), IMAT(J),THTA(J),IEM(JJ) + else + WRITE(IOF,'(10I6,F10.3,I6)') & + & J, (NOP(J,K),K=1,8), IMAT(J),THTA(J),IEM(JJ) + endif + ENDIF + 10 CONTINUE +! +!ipk jan98 restore 9999 + if(np .lt. 100000) then + WRITE(IOF,'(I5)') 9999 + else + WRITE(IOF,'(I6)') 9999 + endif +! +! Write out nodal data +! +!ipk jun97 find max or min number in x or y + cminx=0. + cmaxx=0. + wdmin=1.e10 + wdmax=-1.e10 + do j=1,np + if(inew(j) .eq. 1) then +! write(90,*) j,xusr(j),yusr(j) + if(xusr(j) .gt. cmaxx) cmaxx=xusr(j) + if(yusr(j) .gt. cmaxx) cmaxx=yusr(j) + if(xusr(j) .lt. cminx) cminx=xusr(j) + if(yusr(j) .lt. cminx) cminx=yusr(j) + wdmin=min(wdmin,wd(j)) + wdmax=max(wdmax,wd(j)) + endif + enddo + if(abs(wdmin) .gt. abs(wdmax)) then + temp=log10(abs(wdmin)) + elseif(wdmax .eq. 0.) then + temp=2.5 + else + temp=log10(abs(wdmax)) + endif + if(temp .gt. 2.) then + itp=3 + elseif(temp .gt. 1.) then + itp=4 + else + itp=5 + endif + ndigp=1 + if(cmaxx .gt. 1.) then + ndigp=int(log10(cmaxx))+1 + endif + ndigm=2 + if(abs(cminx) .gt. 1.) then + ndigm=int(log10(abs(cminx)))+2 + endif + ndigo=max(ndigp,ndigm) + ndec=min(8-ndigo,4) +! write(90,*) 'ndigp',ndigp,ndigm,cmaxx,cminx,ndigo,ndec + if(ntempin .lt. 2) then + write(fmtt,6200) NDEC,NDEC,itp +!IPK JUL98 6200 format('(I10,F10.',i1,',F10.'I1,',F10.3,F10.1,2F10.3,F +!IPK FEB02 ALLOW FOR LOCK AND BS1 + 6200 format('(I10,F10.',i1,',F10.'I1,',F10.',I1,',F10.1,2F10.3,3F10.2,I10,F10.4)') + WRITE(FMTU,6201) NDEC,NDEC,ITP +!IPK FEB02 ALLOW FOR LOCK AND BS1 + 6201 format('(I10,F10.',i1,',F10.'I1,',F10.',I1,',60X,I10,F10.4)') + else + ndec=min(14-ndigo,4) +! write(fmtt,6202) NDEC+10,NDEC+10,ITP + write(fmtt,6202) NDEC+9,NDEC+9,ITP + 6202 format('(I10,g20.',i2,',g20.'I2,',F10.',I1,',F10.1,2F10.3,3F10.2,I10,F10.4)') +! WRITE(FMTU,6203) NDEC+10,NDEC+10,ITP + WRITE(FMTU,6203) NDEC+9,NDEC+9,ITP + 6203 format('(I10,g20.',i2,',g20.'I2,',F10.',I1,',60X,I10,F10.4)') + endif + DO 20 J=1,NP + IF (INEW(J) .EQ. 1) THEN +!ipk oct94 IF(WIDTH(J) .GT. 0.01) THEN + IF(WIDTH(J) .GT. 0.001 .or. bs1(j) .gt. 0.) THEN +!ipk feb97 WRITE(IOF, '(I10,2F10.3,F10.2,F10.1,2F10.3,F10.1 +!IPK JUL97 WRITE(IOF, '(I10,3F10.3,F10.1,2F10.3,F10.1)') +!IPK FEB02 ADD LOCK AND BS1 + + WRITE(IOF, FMTT) & + & J,XUSR(J),YUSR(J),WD(J), & + & WIDTH(J),SS1(J),SS2(J),WIDS(J) & + & ,WIDBS(J),SSO(J),LOCK(J),BS1(J) + + ELSE +! write(90,7777) fmtu,j,xusr(j),yusr(j),ndec,ndigo + 7777 format(3x,a23,i5,2e15.6,2i8) + +!ipk feb97 WRITE(IOF, '(I10,2F10.3,F10.2)') +!IPK JUL97 WRITE(IOF, '(I10,3F10.3)') +!ipk feb02 add lock AND BS1 + WRITE(IOF, FMTU) & + & J,XUSR(J),YUSR(J),WD(J),lock(j),BS1(J) + ENDIF + ENDIF + 20 CONTINUE +!ipk jan98 restore 9999 + WRITE(IOF,'(I10)') 9999 + IF(NLST .GT. 0) THEN + DO 30 J=1,NLST + IF(LLIST(J) .GT. 0) THEN + if(np .lt. 100000) then + WRITE(IOF,'(16I5)') (ILIST(J,I),I=1,LLIST(J)) + else + WRITE(IOF,'(16I6)') (ILIST(J,I),I=1,LLIST(J)) + endif + ENDIF + 30 CONTINUE + ENDIF +!ipk jan98 restore 9999 + WRITE(IOF,'(I5)') 9999 +! IF(NLAYD .GT. 0) THEN +! WRITE(IOF,'(2I5)') (I,LAY(I),I=1,NP) +! ENDIF + WRITE(IOF,6000) NENTRY + 6000 FORMAT(I5,20X,'NENTRY') + IF(NENTRY .GT. 0) THEN + WRITE(IOF,'(15I5)') (NEF(I,1),NEF(I,2),NEF(I,3),I=1,NENTRY) + ENDIF + WRITE(IOF,6001) NCLM + 6001 FORMAT(I5,20X,'NCLM') + IF(NCLM .GT. 0) THEN + DO I=1,NCLM + DO J=1,350 + IF(ICCLN(I,J) .EQ. 0) THEN + NTRAC=J-1 + IF(NTRAC .GT. 0) THEN + WRITE(IOF,6002) I,(ICCLN(I,KK),KK=1,NTRAC) + 6002 FORMAT('CC1',I5,9I8/('CC2',5X,9I8)) + ELSE + WRITE(IOF,6002) I + ENDIF + GO TO 40 + ENDIF + ENDDO + 40 CONTINUE + ENDDO + ENDIF + WRITE(IOF,6003) + 6003 FORMAT('ENDDATA') + elseif(itrianout .gt. 0) then + call wrtele(IOT,itrianout) + else + call wrtgfg(IOT) + endif + ENDIF + RETURN + END +!**************************************************************** + SUBROUTINE HEADIN(IUNIT,ISET) +! +! Read and write header data +! +!**************************************************************** +! + USE BLK1MOD + INTEGER*2 I32 + CHARACTER*80 ALINE +!ipk dec97 + character*40 dlin + CHARACTER*32 IJNK +!IPK JUL98 +!ipk may02 + CHARACTER*8 ID8 + CHARACTER*3 ID + CHARACTER*1000 HEADER + + COMMON /RECOD/ IRECD,TSPC +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' + INTEGER*2 NOP2(MAXE,8) + DATA ISLP/0/,IPRT/1/,IPO/1/,IRO/1/,IRFN/0/,IGEN/0/,NXZL/0/,NITST/1/,ISCTXT/0/,IFILL/0/,IALTGM/1/ + DATA HORIZ/10./,VERT/8./,XSALE/1./,YSALE/1./,XFACT/1./,YFACT/1./,AR/0./,ANG/0./ + ! ELSE + !ISLP=0 + !IPRT=1 + !IPO=1 + !IRO=1 + !IRFN=0 + !IGEN=0 + !NXZL=0 + !NITST=1 + !ISCTXT=0 + !IFILL=0 + !IALTGM=1 + + + +! IF ISET = 1 read file +! IUNIT = 0 get a title +! IUNIT ne 0 and IIN = 11 read RST header +! IUNIT ne 0 and IIN = 12 read GEO data +! IUNIT ne 0 and IIN = 10 read RM1 header +! IUNIT ne 0 and IIN = 10 ITRIAN .NE. 0 read ELE header +! IF ISET = 2 write file +! IUNIT = 0 write a backup header +! IUNIT = 0 write RM1 header + +! + IF(ISET .EQ. 1) THEN + IF(IUNIT .EQ. 0) THEN +! +! Generate values +! + CALL SETD(23) +!ipk oct96 WRITE(*,*) 'Enter a title for output file' + WRITE(DLIN,'(a29)') 'Enter a title for output file' +!ipk oct96 change to dlin +! call symbl(0.5,5.0,0.25,dlin,0.0,29) +! ndig=29 +! call gtcharx(title,ndig,0.,4.5) + + IF(IRECD .NE. 2) call get_label(dlin,title) + +! + +!ipk oct96 end changes +!ipk oct96 READ(*,5000) TITLE + CALL SETD(2) +! ISPL=0 + IPRT=1 + IPNN=1 + IPEN=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=10. + VERT=8. + XSALE=0. + YSALE=0. + XFACT=0. + YFACT=0. + AR=0. + ANG=0. + xadded=0. + yadded=0. + ntempin=0. + ELSE + IF(IIN .EQ. 11) THEN +!IPK FEB03 READ(IIN) TITLE,NP,NE +!IPK FEB03 READ(IIN) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & +!IPK FEB03 & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin +!IPK FEB03 READ(IIN) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG +!IPK FEB03 IF(IPP .GT. 0) READ(IIN) ALINE + CALL RDRST(1,IIN) + + ELSEIF(IIN .EQ. 12) THEN + CALL SETD(23) + IPRT=1 + IPNN=1 + IPEN=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=10. + VERT=8. + XSALE=0. + YSALE=0. + XFACT=0. + YFACT=0. + AR=0. + ANG=0. + xadded=0. + yadded=0. + ntempin=0. + !ipk oct96 WRITE(*,*) 'Enter a title for output file' + WRITE(dLIN,'(a29)') 'Enter a title for output file' + + call get_label(dlin,title) + +! call symbl(0.5,5.0,0.25,dlin,0.0,29) +! ndig=29 +! call gtcharx(title,ndig,0.,4.5) + +!ipk oct96 end changes +!ipk oct96 READ(*,5000) TITLE + CALL SETD(2) + IF(IGFG .EQ. 2) THEN + CALL RDBIN(IIN) + RETURN + ENDIF +!ipk dec97 + read(iin,err=100) header + if(header(1:6) .eq. 'RMAGEN' .or. header(1:6) .eq. 'RMASIM') then + inopt=2 + else + inopt=1 + rewind iin + endif + read(iin) n1,m1 + rewind iin + write(90,*) 'Apparent nodes and elements from file are' + write(90,'(i15,i10)') n1,m1 + if(n1 .gt. maxp .or. m1 .gt. maxe) then +! +!...... Perhaps the file format is wrong, close and reopen +! + WRITE(DLIN,'(A32)') 'Parameter limits may be violated' + call symbl(0.5,4.5,0.20,dlin,0.0,32) + WRITE(DLIN,'(A35)') 'Retrying with alternate file format' + call symbl(0.5,4.2,0.20,dlin,0.0,35) + close (iin) + open(iin ,file=fnamkep,status='old',form='unformatted') + read(iin) n1,m1 + write(90,*) 'Revised nodes and elements from file are' + write(90,'(i15,i10)') n1,m1 + if(n1 .gt. maxp .or. m1 .gt. maxe) then + WRITE(DLIN,'(A31)') 'Parameter limits still violated' + call symbl(0.5,3.9,0.20,dlin,0.0,31) + WRITE(DLIN,'(A27)') 'Apparent nodes and elts are' + call symbl(0.5,3.6,0.20,dlin,0.0,27) + WRITE(DLIN,'(2i10)') n1,m1 + call symbl(0.5,3.3,0.20,dlin,0.0,20) + WRITE(DLIN,'(A24)') 'Press enter to terminate' + call symbl(0.5,4.5,0.20,dlin,0.0,24) + CALL GTCHARX(ijnk,ndig,5.0,4.0) +!cipk aug00 read(*,'(i1)') junk + call quit_pgm + endif + endif + rewind iin +!ipk dec97 end changes +!ipk may02 + if(inopt .eq. 2) then + read(iin,err=100) header + READ(IIN,ERR=100) & + & N1,M1,((CORD(J,K),K=1,2),ALPHA,WD(J),J=1,N1), & + & ((NOP(J,K),K=1,8),IMAT(J),THTA(J),I3,J=1,M1) & + & , (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,N1) +!IPK JUL98 + else + READ(IIN,ERR=100) & + & N1,M1,((CORDSN(J,K),K=1,2),ALPHA,WD(J),J=1,N1), & + & ((NOP2(J,K),K=1,8),IMAT(J),THTA(J),I32,J=1,M1) & + & , (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,N1) + DO J=1,N1 + DO K=1,2 + CORD(J,K)=CORDSN(J,K) + ENDDO + ENDDO + DO J=1,M1 + DO K=1,8 + NOP(J,K)=NOP2(J,K) + ENDDO + ENDDO + endif + read(IIN,err=120,end=120) id8 + if(id8(1:6) .eq. 'part-2') then + read(IIN,err=104) (widbs(j),sso(j),j=1,n1) + read(IIN,err=120,end=120) id8 + endif + +!IPK JAN01 Add part 3 write for continuity lines + if(id8(1:6) .eq. 'part-3') then + +!ipk aug02 IF(NCLM .GT. 0) THEN + READ(IIN,ERR=104) NCLM,((ICCLN(I,J),J=1,350),I=1,NCLM) +!ipk aug02 ENDIF + read(IIN,err=120,end=120) id8 + endif +!IPK DEB02 Add part 4 write for lock and BS1 lines and reordering + if(id8(1:6) .eq. 'part-4') then + read(iin,err=104,end=120) (lock(j),bs1(j),j=1,n1) + read(iin,err=104,end=90) & + nlst,((ilist(j,k),k=1,maeln),llist(j),j=1,maxln) + endif + GO TO 120 +!IPK MAR04 + 90 NLST=0 + DO J=1,MAXLN + LLIST(J)=0 + DO K=1,MAELN + ILIST(J,K)=0 + ENDDO + ENDDO + GO TO 120 + + 100 READ(IIN,ERR=104) & + & N1,M1,((CORDSN(J,K),K=1,2),ALPHA,WD(J),J=1,N1), & + & ((NOP2(J,K),K=1,8),IMAT(J),THTA(J),I32,J=1,M1) + DO J=1,N1 + DO K=1,2 + CORD(J,K)=CORDSN(J,K) + ENDDO + ENDDO + DO J=1,M1 + DO K=1,8 + NOP(J,K)=NOP2(J,K) + ENDDO + ENDDO + GO TO 120 + + 104 WRITE(90,*) 'Error reading binary geometry file' +!ipk jan98 CALL SETD(23) + call clscrn() + WRITE(aline,*) 'Error reading binary geometry file' + call symbl & + & (1.1,3.3,0.20,aline,0.0,80) + WRITE(aline,*) 'Press enter to exit' + call symbl & + & (1.1,3.0,0.20,aline,0.0,80) + ndig=1 + CALL GTCHARX(IJNK,NDIG,5.0,7.6) + CALL Quit_Pgm + STOP + + 120 CONTINUE + NP=N1 + NE=M1 + ELSE + IF(IGFG .EQ. 0 .AND. ITRIAN .EQ. 0) THEN + READ(IIN,5000) TITLE + write(90,5000) title + 5000 FORMAT( A80) + READ(IIN,5010) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin + write(90,5010) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin + 5010 FORMAT( 15I5,2f10.1,i10) + READ(IIN,5011) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + 5011 FORMAT( 2F10.0,4F10.4,2F10.0 ) + IF(IPP .GT. 0) READ(IIN,5012) ALINE + 5012 FORMAT(A80) + ELSEIF(IGFG .GT. 0 .OR. ITRIAN .EQ. 1) THEN + write(90,*) 'reading gfg/TRIAN title' + IPRT=1 + IPNN=1 + IPEN=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=10. + VERT=8. + XSALE=0. + YSALE=0. + XFACT=0. + YFACT=0. + AR=0. + ANG=0. + xadded=0. + yadded=0. + ntempin=0. + IF(IGFG .EQ. 1) THEN + DO I=1,10000 + READ(IIN,'(A3,A77)') ID,DLIN + IF(ID .EQ. 'T1 ') THEN + TITLE(1:77)=DLIN + GO TO 140 + ENDIF + ENDDO + ELSEIF(IGFG .EQ. 3) THEN + DO I=1,10000 + READ(IIN,'(A8,A77)') ID8,DLIN + IF(ID8 .EQ. 'MESHNAME') THEN + TITLE(1:77)=DLIN + GO TO 140 + ENDIF + ENDDO + ENDIF + 140 CONTINUE + REWIND IIN + ENDIF + ENDIF + ENDIF + ELSE + IF(IUNIT .EQ. 0 ) THEN + IF(IPNN .NE. 1) THEN + ISLP=0 + IPRT=1 + IPNN=1 + IPEN=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=10. + VERT=8. + XSALE=0. + YSALE=0. + XFACT=0. + YFACT=0. + AR=0. + ANG=0. + xadded=0. + yadded=0. + ntempin=0 + ENDIF + REWIND IBAK + WRITE(IBAK) TITLE,NP,NE + WRITE(IBAK) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin + WRITE(IBAK) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + IF(IPP .GT. 0) WRITE(IBAK) ALINE + ELSEIF(IUNIT .EQ. 1) THEN + IOF=IOT + REWIND IOF +!ipk nov02 +!IPK MAR04 +! if(ne .gt. 99999) then + if(np .gt. 99999) then + if(ntempin .eq. 0) then + ntempin=1 + else + ntempin=3 + endif + endif + ISLP=0 + IPRT=1 + IPO=1 + IRO=1 + IPP=0 + IRFN=0 + IGEN=0 + NXZL=0 + NITST=1 + ISCTXT=0 + IFILL=0 + IALTGM=1 + NLAYD=0 + HORIZ=0 + VERT=0 + XSALE=0 + YSALE=0 + XFACT=0 + YFACT=0 + AR=0 + ANG=0 + WRITE(IOF,5000) TITLE + WRITE(IOF,5010) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin + WRITE(IOF,5011) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + IF(IPP .GT. 0) WRITE(IOF,5012) ALINE + ENDIF + ENDIF + RETURN + END +! + SUBROUTINE RDCORD(IUNIT) +! +! Read in coordinates +! +!IPK MAY02 + USE WINTERACTER + USE BLK1MOD + + include 'd.inc' + + REAL*8 CX,CY,VALS(7) + + + DIMENSION IRLINE(16) + CHARACTER*1 IJNK,ans + character*30 blank + CHARACTER*32 ANS32 + CHARACTER*77 DLIN2 + CHARACTER*28 MESG + CHARACTER*3 ID + character*80 dlin +!ipk feb02 expand to 110 + character*150 dlin1 +! INCLUDE 'BLK1.COM' + DATA IFIRST / 0 / + data blank/' '/ +! + IF (IFIRST .EQ. 0) THEN + IF(IIN .EQ. 10) THEN + NP = 0 + ENDIF + VOID = - 1.0E+10 + VDX = -1.E+9 + IFIRST = 1 + ENDIF + ISTART=0 + JZ=0 +! +! + IF(IUNIT .EQ. 0) RETURN + IF(IUNIT .EQ. 10) THEN + IF(IGFG .gt. 0) REWIND IUNIT +!ipk oct96 upgrade to model limits + 20 continue + IF(IGFG .EQ. 0 .AND. ITRIAN .EQ. 0) THEN +!IPK JUL98 read(iunit,'(a80)',end=98) dlin +!ipk feb02 expand to 110 +!ipk may02 expand to 150 + read(iunit,'(a150)',end=98) dlin1 + if(dlin1(11:30) .eq. blank) go to 98 +!IPK JUL98 READ(dlin,'(I10,7F10.0)') J, CX, CY, BELEV, +!ipk feb02 add lock and BS1 + if(ntempin .lt. 2) then + READ(dlin1,'(I10,9F10.0,I10,F10.0)') J, CX, CY, BELEV, & + & WDTHX,SS1X,SS2X,WDSX,WEL,SSSO,LOCK1,BS11 + else + READ(dlin1,'(I10,2f20.0,7F10.0,I10,F10.0)',err=8888) J, CX, CY, BELEV, & + & WDTHX,SS1X,SS2X,WDSX,WEL,SSSO,LOCK1,BS11 + go to 8889 + 8888 do kcl=61,140 + dlin1(kcl:kcl)=' ' + enddo + READ(DLIN1,'(I10,2F20.0,7F10.0,I10,F10.0)') J, CX, CY, BELEV,& + WDTHX,SS1X,SS2X,WDSX,WEL,SSSO,LOCK1,BS11 +8889 continue + + + endif + ELSEIF(ITRIAN .EQ. 1) THEN + IF(ISTART .EQ. 0) THEN + READ(IUNIT,*) NPPP,NDUM,NATTR + ISTART=1 + ENDIF + READ(IUNIT,*) J,CX,CY,(VALS(K),K=1,NATTR) + IF(J .EQ. 0) THEN + J=NPPP + JZ=1 + ENDIF + BELEV=-9999. + WDTHX=0. + SS1X=0. + SS2X=0. + WDSX=0. + WEL=0. + SSSO=0. + LOCK1=0 + BS11=0. + IF(NATTR .GT. 0) BELEV=VALS(1) + IF(NATTR .GT. 1) WDTHX=VALS(2) + IF(NATTR .GT. 2) SS1X=VALS(3) + IF(NATTR .GT. 3) SS2X=VALS(4) + + ELSE + +!ipk jun02 Allow for GFGEN input + DO ICOUNTC=1,1000000 + DO JJ=1,150 + DLIN1(JJ:JJ)=' ' + ENDDO + READ(IUNIT,'(A3,A150)', END=400) ID,DLIN1 + IF(ID .EQ. 'GNN' .OR. ID .EQ. 'GWN') THEN +! Count the number of variables + I=0 + ICOUNT=0 + 75 CONTINUE + IF(DLIN1(I+1:I+1) .NE. ' ') THEN + GO TO 80 + ELSE + I=I+1 + GO TO 75 + ENDIF + 80 I=I+1 + IF(I .EQ. 151) THEN + ICOUNT =ICOUNT+1 + GO TO 90 + ENDIF + IF(DLIN1(I:I) .EQ. ' ' .OR. DLIN1(I:I) .EQ. ',') THEN + ICOUNT=ICOUNT+1 + 85 CONTINUE + IF(I+1 .EQ. 151) GO TO 90 + IF(DLIN1(I+1:I+1) .EQ. ' ') THEN + I=I+1 + GO TO 85 + ELSE + GO TO 80 + ENDIF + ELSE + GO TO 80 + ENDIF + ELSEIF(ID(1:2) .EQ. 'ND') THEN + ICOUNT=4 + go to 90 + ENDIF + ENDDO + 90 CONTINUE + DO K=1,7 + VALS(K)=0. + ENDDO + READ(DLIN1,*) J,(VALS(K),K=1,ICOUNT-1) +! WRITE(109,'(A8,I8,10F15.6)') ID,J,(VALS(K),K=1,ICOUNT-1) + IF(ID .EQ. 'GNN' .OR. ID .EQ. 'ND ') THEN + CX=VALS(1) + CY=VALS(2) + BELEV=VALS(3) + NP = MAX(NP,J) + CORD(J,1) = CX + CORD(J,2) = CY + XUSR(J) = CX + YUSR(J) = CY + WD(J) = BELEV + INSKP(J)=0 + INEW(J) = 1 + GO TO 20 + ELSE + WDTHX=VALS(1) + SS1X=VALS(2) + SS2X=VALS(3) + WDSX=VALS(4) + WIDTH(J)=WDTHX + SS1(J)=SS1X + SS2(J)=SS2X + WIDS(J)=WDSX + GO TO 20 + ENDIF + ENDIF +!c IF (J .GT. 9000) GOTO 98 + IF (J .GE. MAXP) THEN +!ipk jan98 CALL SETD(23) + call clscrn() + WRITE(dlin,*) ' Node number exceeds MAXP in RDCORD',j + call symbl & + & (1.1,3.3,0.20,dlin,0.0,80) + WRITE(90,*) ' Node number exceeds MAXP in RDCORD' + WRITE(DLIN,*) ' Press enter to exit' + call symbl & + & (1.1,3.0,0.20,dlin,0.0,80) + ndig=1 + CALL GTCHARX(ANS32,ndig,5.0,4.0) +!ipk jan98 READ(*,'(A)') IJNK + CALL Quit_Pgm + STOP + ENDIF + NP = MAX(NP,J) + CORD(J,1) = CX + CORD(J,2) = CY + XUSR(J) = CX + YUSR(J) = CY + WD(J) = BELEV + WIDTH(J)=WDTHX + SS1(J)=SS1X + SS2(J)=SS2X + WIDS(J)=WDSX +!IPK JUL98 + WIDBS(J)=WEL + SSO(J)=SSSO + INSKP(J)=0 + INEW(J) = 1 +!IPK FEB02 ADD LOCK + LOCK(J)=LOCK1 + BS1(J)=BS11 + IF(ITRIAN .EQ. 1) THEN + IF((JZ .EQ. 0 .AND. J .EQ. NPPP) .OR. (JZ .EQ. 1 .AND. J .EQ. NPPP-1)) GO TO 400 + ENDIF +! + GOTO 20 +! + 98 CONTINUE + NLST=0 + KK=0 + 102 continue + if(np .gt. 99999) then + READ(IUNIT,'(16I6)') IRLINE + else + READ(IUNIT,'(16I5)') IRLINE + endif + IF(IRLINE(1) .EQ. 9999 .or. IRLINE(1) .EQ. 99999) GO TO 300 + IF(KK .EQ. 0) NLST=NLST+1 + 104 DO 105 K=1,16 + IF(IRLINE(K) .EQ. 0) GO TO 106 + KK=KK+1 + ILIST(NLST,KK)=IRLINE(K) + 105 CONTINUE + GO TO 102 + 106 CONTINUE + LLIST(NLST)=KK + KK=0 + GO TO 102 + 300 CONTINUE +! IF(NLAYD .GT. 0) THEN +! DO 320 L=1,NP +! READ(IUNIT,'(2I5)') I,LAY(I) +! IF(I .GT. 9000) GO TO 325 +! 320 CONTINUE +! 325 CONTINUE +! ENDIF +!IPK JAN01 + READ(IUNIT,'(I5)',end=375) NENTRY + IF(NENTRY .GT. 0) THEN + READ(IUNIT,'(15I5)') (NEF(I,1),NEF(I,2),NEF(I,3),I=1,NENTRY) + ENDIF + READ(IUNIT,'(I5)', end=375) NCLM + write(90,*) 'INOUT-695 NCLM',nclm + IF(NCLM .GT. 0) THEN + READ(IUNIT,'(A3,A77)') ID,DLIN2 + WRITE(90,'(''INOUT-698'',A3,A77)'),ID,DLIN + IF(ID .EQ. 'CC1') THEN + 330 READ(DLIN2,'(I5,9I8)') I,(ICCLN(I,J),J=1,9) + WRITE(90,'(I5,9I8)') I,(ICCLN(I,J),J=1,9) + NL=1 + 340 NL=NL+9 + READ(IUNIT,'(A3,A77)',end=375) ID,DLIN2 + WRITE(90,'(''INOUT-705'',A3,A77)'),ID,DLIN + IF(ID .EQ. 'CC2') THEN + READ(DLIN2,'(5X,9I8)') (ICCLN(I,J),J=NL,NL+8) + ELSEIF(ID .EQ. 'CC1') THEN + GO TO 330 + ELSEIF(ID .EQ. 'END') THEN + GO TO 375 + ENDIF + GO TO 340 + ENDIF + ENDIF + + 375 CONTINUE + WRITE(90,*) 'INOUT-718 NCLM',NCLM + ELSE + IF(IUNIT .EQ. 11) THEN +!IPK FEB03 READ(IUNIT) & +!IPK FEB03 & (XUSR(J),YUSR(J),WD(J),WIDTH(J),SS1(J),SS2(J),WIDS(J), & +!IPK FEB03 & WIDBS(J),SSO(J),BS1(J),J=1,NP) +!IPK FEB03!ipk jan99 + (XUSR(J),YUSR(J),WD(J),WIDTH(J),SS1(J),SS2(J),WIDS(J) +!IPK FEB03 DO 350 J=1,NP +!IPK FEB03 CORD(J,1) = XUSR(J) +!IPK FEB03 CORD(J,2) = YUSR(J) +!IPK FEB03 INSKP(J)=0 +!IPK FEB03 IF (CORD(J,1) .GT. VDX) THEN +!IPK FEB03 INEW(J) = 1 +!IPK FEB03 ENDIF +!IPK FEB03 350 CONTINUE +!IPK FEB03 READ(IUNIT) NLST +!IPK FEB03 IF(NLST .GT. 0) THEN +!IPK FEB03 READ(IUNIT) (LLIST(J),J=1,NLST), & +!IPK FEB03 ((ILIST(J,I),I=1,LLIST(J)),J=1,NLST) +!IPK FEB03 ENDIF + +!IPK FEB03 READ(IUNIT) NENTRY,NLAYD,NCLM +!IPK FEB03 IF(NENTRY .GT. 0) THEN +!IPK FEB03 READ(IUNIT) ((NEF(I,J),J=1,3),I=1,NENTRY) +!IPK FEB03 ENDIF +!IPK FEB03 IF(NLAYD .GT. 0) THEN +!IPK FEB03 READ(IUNIT) (LAY(I),I=1,NP) +!IPK FEB03 ENDIF +!IPK FEB03 IF(NCLM .GT. 0) THEN +!IPK FEB03 READ(IUNIT) ((ICCLN(I,J),J=1,350),I=1,NCLM) +!IPK FEB03 ENDIF + + CALL RDRST(3,IUNIT) + + ELSE + DO 360 J=1,NP + XUSR(J) = CORD(J,1) + YUSR(J) = CORD(J,2) +!!apr99 INSKP(J)=0 + IF (CORD(J,1) .GT. VDX) THEN + INSKP(J)=0 + INEW(J) = 1 + ENDIF + 360 CONTINUE + ENDIF + ENDIF + 400 CONTINUE + WRITE(90,*) 'INOUT-762 NCLM',NCLM + +! +!ipk jun02 look for nodes that do not have coordinates but are defined in NOP + + do n=1,ne + if(imat(n) .gt. 0) then + ncn=ncorn(n) + if(ncn .eq. 3) then + n1=nop(n,2) + if(n1 .ne. 0) then + if(inew(n1) .ne. 1) then + cord(n1,1)=(cord(nop(n,1),1)+cord(nop(n,3),1))/2. + cord(n1,2)=(cord(nop(n,1),2)+cord(nop(n,3),2))/2. + XUSR(n1) = CORD(n1,1) + YUSR(n1) = CORD(n1,2) + INSKP(n1)=0 + INEW(n1) = 1 + endif + endif + elseif(ncn .gt. 5) then + do k=2,ncn,2 + n1=nop(n,k) + IF(N1 .NE. 0) THEN + if(inew(n1) .ne. 1) then + kk=mod(k+1,ncn) + cord(n1,1)=(cord(nop(n,k-1),1)+cord(nop(n,kk),1))/2. + cord(n1,2)=(cord(nop(n,k-1),2)+cord(nop(n,kk),2))/2. + XUSR(n1) = CORD(n1,1) + YUSR(n1) = CORD(n1,2) + INSKP(n1)=0 + INEW(n1) = 1 + NP = MAX(NP,n1) + endif + ENDIF + if(inew(nop(n,k-1)) .eq. 0) then + CALL EltERRDisp(n,ims) + if(ims .eq. 1) CALL DELTEL(n) + go to 120 + endif + enddo +120 continue + endif + endif + enddo + WRITE(90,*) 'INOUT-797 NCLM',NCLM + + WRITE(MESG,6010) NE + 6010 FORMAT(I7,' Nodes read from file') + CALL SYMBL(1.1,3.3,0.25,mesg,0.0,28) + + RETURN +! + END +! +!**************************************************************** +! + SUBROUTINE RDMAP(IFIRST,IMPP,JSTT,KSTT) +! +! Read in coordinates of map lines +! + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + DIMENSION NTMP(9) + DIMENSION VALS(2000) + INTEGER*8 II +! + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + CHARACTER*80 ALIN,lind +!ipk jan98 CHARACTER*1 IJNK + CHARACTER*1 ans + CHARACTER*32 ANS32 + CHARACTER*5 LAB1 + CHARACTER*9 LAB2 + CHARACTER*8 LAB3 + CHARACTER*12 LAB4 + CHARACTER*4 HEDR +! + 5 continue + + + ielvsw=0 +! IF (IFIRST .EQ. 0) THEN + IF(IFIRST .EQ. 2) IMP=IMPP + VOID = - 1.0E+10 + VDX = -1.0E+9 + CXO=VDX + CYO=VDX + DO 10 J=JSTT+1,MAXPL + CMAP(J,1) = VOID + CMAP(J,2) = VOID + XMAP(J) = VOID + YMAP(J) = VOID + 9 CONTINUE + 10 CONTINUE + write(90,*) 'maxpl in rdmap - 1 ',maxpl +!ipk jan98 + ylv=7.9 + call clscrn +! ENDIF +! +!ipkfeb94 added logic + if(imp .eq. 9) then +! + I=0 + J=0 + K=1 +20 READ(IMP,'(A80)') ALIN + if(alin(1:5) .eq. 'NCOLS') THEN + CALL RDESRI(alin,j,k) + GO TO 98 + ENDIF +!ipk oct96 addition to identify first point + KFIRST=0 + I=I+1 + IF(MOD(I,25) .EQ. 0) REWIND 90 + WRITE(90,'(2i5,A65)') I,K,ALIN +!ipk oct94 3 lines added + if(mod(i,2000) .eq. 0) then +!ipk jan98 write(*,*) i,' map lines now processed' + ylv=ylv-0.3 + if(ylv .lt. 0.1) then + ylv=7.9 + call clscrn + endif + write(lind,6010) i + call symbl & + & (1.1,ylv,0.20,LIND,0.0,80) + endif + DO KC=1,5 + IF(ALIN(KC:KC) .EQ. 'E' .OR. ALIN(KC:KC) .EQ. 'e') THEN + GO TO 98 + ENDIF + ENDDO + READ(ALIN,*) LINTYP(K),VALL + valkp=vall + IF(K .GT. MAXLIN) THEN +!ipk dec09 CALL SETD(23) +!ipk jan98 +!ipk dec09 WRITE(lind,*) 'Too many map lines. increase maxlin in common' +!ipk dec09 ylv=ylv-0.6 +!ipk dec09 if(ylv .lt. 0.1) then +!ipk dec09 ylv=7.9 +!ipk dec09 call clscrn +!ipk dec09 endif +!ipk dec09 call symbl & +!ipk dec09 & (1.1,ylv,0.20,LIND,0.0,80) +!ipk dec09 WRITE(90,*) 'Too many map lines. increase maxlin in common' +!ipk jan98 WRITE(*,*) ' Press enter to exit' +!ipk jan98 READ(*,'(A)') IJNK +!ipk dec09 WRITE(LIND,*) ' Press enter to exit' +!ipk dec09 call symbl & +!ipk dec09 & (1.1,ylv-0.3,0.20,lind,0.0,80) +!ipk dec09 ndig=1 +!ipk dec09 CALL GTCHARX(ANS,IJNK,5.0,4.0) +!ipk dec09 CALL Quit_Pgm + + MAXPLL=MAXPL + call ADJUSTMAP(MAXPLL) + MAXPL=MAXPLL + deallocate (CMAP,XMAP,YMAP,VAL,imap,NCRS) + + allocate (CMAP(MAXPL,2),XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL)) + + ALLOCATE (imap(maxpl),NCRS(MAXPL)) + + maxpts=maxpl + ifirst=0 + rewind imp + go to 5 + + ENDIF + 21 CONTINUE + READ(IMP,'(A80)') ALIN + +!ipk sep05 + + do i=1,80 + if(alin(i:i) .eq. char(9)) then + alin(i:i)=',' + endif + enddo + + I=I+1 + IF(MOD(I,25) .EQ. 0) REWIND 90 + WRITE(90,'(2i5,A65)') I,K,ALIN +!ipk oct94 3 lines added + if(mod(i,10000) .eq. 0) then +!ipk jan98 write(*,*) i,' map lines now processed' + ylv=ylv-0.3 + if(ylv .lt. 0.1) then + ylv=7.9 + call clscrn + endif + write(lind,6010) i + 6010 format(i8,' map points processed') + call symbl & + & (1.1,ylv,0.20,LIND,0.0,80) + endif + DO KC=1,5 + IF(ALIN(KC:KC) .EQ. 'E' .OR. ALIN(KC:KC) .EQ. 'e') THEN + GO TO 97 + ENDIF + ENDDO +!ipk oct96 change to permit more line types +!ipk jan01 IF(LINTYP(K) .NE. 2 .and. valkp .lt. -9998.) THEN +!IPK APR03 IF(LINTYP(K) .NE. 2 .and. valkp .ne. 0.) THEN +!IPK APR03 READ(ALIN,*) CX, CY +!IPK APR03 vall=valkp +!IPK APR03 ELSE +!IPK APR03 READ(ALIN,*) CX, CY, VALL +!IPK APR03 ENDIF + IF(LINTYP(K) .EQ. 2) THEN + READ(ALIN,*) CX, CY, VALL + ELSEIF(VALKP .LT. 9999.) THEN + READ(ALIN,*) CX, CY + vall=valkp + ELSEIF(VALKP .EQ. 9999.) THEN + READ(ALIN,*) CX, CY, VALL + ENDIF +!ipk oct96 addition to prevent test on first point + if(kfirst .ne. 0) then + IF(CX .EQ. CXO .AND. CY .EQ. CYO) GO TO 21 + else + kfirst=1 + endif + IF(J .EQ. MAXPL) THEN + CALL SETD(23) +!ipk jan98 WRITE(*,*) 'Too many map points. increase maxpl in co +!ipk jan98 WRITE(90,*) 'Too many map points. increase maxpl in c +!ipk jan98 WRITE(*,*) ' Press enter to exit' +!ipk jan98 READ(*,'(A)') IJNK +!ipk jan98 +!ipk dec09 WRITE(lind,6030) maxpl +!ipk dec09 6030 format ('Map point exceed',i10,' increase maxpl in common' ) +!ipk dec09 ylv=ylv-0.6 +!ipk dec09 if(ylv .lt. 0.1) then +!ipk dec09 ylv=7.9 +!ipk dec09 call clscrn +!ipk dec09 endif +!ipk dec09 call symbl & +!ipk dec09 & (1.1,ylv,0.20,LIND,0.0,80) +!ipk dec09 WRITE(90,6030) maxpl +!ipk jan98 WRITE(*,*) ' Press enter to exit' +!ipk jan98 READ(*,'(A)') IJNK +!ipk dec09 WRITE(LIND,*) ' Press enter to exit' +!ipk dec09 call symbl & +!ipk dec09 & (1.1,ylv-0.3,0.20,lind,0.0,80) +!ipk dec09 ndig=1 +!ipk dec09 CALL GTCHARX(ANS,IJNK,5.0,4.0) +!ipk dec09 CALL Quit_Pgm + + call ADJUSTMAP(MAXPL) + deallocate (CMAP,XMAP,YMAP,VAL,imap,NCRS) + + allocate (CMAP(MAXPL,2),XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL)) + + ALLOCATE (imap(maxpl),NCRS(MAXPL)) + + maxpts=maxpl + + rewind imp + go to 5 + + + + + ENDIF + J=J+1 + CMAP(J,1) = CX + CMAP(J,2) = CY + XMAP(J) = CX + YMAP(J) = CY + VAL(J) = VALL + CXO=CX + CYO=CY +! + GOTO 21 +! + 97 CONTINUE + J=J+1 + K=K+1 + GO TO 20 + 98 CONTINUE +!ipk feb94 + klint=k-1 + jlint=j +!ipk feb94 end change + J=J+1 + +!IPK FEB03 + + MAXPTS=J-2 + + write(90,*) 'maxpts in rdmap - 2 ',maxpts,xmap(908) + +!IPK FEB02 SCLAE NEW VALUES + + IF(IFIRST .EQ. 2) THEN + IF(CMAP(MAXPTS,1) .GE. VDX) MAXPTS=MAXPTS+1 + DO K=1,MAXPTS + IF (CMAP(K,1) .GT. VDX) THEN + CMAP(K,1) = (CMAP(K,1)+XS)/TXSCAL + CMAP(K,2) = (CMAP(K,2)+YS)/TXSCAL + ENDIF + END DO + ENDIF + write(90,*) 'maxpts',maxpts + CLOSE(IMP) +! do k=1,maxpts +! write(90,*) cmap(k,1),cmap(k,2),xmap(k),ymap(k),val(k) +! enddo + RETURN + ELSEIF(IMP .EQ. 113) THEN + CALL READSHP +! +! +!ipkfeb94 logic to add binary read of map +! + elseif(imp .eq. 92 .OR. IMP .GT. 94) then + + +!ipk jan98 test for max lines + read(imp) klint,jlint + rewind imp + if(klint+KSTT .gt. maxlin .or. jlint +JSTT .gt. maxpl) then + call clscrn + write(lind,6310) + 6310 format(' Compilation limits exceeded') + call symbl & + & (0.5,3.5,0.20,LIND,0.0,80) + write(lind,6311) maxpl,jlint + 6311 FORMAT(' Maximum map points =',2i8,' points requested') + call symbl & + & (0.5,3.2,0.20,LIND,0.0,80) + write(lind,6312) maxlin,klint + 6312 FORMAT( ' Maximum lines =',2i8,' lines requested') + call symbl & + & (0.5,2.9,0.20,LIND,0.0,80) + WRITE(LIND,*) ' Press enter to exit' + call symbl & + & (0.5,2.0,0.20,lind,0.0,80) + ndig=1 + CALL GTCHARX(ANS32,IJNK,5.0,4.0) + CALL Quit_Pgm + STOP + endif + read(imp) klint,jlint,(xmap(j),ymap(j),val(j),j=JSTT+1,JSTT+jlint) & + & ,(lintyp(k),k=KSTT+1,KSTT+klint) + read(imp,end=200) nelts ,((nopel(j,k),k=1,3),j=1,nelts) + maxpts=jlint+JSTT + go to 220 + 200 continue + MAXPTS=JLINT+JSTT + nelts=0 + 220 continue + do j=JSTT+1,JSTT+jlint + cmap(j,1)=xmap(j) + cmap(j,2)=ymap(j) + enddo + JLINT=MAXPTS + KLINT=KSTT+klint + ELSEIF(IMP .EQ. 94) THEN + READ(IMP,'(A4)') HEDR + IF(HEDR .EQ. 'DSAA') THEN + READ(IMP,*) NCOLS1,NROWS1 + maxpts=ncols1*nrows1 + if(maxpts .gt. maxpl) then + maxpl=maxpts+1 + deallocate (CMAP,XMAP,YMAP,VAL,imap,NCRS) + + allocate (CMAP(MAXPL,2),XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL)) + + ALLOCATE (imap(maxpl),NCRS(MAXPL)) + + endif + READ(IMP,*) XXORG,XXTOP,YYORG,YYTOP + READ(IMP,*) DD1,DD2 + DXINT=(XXTOP-XXORG)/(NCOLS1-1) + DYINT=(YYTOP-YYORG)/(NROWS1-1) + JJ=0 + II=0 + ANODAT=1.E36 + READ(IMP,*) (VAL(I),I=1,MAXPTS) + DO J=NROWS1,1,-1 + DO I=1,NCOLS1 + II=II+1 + IF(VAL(II) .GT. ANODAT) CYCLE + JJ=JJ+1 + XMAP(JJ)=DXINT*(I-1)+XXORG + YMAP(JJ)=DYINT*(NROWS1+1-J)+YYORG + CMAP(JJ,1)=XMAP(JJ) + CMAP(JJ,2)=YMAP(JJ) + VAL(JJ)=VAL(II) + ENDDO + ENDDO + + ELSE + REWIND IMP + READ(IMP,*) LAB1,NCOLS1 + READ(IMP,*) LAB1,NROWS1 + maxpts=ncols1*nrows1 + if(maxpts .gt. maxpl) then + maxpl=maxpts+1 + deallocate (CMAP,XMAP,YMAP,VAL,imap,NCRS) + + allocate (CMAP(MAXPL,2),XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL)) + + ALLOCATE (imap(maxpl),NCRS(MAXPL)) + + endif + READ(IMP,*) LAB2,XXORG + READ(IMP,*) LAB2,YYORG + READ(IMP,*) LAB3,CELLSIZ + READ(IMP,*) LAB4,ANODAT + JJ=0 + II=0 + READ(IMP,*) (VAL(I),I=1,MAXPTS) + DO J=1,NROWS1 +! READ(IMP,*) (VALS(I),I=1,NCOLS1) + DO I=1,NCOLS1 + II=II+1 + IF(VAL(II) .EQ. ANODAT) CYCLE + JJ=JJ+1 + XMAP(JJ)=CELLSIZ*(I-1)+XXORG + YMAP(JJ)=CELLSIZ*(NROWS1+1-J)+YYORG + CMAP(JJ,1)=XMAP(JJ) + CMAP(JJ,2)=YMAP(JJ) + VAL(JJ)=VAL(II) + ENDDO + ENDDO + ENDIF + MAXPTS=JJ + XMAP(MAXPTS+1)= VOID + + KLINT=1 + LINTYP(1)=2 + else + +! READ AN RM1 FILE AS A MAP FILE + +! first headers + jlint=0 + READ(IMP,'(a80)') alin + READ(IMP,5010) IPP,nnrl8 + 5010 FORMAT( 30x,i5,60x,i10) + READ(IMP,'(a80)') alin + IF(IPP .GT. 0) READ(IMP,'(a80)') ALIN + +! next elements + + 230 CONTINUE + read(imp,'(a80)',end=300) ALIN + + IF(ALIN(6:20) .EQ. ' ') GO TO 250 + if(mod(nnrl8,2) .eq. 0) then + READ(ALIN,'(10I5)',END=250) J, (NTMP(K),K=1,9) + else + READ(ALIN,'(10I6)',END=250) J, (NTMP(K),K=1,9) + endif + NOPEL(J,1)=NTMP(1) + NOPEL(J,2)=NTMP(3) + NOPEL(J,3)=NTMP(5) + NELTS=MAX(J,NELTS) + GO TO 230 + +! finally nodes + 250 CONTINUE + read(imp,'(a80)',end=300) ALIN + if(ALIN(11:30) .eq. ' ') go to 300 + if(nnrl8 .lt. 2) then + READ(alin,'(I10,3F10.0)') J, CX, CY,BELEV + + else + READ(alin,'(I10,2f20.0,F10.0)') J, CX, CY, BELEV + + endif + xmap(j)=cx + CMAP(J,1)=CX + ymap(j)=cy + CMAP(J,2)=CY + val(j)=belev + jlint=max(j,jlint) + + GO TO 250 + + 300 maxpts=jlint + klint=1 + lintyp(1)=2 + ENDIF + +!IPK FEB02 SCALE NEW VALUES + + IF(IFIRST .EQ. 2) THEN + DO K=JSTT+1,MAXPTS + IF (CMAP(K,1) .GT. VDX) THEN + CMAP(K,1) = (CMAP(K,1)+XS)/TXSCAL + CMAP(K,2) = (CMAP(K,2)+YS)/TXSCAL + ENDIF + END DO + ENDIF + CLOSE(IMP) + return + END +! +!*********************************************************************** +! + SUBROUTINE RDELEM(IUNIT) +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' + CHARACTER*1 AA,ANS + CHARACTER*32 ANS32 + CHARACTER*81 DLIN + CHARACTER*150 DLIN1 + CHARACTER*3 ID +!cipk aug00 + CHARACTER*80 LIND + CHARACTER*25 BLANK + CHARACTER*31 MESG + DIMENSION NTMP(9),ATT(9) +! + DATA IFIRST / 0 / + DATA IERRL /0/ + DATA BLANK /' '/ +!ipk jul94 add a line + MEL=MAXE +!cipk aug00 + ylv=7.5 +! +! Read in existing elements +! + IF (IFIRST .EQ. 0) THEN +! +! Initialize arrays +! + VOID = - 1.0E+10 + VDX = -1.E+9 + IF(IIN .EQ. 10) NE = 0 + IFIRST = 1 + ENDIF + ISTART=0 + NTMP=0 + ATT=0. +! + IF(IUNIT .EQ. 0) RETURN + IF(IUNIT .EQ. 10) THEN + + IF(IGFG .GT. 0) REWIND IUNIT + JZ=0 +!ipk oct96 move around login to allow long length files + 10 CONTINUE + IF(IGFG .EQ. 0 .AND. ITRIAN .EQ. 0) THEN + READ(IUNIT,'(A81)',END=98) DLIN +!ipk mar04 IF(DLIN(6:20) .EQ. BLANK .AND. IERRL .EQ. 0) THEN + IF(DLIN(7:20) .EQ. BLANK .AND. IERRL .EQ. 0) THEN + GO TO 175 +!ipk dec97 generalize to allow multiple errors +!ipk dec97 ELSEIF(IERRL .EQ. 1) THEN + ELSEIF(IERRL .EQ. 1 .and. dlin(6:20) .eq. blank) THEN + CALL SETD(23) +!cipk aug00 + WRITE(lind,6000) + 6000 FORMAT(' Press enter to exit') + call symbl & + & (1.1,ylv-0.3,0.20,lind,0.0,80) + ndig=1 + CALL GTCHARX(ANS32,IJNK,5.0,4.0) + CALL Quit_Pgm + STOP + + ENDIF + ifree=1 + do j=1,10 + if(dlin(j:j) .eq. ',') then + ifree=0 + endif + enddo + if(ifree .eq. 1) then + if(mod(ntempin,2) .eq. 0) then + READ(DLIN,'(10I5,F10.3,I5)',END=98) J, (NTMP(K),K=1,9),THT & + & ,NTEMP + else + READ(DLIN,'(10I6,F10.3,I6)',END=98) J, (NTMP(K),K=1,9),THT & + & ,NTEMP + endif + else + READ(DLIN,*,END=98) J, (NTMP(K),K=1,9),THT & + & ,NTEMP + endif + ELSEIF(ITRIAN .EQ. 1) THEN + IF(ISTART .EQ. 0) THEN + REWIND(IUNIT) + READ(IUNIT,*) NE,NCNTR,NATTR + ISTART=1 + ENDIF + READ(IUNIT,*) J,(NTMP(K),K=1,NCNTR),(ATT(K),K=1,NATTR) + IF(J .EQ. 0) THEN + JZ=1 + J=NE + ENDIF + ELSE +!ipk jun02 Allow for GFGEN input + DO ICOUNTC=1,700000 + DO JJ=1,150 + DLIN1(JJ:JJ)=' ' + ENDDO + READ(IUNIT,'(A3,A150)', END=175) ID,DLIN1 + IF(ID .EQ. 'GE ') THEN +! Count the number of variables + I=0 + ICOUNT=0 + 75 CONTINUE + IF(DLIN1(I+1:I+1) .NE. ' ') THEN + GO TO 80 + ELSE + I=I+1 + GO TO 75 + ENDIF + 80 I=I+1 + IF(I .EQ. 151) THEN + ICOUNT =ICOUNT+1 + GO TO 90 + ENDIF + IF(DLIN1(I:I) .EQ. ' ' .OR. DLIN1(I:I) .EQ. ',') THEN + ICOUNT=ICOUNT+1 + 85 CONTINUE + IF(I+1 .EQ. 151) GO TO 90 + IF(DLIN1(I+1:I+1) .EQ. ' ') THEN + I=I+1 + GO TO 85 + ELSE + GO TO 80 + ENDIF + ELSE + GO TO 80 + ENDIF + ELSEIF(ID .EQ. 'E3T') THEN + ICOUNT=4 + GO TO 90 + ELSEIF(ID .EQ. 'E4Q') THEN + ICOUNT=5 + GO TO 90 + ENDIF + ENDDO + 90 CONTINUE + IF(ICOUNT .GT. 10) THEN + READ(DLIN1,*) J, (NTMP(K),K=1,9),THT + ELSEIF(IGFG .EQ. 3) THEN + IF(ICOUNT .EQ. 4) THEN + READ(DLIN1,*) J, (NTMP(K),K=1,7,2) + IF(NTMP(7) .EQ. 0) NTMP(9)=1 + NTMP(2)=0 + NTMP(4)=0 + NTMP(6)=0 + NTMP(7)=0 + NTMP(8)=0 + ELSEIF(ICOUNT .EQ. 5) THEN + READ(DLIN1,*) J, (NTMP(K),K=1,9,2) + IF(NTMP(9) .EQ. 0) NTMP(9)=1 + NTMP(2)=0 + NTMP(4)=0 + NTMP(6)=0 + NTMP(8)=0 + ENDIF + ELSE + READ(DLIN1,*) J, (NTMP(K),K=1,9) + ENDIF + ENDIF + +!c IF (J .GT. 9000 .AND. IERRL .EQ. 0) THEN +!c GO TO 175 +!IPK OCT96 END CHANGES + IF (J .GE. MEL) THEN + CALL SETD(23) +!cipk aug00 + WRITE(lind,*) ' Element number exceeds MAXE in RDELEM' + call symbl & + & (1.1,ylv-0.3,0.20,lind,0.0,80) + ndig=1 + WRITE(90,*) ' Element number exceeds MAXE in RDELEM' + WRITE(lind,6000) + CALL GTCHARX(ANS32,IJNK,5.0,4.0) + CALL Quit_Pgm + STOP + ENDIF +! +! Check to ensure there are no duplicate numbers in input stream +! of element connections +! + DO 12 K=1,7 + IF(NTMP(K) .EQ. 0) GO TO 12 + DO 11 L=K+1,8 + IF(NTMP(K) .EQ. NTMP(L)) THEN + CALL SETD(23) +!cipk aug00 +! WRITE(90,5000) J +! write(90,5001) (NTMP(MM),MM=1,8) +! WRITE(lind,5000) J +! call symbl & +! & (1.1,ylv-0.3,0.25,lind,0.0,80) +! ylv=ylv-0.3 +! if(ylv .lt. 0.4) then +! call clscrn +! ylv=7.5 +! endif +! write(lind,5001) (NTMP(MM),MM=1,8) +! call symbl & +! & (1.1,ylv-0.3,0.25,lind,0.0,80) +! ylv=ylv-0.3 +! if(ylv .lt. 0.4) then +! call clscrn +! ylv=7.5 +! endif + 5000 FORMAT(' **ERROR** Nodes at element number',i5,' are duplicated') + 5001 FORMAT(' node list as follows ',8i5) +! IERRL=1 + DO KK=1,8 + NOP(J,KK) = NTMP(KK) + ENDDO + IMAT(J)=NTMP(9) + call eltdisp(j) + DO KK=1,8 + NTMP(KK) = NOP(J,KK) + ENDDO + NTMP(9)=IMAT(J) + GO TO 13 + ENDIF + 11 CONTINUE + 12 CONTINUE + 13 CONTINUE + IF(ITRIAN .EQ. 0) THEN + DO 15 K=1,8 + NOP(J,K) = NTMP(K) + ND = NTMP(K) + IF (ND .GT. 0) THEN + INEW(ND) = 2 + NP = MAX(NP,ND) + ENDIF + 15 CONTINUE + IMAT(J) = NTMP(9) + THTA(J)=0 + IEM(J) = j + ELSE + DO K=1,3 + NOP(J,2*K-1)=NTMP(K) + IF(NCNTR .EQ. 3) THEN + NOP(J,2*K)=0 + ELSEIF(NCNTR .EQ. 6) THEN + NOP(J,2*K)=NTMP(K+3) + ENDIF + ND = NTMP(K) + IF (ND .GT. 0) THEN + INEW(ND) = 2 + NP = MAX(NP,ND) + ENDIF + ENDDO + NOP(J,7)=0 + NOP(J,8)=0 + IF(NATTR .GT. 0) THEN + IMAT(J)=ATT(1)+0.5 + IF(NATTR .GT. 1) THEN + THTA(J)=ATT(2) + IF(NATTR .GT. 2) THEN + IEM(J)=ATT(3) + ELSE + IEM(J)=0 + ENDIF + ELSE + THTA(J)=0. + IEM(J)=0 + ENDIF + ELSE + IMAT(J)=1 + THTA(J)=0. + IEM(J)=0 + ENDIF + ENDIF + NCN = 2 + IF (NOP(J,3) .NE. 0) NCN = 3 + IF (NOP(J,4) .NE. 0) NCN = 4 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .NE. 0) NCN = 5 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .EQ. 0) NCN = 6 + IF (NOP(J,6) .NE. 0) NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + NCORN(J) = NCN + IESKP(J) = 0 + DO 25 K=2,NCN,2 + ND = NTMP(K) + IF (ND .GT. 0) THEN + IF(NCN .EQ. 5 .AND. K .EQ. 4) GO TO 25 + WD(ND)=0. + ENDIF + 25 CONTINUE + IF(ITRIAN .EQ. 1) THEN + IF((JZ .EQ. 0 .AND. J .EQ. NE) .OR. (JZ .EQ. 1 .AND. J .EQ. NE-1)) THEN + CLOSE(IUNIT) + DO L=255,1,-1 + IF(FNAMKEP(L:L) .EQ. '.') THEN + FNAMKEP(L+1:L+1)='n' + FNAMKEP(L+2:L+2)='o' + FNAMKEP(L+3:L+3)='d' + FNAMKEP(L+4:L+4)='e' + OPEN(IUNIT,FILE=FNAMKEP,STATUS='OLD',ACTION='READ') + IF(JZ .EQ. 1) THEN + READ(IUNIT,*) NPPP,NDUM,NATTR + REWIND(IUNIT) + DO J=1,NE + DO K=1,5,2 + IF(NOP(J,K) .EQ. 0) NOP(J,K)=NPPP + ENDDO + ENDDO + ENDIF + GO TO 175 + ENDIF + ENDDO + ENDIF + ENDIF + NE = MAX(J,NE) +! + GOTO 10 +! + 98 CONTINUE + ELSE + IF(IUNIT .EQ. 11) THEN +!IPK FEB03 READ(IUNIT) ((NOP(J,K),K=1,8),IMAT(J),THTA(J),J=1,NE) + + CALL RDRST(2,IUNIT) + ENDIF + DO 140 J=1,NE + IF(IMAT(J) .EQ. 0) GO TO 140 + NCN = 2 + IF (NOP(J,3) .NE. 0) NCN = 3 + IF (NOP(J,4) .NE. 0) NCN = 4 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .NE. 0) NCN = 5 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .EQ. 0) NCN = 6 + IF (NOP(J,6) .NE. 0) NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + NCORN(J) = NCN + IESKP(J) = 0 +! DO 125 K=2,NCN,2 +! ND = NOP(J,K) +! IF (ND .GT. 0) THEN +! IF(NCN .EQ. 5 .AND. K .EQ. 4) GO TO 125 +! WD(ND)=0. +! ENDIF +! 125 CONTINUE + 140 CONTINUE + ENDIF +! +! Set up junction counter array +! + 175 CONTINUE + DO 180 N=1,NP + IJUN(N)=0 + 180 END DO + DO 200 N=1,NE +!ipkoct93 IF(IMAT(N) .GT. 900) THEN + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) THEN + DO 190 K=1,NCORN(N) + IF(NOP(N,K) .GT. 0) THEN + IJUN(NOP(N,K))=K + ENDIF + 190 CONTINUE + ENDIF + 200 END DO + WRITE(MESG,6010) NE + 6010 FORMAT(I7,' Elements read from file') + CALL SYMBL(1.1,4.3,0.25,mesg,0.0,31) + RETURN + END + SUBROUTINE CHKCON(IREP) + USE WINTERACTER +! +! Check connectivity of grid +! +!- + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + CHARACTER*80 LIND +! + CHARACTER*1 ANS +! CHARACTER*60 STRELS +! DATA STRELS/' You have tried to save before executing "FILL"'/ +! +! Test to make sure fill has been executed. +! + IF(IREP .EQ. 1) GO TO 100 + ylv=7.5 + IREP = 1 + DO 70 N=1,NE + IF(IMAT(N) .GT. 0) THEN + DO 60 M=2,NCORN(N),2 + IF(NOP(N,M) .EQ. 0 .AND. IMAT(N) .NE. 999) THEN + CALL GETSVPN(ANS) + IF(ANS .EQ. 'T' .OR. ANS .EQ. 't') THEN + IREP = 0 +!ipk nov97 add 0 + CALL PLOTOT(0) + CALL HEDR + RETURN + ELSEIF(ANS .EQ. 'S' .OR. ANS .EQ. 's') THEN +!ipk nov97 add (0) + CALL PLOTOT(0) + CALL HEDR + IREP = 1 + return +! go to 100 +!ipk jun04 RETURN + ELSEIF(ANS .EQ. 'F' .OR. ANS .EQ. 'f') THEN +!ipk aug02 + CALL FILM(0) + IREP = 1 + ELSE + IREP = 2 + ENDIF + ENDIF + 60 CONTINUE + ENDIF + 70 END DO + 100 CONTINUE + + + IDUP=0 + call kcon(1) + do n=1,ne + if(imat(n) .lt. 900 .and. imat(n) .gt. 0) then + ndup=0 + do j=2,ncorn(n),2 + if(nop(n,j) .eq. 0) go to 120 + if(ndelm(nop(n,j)) .gt. 2) then + ndup=ndup+1 + endif + enddo + if(ndup .eq. ncorn(n)/2) then + IDUP=1 + write(90,*) ' DUPLICATE ELEMENT',n + endif + endif + enddo + + 120 continue + + IF(IDUP .EQ. 1) THEN +!cipk aug00 + + Call WMessageBox(1,3,0,'Duplicate elements have been found'//Char(13)//& + 'See file MESSGEN.OUT for details'//'Press OK to continue save',& + 'ERROR IN NETWORK!!') + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then + CALL HEDR + CALL PLOTOT(0) + IREP = 1 + ELSE + IREP = 0 + CALL HEDR +!ipk nov97 add (0) + CALL PLOTOT(0) + RETURN + ENDIF + endif + +! +! Test for areas of each element +! + INEG = 0 + DO 250 N=1,NE + IF(IMAT(N) .GT. 0 .AND. NCORN(N) .GT. 5) THEN + J1=NOP(N,1) + J2=NOP(N,3) + J3=NOP(N,5) + AREA=(CORD(J2,1)-CORD(J1,1))*(CORD(J3,2)-CORD(J1,2))- & + & (CORD(J3,1)-CORD(J1,1))*(CORD(J2,2)-CORD(J1,2)) + IF(AREA .LT. 0.) THEN +! IF(INEG .EQ. 0) CALL CLSCRN +! CALL SETD(23) +!cipk aug00 +! WRITE(lind,*) 'Negative area for element number',N + WRITE(90,*) ' NEGATIVE AREA FOR ELEMENT NUMBER',N +! if(ylv .lt. 0.4) then +! ylv=7.5 +! call clscrn +! endif +! call symbl & +! & (1.1,ylv-0.3,0.20,lind,0.0,80) +! ylv=ylv-0.3 +! ndig=1 + INEG = 1 + GO TO 250 + ENDIF + IF(NCORN(N) .EQ. 8) THEN + J1=NOP(N,3) + J2=NOP(N,5) + J3=NOP(N,7) + AREA=(CORD(J2,1)-CORD(J1,1))*(CORD(J3,2)-CORD(J1,2))- & + & (CORD(J3,1)-CORD(J1,1))*(CORD(J2,2)-CORD(J1,2)) + IF(AREA .LT. 0.) THEN +! IF(INEG .EQ. 0) CALL CLSCRN +! CALL SETD(23) +!cipk aug00 +! WRITE(lind,*) 'Negative area for element number',N + WRITE(90,*) 'Negative area for element number',N +! if(ylv .lt. 0.4) then +! ylv=7.5 +! call clscrn +! endif +! call symbl & +! & (1.1,ylv-0.3,0.20,lind,0.0,80) +! ylv=ylv-0.3 +! ndig=1 + INEG = 1 + ENDIF + ENDIF + ENDIF + 250 END DO + + IF(INEG .EQ. 1) THEN +!cipk aug00 + + Call WMessageBox(1,3,0,'Negative Areas have been found'//Char(13)//& + 'See file MESSGEN.OUT for details'//'Press OK to continue save',& + 'ERROR IN NETWORK!!') + +! WRITE(lind,*) 'If you wish to terminate save enter (t)' +! if(ylv .lt. 0.7) then +! ylv=7.5 +! call clscrn +! endif +! call symbl & +! & (1.1,ylv-0.3,0.20,lind,0.0,80) +! ylv=ylv-0.3 +! WRITE(lind,*) 'If you still wish to save enter (s)' +! call symbl & +! & (1.1,ylv-0.3,0.20,lind,0.0,80) + +!ipk jun96 change * to (a) + +!cipkaug00 READ(*,'(A)') ANS +! READ(*,*) ANS +! CALL GTCHARX(ANS,IJNK,5.0,4.0) + +! CALL SETD(2) +! IF(ANS .EQ. 'T' .OR. ANS .EQ. 't') THEN + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then + CALL HEDR + CALL PLOTOT(0) + IREP = 1 + RETURN + ELSE + IREP = 0 + CALL HEDR +!ipk nov97 add (0) + CALL PLOTOT(0) + RETURN + ENDIF +! ELSEIF(ANS .EQ. 'S' .OR. ANS .EQ. 's') THEN +! CALL HEDR +!ipknov97 add (0) +! CALL PLOTOT(0) +! IREP = 1 +! RETURN +! ENDIF + ENDIF + + RETURN + END +!ipk oct98 update call + SUBROUTINE WRTMAP(isw) +! +! Write map file in binary format +! + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + character*3 ends +! +! +! Open binary map file +! + IF(ISW .GT. 90) THEN + IMPF=ISW + ELSE + impf=93 + ENDIF + +!ipk oct98 + if(isw .eq. 0) then + OPEN(IMPF ,FILE=mpnam,STATUS='unknown',form='unformatted') +!IPK FRB03 + else + rewind impf + endif + + if(isw .eq. 2) then + impf=94 + aninin=-9999. + zero=0. + ends='END' + if(lintyp(1) .eq. 0 .or. lintyp(1) .eq. 1) then + write(impf,*) lintyp(1),aninin + ifm=1 + elseif(lintyp(1) .eq. 2) then + write(impf,*) lintyp(1),zero + ifm=2 + else + write(impf,*) lintyp(1),val(1) + ifm=1 + endif + ilin=1 + do J=1,maxpts + if(xmap(J) .gt. vdx) then + if(ifm .eq. 1) then + write(impf,*) xmap(j),ymap(j) + else + write(impf,*) xmap(j),ymap(j),val(j) + endif + if(j .eq. maxpts) write(impf,'(a3)') ends + else + write(impf,'(a3)') ends + ilin=ilin+1 + if(j .eq. maxpts) go to 200 + if(lintyp(ilin) .eq. 0 .or. lintyp(ilin) .eq. 1) then + write(impf,*) lintyp(ilin),aninin + ifm=1 + elseif(lintyp(ilin) .eq. 2) then + write(impf,*) lintyp(ilin),zero + ifm=2 + else + write(impf,*) lintyp(ilin),val(j+1) + ifm=1 + endif + endif + + enddo + 200 continue + write(impf,'(a3)') ends + return + endif + jlint=maxpts + write(impf) klint,jlint,(xmap(j),ymap(j),val(j),j=1,jlint) & + & ,(lintyp(k),k=1,klint) + + if(nelts .gt. 0) then + write(impf) nelts,((nopel(j,k),k=1,3),j=1,nelts) + endif + return + END + + SUBROUTINE GETSVPN(ANS) + + use winteracter + + implicit none + + include 'D.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: IPOS + INTEGER :: JNK,ierr + CHARACTER*1 :: ANS,CDAT(4) + DATA CDAT/'s','t','f','c'/ + call wdialogload(IDD_DIALOG07) + ierr=infoerror(1) + + + call wdialogputRadioButton(idf_radio1) + + + CALL WDialogSelect(IDD_DIALOG07) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ipos) + ans=cdat(ipos) + return + endif +!IPK SEP02 + ans=cdat(1) + return + enddo + RETURN + END + +!*************************************************************************************** + + subroutine wrtgfg(IOF) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + IOF=IOT + WRITE(IOF,5000) TITLE + 5000 format('T1'/'T2'/'T3 ',A80) + WRITE(IOF,5001) + 5001 FORMAT('SI 1') + WRITE(IOF,5002) + 5002 FORMAT('$L 3 0 6 0') +! +! CURRENTLY DISABLED +! +! IF(NLST .GT. 0) THEN +! DO J=1,NLST +! IF(LLIST(J) .GT. 0) THEN +! IF(J .EQ. 1) THEN +! ILIST(J,LLIST(J))=-ABS(ILIST(J,LLIST(J))) +! ENDIF +! WRITE(IOF,5003) (ILIST(J,I),I=1,LLIST(J)) +! 5003 FORMAT('GO 2',11I6/('GO',12I6)) +! ENDIF +! ENDDO +! ENDIF + DO J=1,NE + IF (IMAT(J) .NE. 0) THEN + IF(IECHG .EQ. 0) IEM(J)=J + WRITE(IOF,5004) & + & J, (NOP(J,K),K=1,8), IMAT(J),THTA(J) + 5004 FORMAT('GE',10(1X,I6),F17.4) + ENDIF + ENDDO + DO J=1,NP + IF (INEW(J) .EQ. 1) THEN + WRITE(IOF, 5005) & + & J,XUSR(J),YUSR(J),WD(J) + 5005 FORMAT('GNN',I6,2F14.3,F10.3) + ENDIF + ENDDO + DO J=1,NP + IF (INEW(J) .EQ. 1) THEN + IF(WIDTH(J) .GT. 0.) THEN + WRITE(IOF, 5006) & + & J, & + & WIDTH(J),SS1(J),SS2(J),WIDS(J) + 5006 FORMAT('GWN',I6,1X,F9.1,1X,2F6.2,1X,F9.1) + ENDIF + ENDIF + ENDDO + + + return + end + + subroutine wrtele(IOF,itr) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + IOF=IOT + NVRT=2 + if(itr .eq. 1) then + NEL=NE + NATT=2 + IF(NOP(1,2) .EQ. 0) THEN + NVRT=3 + ELSE + NVRT=6 + ENDIF + write(IOF,6001) NEL,NVRT,NATT + DO N=1,NE + IF(NVRT .EQ. 3) THEN + WRITE(IOF,6002) N,(NOP(N,J),J=1,5,2),IMAT(N),THTA(N) + ELSE + WRITE(IOF,6003) N,(NOP(N,J),J=1,5,2),(NOP(N,J),J=2,6,2),IMAT(N),THTA(N) + ENDIF + ENDDO + else + NPL=NP + NATT=1 + write(IOF,6001) NPL,NVRT,NATT + DO N=1,NPL + WRITE(IOF,6004) N,XUSR(N),YUSR(N),WD(N) + ENDDO + + endif + 6001 FORMAT(I6,I2,I2,I2) + 6002 FORMAT(I6,3(' ',I6),I5,' ',F6.2) + 6003 FORMAT(I6,6(' ',I6),I5,' ',F6.2) + 6004 FORMAT(I6,2F16.6,F11.4) + return + end + + + SUBROUTINE RDRST(IENT,IUNIT) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*80 ALINE + + IF(IENT .EQ. 1) THEN +! READ(IUNIT) IDUMMY1 + READ(IUNIT) TITLE,NP,NE +! READ(IUNIT) IDUMMY1,IDUMMY2 + READ(IUNIT) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempin +! READ(IUNIT) ,IDUMMY2,IDUMMY3 + READ(IUNIT) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + IPP=0 + NTEMPIN=2 + IF(IPP .GT. 0) THEN +! READ(IIN) IDUMMY3,IDUMMY4 + READ(IIN) ALINE + ENDIF + + ELSEIF(IENT .EQ. 2) THEN +! READ(IUNIT) IDUMMY4,IDUMMY5 + READ(IUNIT) ((NOP(J,K),K=1,8),IMAT(J),THTA(J),J=1,NE) + DO J=1,NE + IF(IMAT(J) .NE. 0) THEN + NCN = 2 + IF (NOP(J,3) .NE. 0) NCN = 3 + IF (NOP(J,4) .NE. 0) NCN = 4 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .NE. 0) NCN = 5 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .EQ. 0) NCN = 6 + IF (NOP(J,6) .NE. 0) NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + NCORN(J) = NCN + IESKP(J) = 0 + ENDIF + ENDDO + ELSE + +! READ(IUNIT) IDUMMY5,IDUMMY6 + READ(IUNIT) & + & (XUSR(J),YUSR(J),WD(J),WIDTH(J),SS1(J),SS2(J),WIDS(J), & + & WIDBS(J),SSO(J),BS1(J),J=1,NP) + DO J=1,NP + CORD(J,1) = XUSR(J) + CORD(J,2) = YUSR(J) + INSKP(J)=0 + INEW(J)=0 + IF (CORD(J,1) .GT. VDX) THEN + INEW(J) = 1 + ENDIF + ENDDO +! READ(IUNIT) IDUMMY5,IDUMMY6 + READ(IUNIT) NLST + IF(NLST .GT. 0) THEN +! READ(IUNIT) IDUMMY5,IDUMMY6 + READ(IUNIT) (LLIST(J),J=1,NLST), & + ((ILIST(J,I),I=1,LLIST(J)),J=1,NLST) + ENDIF + +! READ(IUNIT) IDUMMY5,IDUMMY6 + READ(IUNIT) NENTRY,NLAYD,NCLM + if(nentry .eq. 0 .and. nlayd .eq. 0 .and. nclm .eq. 0) return +! READ(IUNIT) IDUMMY5,IDUMMY6 + IF(NENTRY .GT. 0) THEN +! READ(IUNIT) IDUMMY5,IDUMMY6 + READ(IUNIT) ((NEF(I,J),J=1,3),I=1,NENTRY) + ENDIF + IF(NLAYD .GT. 0) THEN +! READ(IUNIT) IDUMMY5,IDUMMY6 + READ(IUNIT) (LAY(I),I=1,NP),((WTLAY(I,J),J=1,9),I=0,NP) + ENDIF + IF(NCLM .GT. 0) THEN +! READ(IUNIT) IDUMMY5,IDUMMY6 +! NCLM=11 + READ(IUNIT) ((ICCLN(I,J),J=1,350),I=1,NCLM) + ENDIF + ENDIF + RETURN + END + + SUBROUTINE ADJUSTMAP(MAXPLL) +! +! Generate continuity lines +! + + USE WINTERACTER + USE BLKMAP + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: NTYP,NLOCC + + + call wdialogload(IDD_SETMAXMAP) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_SETMAXMAP) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,MAXPLL) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,MAXPLL) + + GO TO 100 + ENDIF + + enddo + + 100 CONTINUE + return + end + + SUBROUTINE RDESRI(alin,k,j) + use blkmap + use blk1mod + real*8 xorig,yorig,cellsize + character*80 alin +! READ HEADERS + read(alin(6:80),*) ncols + READ(IMP,'(A80)') ALIN + read(alin(6:80),*) nrows + READ(IMP,'(A80)') ALIN + read(alin(10:80),*) xorig + READ(IMP,'(A80)') ALIN + read(alin(10:80),*) yorig + READ(IMP,'(A80)') ALIN + read(alin(9:80),*) cellsize + READ(IMP,'(A80)') ALIN + read(alin(13:80),*) xnodat + ntot=ncols*nrows + read(imp,'(10f12.0)') (val(i),i=1,ntot) + ict=0 + ikp=0 + do n=1,nrows + ytemp=cellsize*(n-1)+yorig + do m=1,ncols + ict=ict+1 + if(val(ict) .ne. xnodat) then + xtemp=cellsize*(m-1)+xorig + ikp=ikp+1 + xmap(ikp)=xtemp + ymap(ikp)=ytemp + cmap(ikp,1)=xtemp + cmap(ikp,2)=ytemp + val(ikp)=val(ict) + endif + enddo + LINTYP(1)=2 + k=2 + j=ikp + enddo + RETURN + END \ No newline at end of file diff --git a/src/src83e/INTEL.F90 b/src/src83e/INTEL.F90 new file mode 100644 index 0000000..9fb6fe0 --- /dev/null +++ b/src/src83e/INTEL.F90 @@ -0,0 +1,438 @@ + SUBROUTINE GRELV +! +! THIS ROUTINE COMPUTES THE GRIDDED ELEVATION +! + use winteracter + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' +!- + + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: IERR,ISET + REAL :: ASET + DATA NXP,NYP/30,20/ + DATA ITIM/0/ + + IF(ITIM .EQ. 0) THEN + NX=NXP+2 + NY=NYP+2 + ITIM=0 + ENDIF + + call wdialogload(IDD_GETINTP) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETINTP) + ierr=infoerror(1) + + 100 continue + NXP=NX-2 + NYP=NY-2 + XGR=XGRID*TXSCAL + YGR=YGRID*TXSCAL + CALL WDialogPutINTEGER(IDF_INTEGER1,NXP) + CALL WDialogPutINTEGER(IDF_INTEGER2,NYP) + CALL WDialogPutREAL(IDF_REAL1,XGR) + CALL WDialogPutREAL(IDF_REAL2,YGR) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + CALL WDialogGetINTEGER(IDF_INTEGER1,NXP) + CALL WDialogGetINTEGER(IDF_INTEGER2,NYP) + CALL WDialogGetREAL(IDF_REAL1,XGR) + CALL WDialogGetREAL(IDF_REAL2,YGR) + GO TO 200 + else + NRECC=0 + endif + + enddo + + 200 CONTINUE + NX=NXP+2 + NY=NYP+2 + XGRID=XGR/TXSCAL + YGRID=YGR/TXSCAL +!- + AXMAX = HSIZE + AYMAX = 7.0 + if(xgrid .eq. 0.) then + XGRID = AXMAX/FLOAT(NX-3) + ELSE + NX=(AXMAX/XGRID+0.5)+3 + ENDIF + IF(YGRID .EQ. 0.) THEN + YGRID = AYMAX/FLOAT(NY-3) + ELSE + NY=(AYMAX/YGRID+0.5)+3 + ENDIF + + IF(NX .GT. MAXGRD .OR. NY .GT. MAXGRD) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK, & + 'Maximum number of interpolation points exceeded '//CHAR(13) & + //'Choose a lower resolution.', & + 'Warning') + go to 100 + endif + + CALL LOCATE +! + CALL POINTEL + + RETURN + END + + SUBROUTINE POINTEL +!*********************************** .....POINTS..... +!- +!......SUBROUTINE TO EVALUATE FUNCTION AT GRID POINTS +!- +!- + USE WINTERACTER + USE BLK1MOD + + include 'd.inc' + + INCLUDE 'TXFRM.COM' +! + REAL*8 XN,DNX,DNY + DOUBLE PRECISION XG,YG,XK,YK,XP,YP +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLKV1.COM' +! INCLUDE 'BLKV2.COM' + INCLUDE 'BFILES.I90' +!- +!ipk jul94 DIMENSION X(8),Y(8) + DIMENSION X(9),Y(9) + CHARACTER(LEN=255) :: FNAME,FNAMR + CHARACTER(LEN=256) :: FILTER + CHARACTER(LEN=3) :: SUB,SUB1 +!- + DATA TOL/0.01/ +!- + +!- +!......LOOP ON ALL GRID POINTS +!- + FILTER = 'Map file *.map|*.map|' + CALL WSelectFile(FILTER,SaveDialog+PromptOn,FNAME,'Save Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(199,FILE=FNAME,STATUS='UNKNOWN') + WRITE(199,8000) + 8000 FORMAT('2,0.') + ELSE + RETURN + ENDIF + + DO 1000 NN=1,NX + DO 950 MM=1,NY + N=IGRID(NN,MM) + IF(N.EQ.0) GO TO 950 + HGN=0. + 250 CONTINUE +!- +!......DETERMINE ELEMENT TYPE +!- +!IPKOCT93 ADD + NCN=8 + IT=1 + + IF(NOP(N,7).NE.0) GO TO 275 + NCN=6 + IT=2 + 275 CONTINUE +!- +!......ESTABLISH LOCAL COORDINATES FOR EACH NODE POINT +!- + K1=NOP(N,1) + X(1)=0. + Y(1)=0. + DO 300 K=2,NCN + K2=NOP(N,K) + X(K)=CORD(K2,1)-CORD(K1,1) + Y(K)=CORD(K2,2)-CORD(K1,2) + 300 END DO +!- +!......ESTABLISH LOCAL COORDINATES OF DESIRED POINT +!- + XP=FLOAT(NN-2)*XGRID + XRL=XP*TXSCAL-XS + XP=XP-CORD(K1,1) + YP=FLOAT(MM-2)*YGRID + YRL=YP*TXSCAL-YS + YP=YP-CORD(K1,2) + XG=0. + YG=0. +!- +!......ITERATE TO FIND LOCAL COORDINATE +!- + DO 400 ITER=1,10 + DXKDX=0. + DXKDY=0. + DYKDX=0. + DYKDY=0. + XK=-XP + YK=-YP + DO 350 K=2,NCN + XK=XK+XN(IT,K,XG,YG)*X(K) + YK=YK+XN(IT,K,XG,YG)*Y(K) + DXKDX=DXKDX+DNX(IT,K,XG,YG)*X(K) + DYKDX=DYKDX+DNX(IT,K,XG,YG)*Y(K) + DXKDY=DXKDY+DNY(IT,K,XG,YG)*X(K) + DYKDY=DYKDY+DNY(IT,K,XG,YG)*Y(K) + 350 END DO + DET=DXKDX*DYKDY-DXKDY*DYKDX + DX=(-DYKDY*XK+DXKDY*YK)/DET + DY=( DYKDX*XK-DXKDX*YK)/DET + XG=XG+DX + YG=YG+DY + IF(ABS(DX).LT.TOL .AND. ABS(DY).LT.TOL) GO TO 420 + 400 END DO +!- +!......NOW EVALUATE GRID POINT +!- + 420 CONTINUE + DO 450 K=1,NCN + J=NOP(N,K) + HGN=HGN+XN(IT,K,XG,YG)*WD(J) + 450 END DO + WRITE(199,9800) XRL,YRL,HGN + 9800 FORMAT(F14.2',',F14.2,',',F14.3) + 950 END DO + 1000 END DO +! IF(NVEL .EQ. 1) WRITE(6,9803) ((UGRID(NN,MM),MM=1,32), +! 1NN=1,32) +! IF(NVEL .EQ. 1) WRITE(6,9803) ((VGRID(NN,MM),MM=1,32), +! 1NN=1,32) + 9803 FORMAT(8E12.4) +! WRITE(6,9802)((GRID(NN,MM),MM=1,16),NN=1,16) +!9802 FORMAT(16F8.2) + WRITE(199,8001) + 8001 FORMAT('END') + WRITE(199,8001) + RETURN + END + +! + SUBROUTINE LOCATE +!*********************************** .....LOCATE..... +!- +!......LOCATE ESTABLISHES ELEMENT NUMBERS FOR ALL GRID POINTS +!- + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLKV1.COM' +! INCLUDE 'BLKV2.COM' + INCLUDE 'BFILES.I90' +! + COMMON XS(4,3),YS(4,3),XM(4,3),ROOT(10) +! + VOID=1.E+20 + NPTS= 7 + DS=1./(FLOAT(NPTS)-1.) + DO 340 N=1,MAXGRD + DO 340 M=1,MAXGRD + 340 IGRID(N,M)=0 +!- +!....... PROCESS EACH ELEMENT +!- + DO 900 N=1,NE + IF(IESKP(N) .NE. 0) GO TO 900 + IF(IMAT(N).LE.0) GO TO 900 + IF(NOP(N,6) .EQ. 0) GO TO 900 + XMINN=VOID + YMINN=VOID + XMAXX=-VOID + YMAXX=-VOID +!- +!...... TRACE AROUND EACH SIDE FOR MAX AND MIN LOCATIONS +!- + NCN=8 + IF(NOP(N,7).EQ.0) NCN=6 + NSIDE=NCN/2 + K=0 + DO 600 M=1,NCN,2 + K=K+1 + M1=NOP(N,M) + M2=NOP(N,M+1) + M3=MOD(M+2,NCN) + M3=NOP(N,M3) + XS(K,1)=CORD(M1,1) + XS(K,2)=CORD(M2,1) + XS(K,3)=CORD(M3,1) + YS(K,1)=CORD(M1,2) + YS(K,2)=CORD(M2,2) + YS(K,3)=CORD(M3,2) + XM(K,1)=2.*XS(K,1)-4.*XS(K,2)+2.*XS(K,3) + XM(K,2)=-3.*XS(K,1)+4.*XS(K,2)-XS(K,3) + XM(K,3)=XS(K,1) +!- +!..... WORK ALONG BOUNDARY OF ELEMENT +!- + S=0. + DO 550 J=1,NPTS + XN1=(1.-S)*(1.-2.*S) + XN2=4.*(1.-S)*S + XN3=S*(2.*S-1.) + X=XN1*XS(K,1)+XN2*XS(K,2)+XN3*XS(K,3) + Y=XN1*YS(K,1)+XN2*YS(K,2)+XN3*YS(K,3) + IF(X.LT.XMINN) XMINN=X + IF(X.GT.XMAXX) XMAXX=X + IF(Y.LT.YMINN) YMINN=Y + IF(Y.GT.YMAXX) YMAXX=Y + S=S+DS + 550 END DO + 600 END DO +!- +!...... ESTABLISH GRID FRAMEWORK +!- + XLH=XMINN/XGRID + XRH=XMAXX/XGRID + YBT=YMINN/YGRID + YTP=YMAXX/YGRID + IXL=XLH+2.999 + IXT=XRH+2.001 + IYL=YBT+2.999 + IYT=YTP+2.001 + IERR=0 +!$$$ + IF(IXL.LT.0) IERR=1 + IF (IXL .LT. 1) IXL = 1 + IF(IYL.LT.0) IERR=1 + IF (IYL .LT. 1) IYL = 1 + IF(IXT.GT.NX) IERR=1 + IF (IXT .GT. NX) IXT = NX + IF(IYT.GT.NY) IERR=1 + IF (IYT .GT. NY) IYT = NY +! + IF(IERR.EQ.0) GO TO 620 +! WRITE(6,9989) N +! 9989 FORMAT(///' ERROR STOP FOR ELEMENT',I5) +! WRITE(6,9990) (K,(XS(K,M),YS(K,M),XM(K,M),M=1,3),K=1,NSIDE) +! 9990 FORMAT(I10,9E13.4) +! WRITE(6,9992) XLH,XRH,YBT,YTP,IXL,IXT,IYL,IYT +! 9992 FORMAT(4F20.6,4I8) +!$$$ STOP + 620 CONTINUE +!- +!...... FIND INTERSECTIONS FOR HORIZONTAL GRID LINE +!- + DO 800 M=IYL,IYT + Y=(M-2)*YGRID + IL=0 + DO 700 K=1,NSIDE + A=2.*YS(K,1)-4.*YS(K,2)+2.*YS(K,3) + B=-3.*YS(K,1)+4.*YS(K,2)-YS(K,3) + C=YS(K,1)-Y + SQ=B**2-4.*A*C + IF(ABS(A).LT.0.01) GO TO 650 + IF(SQ.GT..001) GO TO 660 + IF(SQ.LT.-.001) GO TO 700 + S=-B/(2.*A) + IF(S.LT.0. .OR. S.GT.1.0) GO TO 700 + IL=IL+1 + ROOT(IL)=XM(K,1)*S**2+XM(K,2)*S+XM(K,3) + IL=IL+1 + ROOT(IL)=ROOT(IL-1) + GO TO 700 + 650 IF(ABS(B).LT. 0.001) GO TO 700 + S=-C/B + GO TO 670 + 660 CONTINUE + S=(-B+SQRT(SQ))/(2.*A) + IF(S.LT.0. .OR. S.GT.1.0) GO TO 665 + IL=IL+1 + ROOT(IL)=XM(K,1)*S**2+XM(K,2)*S+XM(K,3) + 665 S=(-B-SQRT(SQ))/(2.*A) + 670 CONTINUE + IF(S.LT.0. .OR. S.GT.1.0) GO TO 700 + IL=IL+1 + ROOT(IL)=XM(K,1)*S**2+XM(K,2)*S+XM(K,3) + 700 END DO + IF(IL.GT.0) GO TO 705 + DO 703 K=1,NSIDE + IF(ABS(YS(K,3)-Y).LT.0.05) GO TO 704 + 703 END DO + GO TO 800 + 704 IL=2 + ROOT(1)=XS(K,3)-0.05 + ROOT(2)=XS(K,3)+0.05 + 705 CONTINUE + CALL SORTE(ROOT,IL) +! ISET=0 + IC=1 +!- +!....... LOCATE VALUES INTO IGRID +!- + 9908 FORMAT(I10,F20.2) + 9997 FORMAT(5F20.4) + DO 750 K=IXL,IXT + X=(K-2)*XGRID + 710 CONTINUE + IF(X.LE.ROOT(IC)) GO TO 720 + IC=IC+1 + IF(IC.GT.IL) GO TO 800 + GO TO 710 + 720 IF(MOD(IC,2).EQ.0) IGRID(K,M)=N + 750 END DO + 800 END DO + 900 END DO +!CC WRITE(*,9800) ((IGRID(N,M),N=1,20),M=1,20) + 9800 FORMAT(20I3) + RETURN + END +! + SUBROUTINE SORTE(A,N) +!*********************************** .....SORT..... +!- +!......SORT IS A SIMPLE SHELL SORT ROUTINE +!- +! SHELL SORT + SAVE +! + DIMENSION A(*) + IF(N.LT.2) RETURN + ID = N + 100 ID = ID / 2 + 110 IB = 1 + 120 GO TO 200 + 130 IB = IB + 1 + IF( IB .LE. ID ) GO TO 200 + IF( ID .GT. 1 ) GO TO 100 + RETURN + 200 I = IB + 210 K = I + ID + 220 IF( A(I) .LE. A(K) ) GO TO 250 + T = A(K) + A(K) = A(I) + J = I + 230 K = J - ID + IF( K .LT. 1 ) GO TO 240 + IF( T .GT. A(K) ) GO TO 240 + A(J) = A(K) + J = K + GO TO 230 + 240 A(J) = T + 250 I = I + ID + IF( I + ID .LE. N ) GO TO 210 + GO TO 130 + END +! diff --git a/src/src83e/JLINE.F90 b/src/src83e/JLINE.F90 new file mode 100644 index 0000000..2de216e --- /dev/null +++ b/src/src83e/JLINE.F90 @@ -0,0 +1,122 @@ + SUBROUTINE JLINE(ILIN,CVAL) + +! Routine to join up points + + USE BLKMAP + USE BLK1MOD + ! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' + COMMON /CCGEN/ XCLIN(4000,2),YCLIN(4000,2),ALIN(-4000:4000,2),IUSED(4000) + + + VOID=-1.0E+10 + + DO K=1,MAXLIN + IF(LINTYP(K) .EQ. -999) THEN + NLIN=K-1 + GO TO 100 + ENDIF + ENDDO + NLIN=MAXLIN + 100 CONTINUE + + DO I=1,ILIN + IUSED(I)=0 + ENDDO +! Loop through remaining poins + + DO I=1,ILIN + IF(IUSED(I) .EQ. 0) THEN + +! Set first points + + IFW=2 + IFB=1 + IUSED(I)=1 + ALIN(1,1)=XCLIN(I,1) + ALIN(1,2)=YCLIN(I,1) + ALIN(2,1)=XCLIN(I,2) + ALIN(2,2)=YCLIN(I,2) + +! Look at remaining points for match + + 200 CONTINUE + + DO J=I,ILIN + IF(IUSED(J) .EQ. 0) THEN +! First for forward points + + IF(XCLIN(J,1) .EQ. ALIN(IFW,1) .AND. YCLIN(J,1) .EQ. ALIN(IFW,2)) THEN + IFW=IFW+1 + ALIN(IFW,1)=XCLIN(J,2) + ALIN(IFW,2)=YCLIN(J,2) + IUSED(J)=1 + ELSEIF(XCLIN(J,2) .EQ. ALIN(IFW,1) .AND. YCLIN(J,2) .EQ. ALIN(IFW,2)) THEN + IFW=IFW+1 + ALIN(IFW,1)=XCLIN(J,1) + ALIN(IFW,2)=YCLIN(J,1) + IUSED(J)=1 + ELSEIF(XCLIN(J,1) .EQ. ALIN(IFB,1) .AND. YCLIN(J,1) .EQ. ALIN(IFB,2)) THEN + IFB=IFB-1 + ALIN(IFB,1)=XCLIN(J,2) + ALIN(IFB,2)=YCLIN(J,2) + IUSED(J)=1 + ELSEIF(XCLIN(J,2) .EQ. ALIN(IFB,1) .AND. YCLIN(J,2) .EQ. ALIN(IFB,2)) THEN + IFB=IFB-1 + ALIN(IFB,1)=XCLIN(J,1) + ALIN(IFB,2)=YCLIN(J,1) + IUSED(J)=1 + ENDIF + IF(IUSED(J) .EQ. 1) GO TO 200 + ENDIF + ENDDO + +! No new points found line must be complete +! Check for loops +! First end points + + 250 CONTINUE +! IF((ALIN(IFB,1) .EQ. ALIN(IFW,1)) .AND. (ALIN(IFB,2) .EQ. ALIN(IFW,2))) THEN +! IFB=IFB+1 +! IF(IFB .EQ. IFW) GO TO 300 +! GO TO 250 +! ENDIF + NLIN=NLIN+1 + LINTYP(NLIN)=3 + IF(IMP .EQ. 0) IMP=9 + N=0 + IF(MAXPTS .EQ. MAXPL) MAXPTS=0 + IF(MAXPTS .GT. 0) THEN + MAXPTS=MAXPTS+1 + CMAP(MAXPTS,1) = VOID + CMAP(MAXPTS,2) = VOID + XMAP(MAXPTS) = VOID + YMAP(MAXPTS) = VOID +! WRITE(198,'(I5,3F15.6)') MAXPTS,XMAP(MAXPTS),YMAP(MAXPTS),VAL(MAXPTS) + ENDIF + A1= VOID + A2= VOID + DO J=IFB,IFW + IF(ALIN(J,1) .EQ. A1 .AND. ALIN(J,2) .EQ. A2) GO TO 275 + MAXPTS=MAXPTS+1 +! Check for double points + XMAP(MAXPTS) = ALIN(J,1) + YMAP(MAXPTS) = ALIN(J,2) + VAL(MAXPTS) = CVAL + CMAP(MAXPTS,1)=(XMAP(MAXPTS)+XS)/TXSCAL + CMAP(MAXPTS,2)=(YMAP(MAXPTS)+YS)/TXSCAL + +! WRITE(198,'(I5,3F15.6)') MAXPTS,XMAP(MAXPTS),YMAP(MAXPTS),VAL(MAXPTS) + 275 CONTINUE + ENDDO + 300 CONTINUE + ENDIF + +! Copy values into contour line array + + ENDDO + klint=nlin + + RETURN + END + diff --git a/src/src83e/JOIN.bmp b/src/src83e/JOIN.bmp new file mode 100644 index 0000000..60f0ed5 Binary files /dev/null and b/src/src83e/JOIN.bmp differ diff --git a/src/src83e/JOINEL.F90 b/src/src83e/JOINEL.F90 new file mode 100644 index 0000000..00dcc4e --- /dev/null +++ b/src/src83e/JOINEL.F90 @@ -0,0 +1,452 @@ +!IPK LAST UPDATE SEP 23 2015 ADD OPTION FOR JOINING ELEMENTS + subroutine joinel + + USE BLK1MOD + USE BLK2MOD + use blkmap + INTEGER LIST1(1000),LIST2(1000),idel(1000) + real xmapt(1000),ymapt(1000) + + + CHARACTER*1 IFLAG,ANSW(10) + CHARACTER*60 STRELS + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + + + DATA STRELS/' You have tried to join before executing "FILL"'/ +! +! +! Test to make sure fill has been executed. +! + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + DO M=2,NCORN(N),2 +!ipkoct93 + if(imat(n) .LT. 900) THEN + IF(NOP(N,M) .EQ. 0) THEN + CALL SYMBL(0.,7.30,0.20,STRELS,0.,60) + RETURN + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO +! Initiliaze list etc + + NHTPSV=NHTP + NMESSSV=NMESS + NBRRSV=NBRR + +! get starting elements + CALL KCON(0) + DO N=1,NE + DO M=1,8 + NOPSV(N,M)=NOP(N,M) + ENDDO + IMATSV(N)=IMAT(N) + ENDDO + NESAV=NE + NEFSAV=NENTRY + NPUNDO=0 + list1=0 + list2=0 +! SELECT FIRST ELEMENT +10 CONTINUE + CALL PANELTYP(NMTYP) + NHTP=0 + NMESS=20 + NBRR=8 + CALL HEDR + + CALL PROX(XC,YC,NE,XX,YY,NEL1,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + CALL fillem(NEL1) +! + IF(IFLAG .EQ. 'q') THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + + CALL PROX(XC,YC,NE,XX,YY,NEL2,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF +! + IF(IFLAG .EQ. 'q') THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + CALL fillem(NEL1) + CALL fillem(NEL2) + + CALL PROX(XC,YC,NE,XX,YY,NEL3,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF +! + IF(IFLAG .EQ. 'q') THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + + CALL fillem(NEL1) + CALL fillem(NEL2) + CALL fillem(NEL3) + CALL PROX(XC,YC,NE,XX,YY,NEL4,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF +! + IF(IFLAG .EQ. 'q') THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + CALL fillem(NEL1) + CALL fillem(NEL2) + CALL fillem(NEL3) + CALL fillem(NEL4) + +! work on first pair +! get starting mid-side + ilc=0 + call findbcel(nel1,nd1,nd2,nd3,ierr,ilc) +! save back node + list1(1)=nd1 + write(90,*) '1',nd1 + +! get adjacent corner save corner + m=2 + list1(m)=nd3 + write(90,*) m,nd3 + nelc=nel1 + nelcsv=nel1 +! start looop + do nss=1,1000 +! find next element and get mid side + nadj=ndelm(nd3) + do kkk=1,nadj + nd3=list1(m) + nelc=nelcsv + if(necon(nd3,kkk) .ne. nelc) then + nelc=necon(nd3,kkk) + ilc=2 + call findbcel(nelc,nd1,nd2,nd3,ierr,ilc) + if(ierr .eq. 0) go to 200 + endif + enddo +200 continue + nelcsv=nelc +! get and save next corner + m=m+1 + if(m .gt. 1000) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + RETURN + ENDIF + list1(m)=nd3 + write(90,*) m,nd3 +! test for last element + if(nelc .eq. nel2) go to 250 + enddo +250 continue + m1=m + +! repeat for second pair +! get starting mid-side + ilc=1 + call findbcel(nel3,nd1,nd2,nd3,ierr,ilc) +! save back node + list2(1)=nd1 + write(90,*) m,nd1 + +! get adjacent corner save corner + m=2 + list2(m)=nd3 + write(90,*) m,nd3 + nelc=nel3 + nelcsv=nel3 +! start looop + do nss=1,1000 +! find next element and get mid side + nadj=ndelm(nd3) + do kkk=1,nadj + nd3=list2(m) + nelc=nelcsv + if(necon(nd3,kkk) .ne. nelc) then + nelc=necon(nd3,kkk) + ilc=2 + if(nelc .eq. nel4) ilc=4 + call findbcel(nelc,nd1,nd2,nd3,ierr,ilc) + if(ierr .eq. 0) go to 300 + + endif + enddo +300 continue + nelcsv=nelc +! get and save next corner + m=m+1 + if(m .gt. 1000) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + ENDIF + list2(m)=nd3 + write(90,*) m,nd3 +! test for last element + if(nelc .eq. nel4) go to 350 + enddo +350 continue + m2=m + ! add points in triangle list + do j=1,m2 + list1(m1+j)=list2(j) + enddo + nvert=m1+m2 + do n=1,nvert + write(90,*) n,list1(n) + enddo + do j=1,nvert + xmap(j)=xusr(list1(j)) + ymap(j)=yusr(list1(j)) + xmapt(j)=xusr(list1(j)) + ymapt(j)=yusr(list1(j)) + imap(j)=1 + val(j)=1. + enddo +! call for triangulation + + CALL DELAUNAY(NVERT) + + do n=1,nelts + if(nopel(n,1) .le. m1) then + if(nopel(n,2) .le. m1 .and. nopel(n,3) .le. m1) then + cycle + endif + else + if(nopel(n,2) .gt. m1 .and. nopel(n,3) .gt. m1) then + cycle + endif +500 continue + endif +! FORM A NEW ELEMENT ASSIGN TYPE AS INDICATED + CALL GETELM(J) + NOP(J,1)=list1(nopel(n,1)) + NOP(J,3)=list1(nopel(n,2)) + NOP(J,5)=list1(nopel(n,3)) + NOP(J,2)=0 + NOP(J,4)=0 + NOP(J,6)=0 + NOP(J,7)=0 + NOP(J,8)=0 + IMAT(J)=NMTYP + IESKP(J) = 0 + NCORN(J)=6 + enddo + CALL PLOTOT(1) + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + + CALL HEDR + return + end + + subroutine findbcel(nel,nd1,nd2,nd3,ierr,ilc) + use blk1mod + USE BLK2MOD + integer nel,nd1,nd2,nd3,mlc(5),ndkp + ndkp=nd3 + ierr=0 + kk=0 + do k=2,ncorn(nel),2 + nd2=nop(nel,k) + if(ndelm(nd2) .eq. 1) then + nd1=nop(nel,k-1) + if(nd1 .ne. ndkp .and. ilc .gt. 1) cycle + jj=mod(k,ncorn(nel))+1 + nd3=nop(nel,jj) + if(ilc .eq. 4) return + if(ilc .gt. 0) then + kk=kk+1 + mlc(kk)=k + cycle + else +! check for more than 1 + kj=k+2 + if(kj .gt. ncorn(nel)) kj=2 + nd2a=nop(nel,kj) + if(ndelm(nd2a) .eq. 1) then + nd1=nop(nel,kj-1) + jj=mod(kj,ncorn(nel))+1 + nd3=nop(nel,jj) + nd2=nd2a + endif + return + endif + + endif + enddo + if(ilc .gt. 0) then + if(kk .eq. 1) then + if(nd1 .eq. ndkp) then + return + else + ierr=1 + return + endif + elseif(kk .eq. 2) then + if(abs(mlc(2)-mlc(1)) .eq. 4) then + do kk=1,2 + nd1=nop(nel,mlc(kk)-1) + if(nd1 .eq. ndkp) then + nd2=nop(nel,mlc(kk)) + nd3=mod(mlc(kk),ncorn(nel))+1 + nd3=nop(nel,nd3) + return + endif + enddo + endif + if(ilc .eq. 1) then + if(mlc(kk) .eq. ncorn(nel) .and. mlc(kk-1) .eq. 2) then + nd1=nop(nel,1) + nd2=nop(nel,2) + nd3=nop(nel,3) + else + return + endif + else + if(mlc(kk) .eq. ncorn(nel) .and. mlc(kk-1) .eq. 2) then + return + else + nd1=nop(nel,mlc(1)-1) + nd2=nop(nel,mlc(1)) + nd3=nop(nel,mlc(1)+1) + endif + endif + elseif(kk .eq. 3) then + if(mlc(kk) .eq. ncorn(nel)) then + if(mlc(kk-1) .eq. ncorn(nel)-2) then + nd1=nop(nel,1) + nd2=nop(nel,2) + nd3=nop(nel,3) + elseif(mlc(kk-1) .eq. ncorn(nel)-4) then + nd1=nop(nel,3) + nd2=nop(nel,4) + nd3=nop(nel,5) + else + return + endif + else + return + endif + endif +! else +! return + endif + ierr=1 + return + end + + SUBROUTINE PANELTYP(N1) + +! Choose options and intervals + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,itime,IERR + data itime/0/ + + if(itime .eq. 0) then + n1=1 + itime=1 + endif + + call wdialogload(IDD_MATTYP) + ierr=infoerror(1) + + CALL WDialogPutInteger(idf_integer1,N1) + + CALL WDialogSelect(IDD_MATTYP) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(idf_integer1,N1) + ELSE + N1=1 + RETURN + + ENDIF + + RETURN + END + \ No newline at end of file diff --git a/src/src83e/LAYDISP.F90 b/src/src83e/LAYDISP.F90 new file mode 100644 index 0000000..1607335 --- /dev/null +++ b/src/src83e/LAYDISP.F90 @@ -0,0 +1,69 @@ + Subroutine LayDisp + + USE WINTERACTER + USE BLK1MOD +! + include 'd.inc' +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: INODE,IBOX,NN + INTEGER :: IERR + CHARACTER*1 :: IFLAG + + DATA INODE/1/ + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select node','CHOOSE NODE') + IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + + 100 continue + call wdialogload(IDD_LAY) + ierr=infoerror(1) + + + IF(ILAYTP .EQ. 1) THEN + call wdialogputRadioButton(idf_radio1) + ELSE + call wdialogputRadioButton(idf_radio2) + ENDIF + lno=lay(INODE) + CALL WDialogPutINTEGER(IDF_INTEGER1,lno) + do i=1,7 + CALL WGridPutCellReal(IDF_GRID1,i,1,wtlay(INODE,i)) + enddo + + + CALL WDialogSelect(IDD_LAY) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ilaytp) + + CALL WDialogGetINTEGER(IDF_INTEGER1,lno) + lay(INODE)=lno + do i=1,7 + CALL WGridGetCellReal(IDF_GRID1,i,1,wtlay(INODE,i)) + enddo + return + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + RETURN + endif +!IPK SEP02 + return + enddo + RETURN + END diff --git a/src/src83e/LEVSETTYP.F90 b/src/src83e/LEVSETTYP.F90 new file mode 100644 index 0000000..60fd971 --- /dev/null +++ b/src/src83e/LEVSETTYP.F90 @@ -0,0 +1,50 @@ + SUBROUTINE LEVSETTYP + USE WINTERACTER + USE BLK1MOD + include 'd.inc' + + CHARACTER*47 MESSAGE + + DATA ITIME/0/ + IMATTYP=1 + BLELVEL=0. + + call wdialogload(IDD_LEVSETTYP) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_LEVSETTYP) + ierr=infoerror(1) + + CALL WDialogPutReal(IDF_REAL1,BLEVEL) + + CALL WDialogPutInteger(IDF_INTEGER1,IMATTYP) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetInteger(IDF_INTEGER1,IMATTYP) + CALL WDialogGetReal(IDF_REAL1,BLEVEL) + GO TO 200 + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + RETURN + ENDIF + ENDDO + +200 CONTINUE + + DO N=1,NE + IF(IMAT(N) .EQ. 99) CYCLE + DO K=1,NCORN(N) + IF(NOP(N,K) .EQ. 0) CYCLE + IF(WD(NOP(N,K)) .LT. BLEVEL) GO TO 300 + ENDDO + IMAT(N)=IMATTYP +300 CONTINUE + ENDDO + RETURN + END + \ No newline at end of file diff --git a/src/src83e/LOADFIL.F90 b/src/src83e/LOADFIL.F90 new file mode 100644 index 0000000..e7e38f2 --- /dev/null +++ b/src/src83e/LOADFIL.F90 @@ -0,0 +1,23 @@ + SUBROUTINE LOADFIL + + INCLUDE 'BFILES.I90' + + + IFILOUT=IACTVFIL+50 + +! Zero out current arrays + + CALL ZEROOUT + + IFNUM=IACTVFIL+50 + WRITE(90,*) 'IN LOADFIL IFNUM',IFNUM + CALL RDRST(1,IFNUM) + CALL RDRST(2,IFNUM) + CALL RDRST(3,IFNUM) + REWIND IFNUM + + CALL RESCAL + CALL HEDR + + RETURN + END \ No newline at end of file diff --git a/src/src83e/MMAP.F90 b/src/src83e/MMAP.F90 new file mode 100644 index 0000000..04909ec --- /dev/null +++ b/src/src83e/MMAP.F90 @@ -0,0 +1,99 @@ +!IPK LAST UPDATE SEP 23 2015 ADD NEW FORMAT TO 6 DEC + Subroutine MMap + + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + CALL OPENMP + + CALL SVELEM(IYES) + + rewind 99 + +! if IYES .eq. 1 save as an element format + + valmap=0. + mapno=2 + IF(IYES .EQ. 1) THEN + do n=1,ne + write(99,6001) + 6001 format(' 3,9999.') + if(imat(n) .gt. 0) then + ncn=ncorn(n) + do m=1,ncn + j=nop(n,m) + if(j .gt. 0) then + write(99,'(3f16.3)') xusr(j),yusr(j),wd(j) + endif + enddo + j=nop(n,1) + if(j .gt. 0) then + write(99,'(3f16.3)') xusr(j),yusr(j),wd(j) + endif + endif + write(99,6000) + 6000 format('END') + enddo + +! if IYES .eq. 0 save as a nodal list + + + ELSE + write(99,6002) + 6002 format(' 2,0') + do j=1,np + if(inew(j) .eq. 1) then + write(99,'(3f16.6)') xusr(j),yusr(j),wd(j) + endif + enddo + write(99,6000) + ENDIF + write(99,6000) + close (99) + return + end + + subroutine openmp + + use winteracter + + implicit none + + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + CALL WSelectFile(ID_STRING7,SaveDialog+PromptOn,FNAME,'Save Network as Mapfile') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='map' + CALL ADDSUB(FNAME,SUB) + open(99,file=fname, form='formatted', status='unknown') + ENDIF + RETURN + END + + SUBROUTINE SVELEM(IYES) + + USE WINTERACTER + + INCLUDE 'D.INC' + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to save element layout?'//& + CHAR(13)//' ','Map option') +! +! If answer 'No', return +! + iyes=1 + IF (WInfoDialog(4).EQ.2) iyes=0 + return + end + \ No newline at end of file diff --git a/src/src83e/MOVMESH.f90 b/src/src83e/MOVMESH.f90 new file mode 100644 index 0000000..ef3e501 --- /dev/null +++ b/src/src83e/MOVMESH.f90 @@ -0,0 +1,386 @@ + SUBROUTINE MOVMESH + + USE WINTERACTER + USE BLK1MOD + + SAVE + +! implicit none + + include 'd.inc' + + INCLUDE 'TXFRM.COM' + + INCLUDE 'BFILES.I90' + + CHARACTER*1 IFLAG + REAL xlocorg,ylocorg,xlocscl,ylocscl,XREFPT,YREFPT,xlocs,ylocs,xlocf,ylocf,stscalx,stscaly,xtest,ytest + INTEGER NTYPR,ITIMETHRU + + allocatable xusrt(:),yusrt(:),xcrst(:),ycrst(:) + + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + DATA ITIMTHRU/0/,NTYPR/1/,xlocorg/0./,ylocorg/0./,xlocscl/0./,ylocscl/0./ + + call wdialogload(IDD_DIALOG048) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG048) + ierr=infoerror(1) + + IF(NTYPR .EQ. 1) THEN + call wdialogputRadioButton(idf_radio1) + ELSE + call wdialogputRadioButton(idf_radio2) + ENDIF + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ntypr) + go to 100 + + elseif(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + return + ENDIF + + enddo + + 100 continue + + IF(NTYPR .EQ. 1) THEN + + call wdialogload(IDD_DIALOG047) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG047) + ierr=infoerror(1) + + CALL WDialogPutReal(IDF_REAL1,xlocorg) + CALL WDialogPutReal(IDF_REAL2,ylocorg) + CALL WDialogPutReal(IDF_REAL3,xlocscl) + CALL WDialogPutReal(IDF_REAL4,ylocscl) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetReal(IDF_REAL1,xlocorg) + CALL WDialogGetReal(IDF_REAL2,ylocorg) + CALL WDialogGetReal(IDF_REAL3,xlocscl) + CALL WDialoggetReal(IDF_REAL4,ylocscl) + + allocate (xusrt(np),yusrt(np)) + + if(xlocscl .eq. 0.) then + do j=1,np + xusrt(j)=xusr(j) + yusrt(j)=yusr(j) + xusr(j)=xusr(j)+xlocorg + yusr(j)=yusr(j)+ylocorg + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + enddo + if(ncrsec .gt. 0) then + allocate (xcrst(nrsec),ycrst(nrsec)) + do j=1,ncrsec + xcrst(j)=xcrs(j) + ycrst(j)=ycrs(j) + xcrs(j)=xcrs(j)+xlocorg + ycrs(j)=ycrs(j)+ylocorg + enddo + endif + else + do j=1,np + xusr(j)=(xusr(j)-xlocorg)*xlocscl + yusr(j)=(yusr(j)-ylocorg)*ylocscl + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + enddo + if(ncrsec .gt. 0) then + allocate (xcrst(nrsec),ycrst(nrsec)) + do j=1,ncrsec + xcrst(j)=xcrs(j) + ycrst(j)=ycrs(j) + xcrs(j)=(xcrs(j)-xlocorg)*xlocscl + ycrs(j)=(ycrs(j)-ylocorg)*ylocscl + enddo + endif + endif + + go to 300 + + elseif(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + return + endif + enddo + + else + +! get reference point +! xrefpt +! yrefpt + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select Fixed Reference point','CHOOSE REFERENCE') + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + XREFPT = XTEMP*TXSCAL - XS + YREFPT = YTEMP*TXSCAL - YS + +! get start move point +! xlocs +! ylocs + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select Starting point','CHOOSE START') + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + XLOCS = XTEMP*TXSCAL - XS + YLOCS = YTEMP*TXSCAL - YS + +! get finish move point +! xlocf +! ylocf + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select Finishing point','CHOOSE FINISH') + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + XLOCF = XTEMP*TXSCAL - XS + YLOCF = YTEMP*TXSCAL - YS + +! establish x moves + stscalx=(xlocf-xrefpt)/(xlocs-xrefpt) + +! establish y moves + stscaly=(ylocf-yrefpt)/(ylocs-yrefpt) + + allocate (xusrt(np),yusrt(np)) + do j=1,np + xusrt(j)=xusr(j) + yusrt(j)=yusr(j) + xusr(j)=xrefpt-(xrefpt-xusr(j))*stscalx + yusr(j)=yrefpt-(yrefpt-yusr(j))*stscaly + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + enddo + if(ncrsec .gt. 0) then + allocate (xcrst(nrsec),ycrst(nrsec)) + do j=1,ncrsec + xcrst(j)=xcrs(j) + ycrst(j)=ycrs(j) + xcrs(j)=xrefpt-(xrefpt-xcrs(j))*stscalx + ycrs(j)=yrefpt-(yrefpt-ycrs(j))*stscaly + enddo + endif + + endif + + 300 continue + CALL CLSCRN + CALL PLOTOT(1) + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to keep '//& + CHAR(13)//' ','new locations?') + ! +! If answer 'No', reset +! + IF (WInfoDialog(4).EQ.2) then + do j=1,np + xusr(j)=xusrt(j) + yusr(j)=yusrt(j) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + enddo + if(ncrsec .gt. 0) then + do j=1,ncrsec + xcrs(j)=xcrst(j) + ycrs(j)=ycrst(j) + enddo + deallocate (xcrst,ycrst) + endif + CALL CLSCRN + CALL PLOTOT(1) + endif + + deallocate(xusrt,yusrt) + + RETURN + END + + SUBROUTINE TRANSMESH + + USE WINTERACTER + USE BLK1MOD + + SAVE + +! implicit none + + include 'd.inc' + + INCLUDE 'TXFRM.COM' + + INCLUDE 'BFILES.I90' + + CHARACTER*1 IFLAG + allocatable xusrt(:),yusrt(:),xcrst(:),ycrst(:) + data iopt1/1/ + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + call wdialogload(IDD_TRANSFORM) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_TRANSFORM) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,IOPT1) + + CALL WDialogPutReal(IDF_REAL3,COEF1) + CALL WDialogPutReal(IDF_REAL4,COEF2) + CALL WDialogPutReal(IDF_REAL5,COEF3) + CALL WDialogPutReal(IDF_REAL6,COEF4) + CALL WDialogPutReal(IDF_REAL7,COEF5) + CALL WDialogPutReal(IDF_REAL8,COEF6) + CALL WDialogPutINTEGER(IDF_INTEGER2,ICOEF1) + CALL WDialogPutINTEGER(IDF_INTEGER3,ICOEF2) + CALL WDialogPutINTEGER(IDF_INTEGER4,ICOEF3) + CALL WDialogPutINTEGER(IDF_INTEGER5,ICOEF4) + CALL WDialogPutINTEGER(IDF_INTEGER9,ICOEF5) + CALL WDialogPutINTEGER(IDF_INTEGER10,ICOEF6) + + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,IOPT1) + CALL WDialogGetReal(IDF_REAL3,COEF1) + CALL WDialogGetReal(IDF_REAL4,COEF2) + CALL WDialogGetReal(IDF_REAL5,COEF3) + CALL WDialoggetReal(IDF_REAL6,COEF4) + CALL WDialoggetReal(IDF_REAL7,COEF5) + CALL WDialoggetReal(IDF_REAL8,COEF6) + CALL WDialogGetINTEGER(IDF_INTEGER2,ICOEF1) + CALL WDialogGetINTEGER(IDF_INTEGER3,ICOEF2) + CALL WDialogGetINTEGER(IDF_INTEGER4,ICOEF3) + CALL WDialogGetINTEGER(IDF_INTEGER5,ICOEF4) + CALL WDialogGetINTEGER(IDF_INTEGER9,ICOEF5) + CALL WDialogGetINTEGER(IDF_INTEGER10,ICOEF6) + go to 200 + elseif(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + return + ENDIF + + enddo +200 continue + if(.not. allocated(xusrt)) then + allocate (xusrt(np),yusrt(np)) + + do j=1,np + xusrt(j)=xusr(j) + yusrt(j)=yusr(j) + enddo + if(ncrsec .gt. 0) then + allocate (xcrst(nrsec),ycrst(nrsec)) + do j=1,ncrsec + xcrst(j)=xcrs(j) + ycrst(j)=ycrs(j) + enddo + endif + endif + IF(IOPT1 .EQ. 1) THEN + DO J=1,NP + XUSR(J)=COEF1*XUSR(J)+COEF2 + YUSR(J)=COEF3*YUSR(J)+COEF4 + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + IF(COEF5 .EQ. 0. .AND. COEF6 .EQ. 0.) CYCLE + WD(J)=COEF5*WD(J)+COEF6 + ENDDO + if(ncrsec .gt. 0) then + do j=1,ncrsec + xcrs(j)=coef1*XCRS(J)+COEF2 + ycrs(j)=coef3*YCRS(J)+COEF4 + enddo + endif + ELSE IF(IOPT1 .EQ. 2) THEN + do j=1,np + reff=coef3 + angl=(xusr(j)-coef1)/reff + a=cos(angl) + a=reff*cos(angl) + b=reff*sin(angl) + xusr(j)=reff*sin(angl)-(yusr(j)-coef2)*sin(angl) + yusr(j)=(yusr(j)-coef2)*cos(angl)+reff*(1.-cos(angl)) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + enddo + if(ncrsec .gt. 0) then + do j=1,ncrsec + reff=coef3+coef2-ycrs(j) + ang=(xcrs(j)-coef1)/reff + xcrs(j)=coef1+reff*sin(angl) + ycrs(j)=coef2+reff*cos(angl) + enddo + endif + ELSEIF(IOPT1 .EQ. 3) THEN + DO J=1,NP + A=(XUSR(J)-COEF1)*COS(COEF3)-(YUSR(J)-COEF2)*SIN(COEF3) + B=(XUSR(J)-COEF1)*SIN(COEF3)+(YUSR(J)-COEF2)*COS(COEF3) + XUSR(J)=A + YUSR(J)=B + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + ENDDO + if(ncrsec .gt. 0) then + do j=1,ncrsec + A=(XCRS(J)-COEF1)*COS(COEF3)-(YCRS(J)-COEF2)*SIN(COEF3) + B=(XCRS(J)-COEF1)*SIN(COEF3)+(YCRS(J)-COEF2)*COS(COEF3) + xcrs(j)=A + ycrs(j)=B + enddo + endif + ENDIF + CALL CLSCRN + CALL PLOTOT(1) + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to keep '//& + CHAR(13)//' ','new locations?') + ! +! If answer 'No', reset +! + IF (WInfoDialog(4).EQ.2) then + do j=1,np + xusr(j)=xusrt(j) + yusr(j)=yusrt(j) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + enddo + deallocate (Xusrt,yusrt) + if(ncrsec .gt. 0) then + do j=1,ncrsec + xcrs(j)=xcrst(j) + ycrs(j)=ycrst(j) + enddo + deallocate (xcrst,ycrst) + endif + CALL CLSCRN + CALL PLOTOT(1) + endif + RETURN + END \ No newline at end of file diff --git a/src/src83e/NECON.F90 b/src/src83e/NECON.F90 new file mode 100644 index 0000000..c5a88c7 --- /dev/null +++ b/src/src83e/NECON.F90 @@ -0,0 +1,44 @@ + SUBROUTINE NDNECON(IERR) +! +! ESTABLISH ELEMENT CONNECTED TO ELEMENT TABLE +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! INITIALIZE +! + ISWT=IERR + NCM=MAXECON + DO J=1,NCM + DO N=1,NP + NECON(N,J)=0 + ENDDO + ENDDO + DO N=1,NP + NDELM(N)=0 + ENDDO +! +! FORM TABLE OF ELEMENTS CONNECTED TO EACH NODE +! +! IERR=0 + DO M=1,NE + IF(IMAT(M) .NE. 0) THEN + DO K=1,8 + IF(ISWT .EQ. 1 .AND. MOD(K,2) .EQ. 1) CYCLE + N=NOP(M,K) + IF (N .GT. 0) THEN + NDELM(N)=NDELM(N)+1 + J=NDELM(N) + IF(J .GT. MAXECON) THEN + IERR=MAX(IERR,J) + ELSE + NECON(N,J)=M + ENDIF + ENDIF + ENDDO + ENDIF + END DO + RETURN + END diff --git a/src/src83e/NEWRMGN.F90 b/src/src83e/NEWRMGN.F90 new file mode 100644 index 0000000..0fabdb2 --- /dev/null +++ b/src/src83e/NEWRMGN.F90 @@ -0,0 +1,952 @@ +!IPK LAST UPDATE SEP 23 2015 ADD MORE INFO ON FRAME +! + PROGRAM NEWRMAGEN +! +! Use of the module is compulsory +! + USE WINTERACTER + USE DFLIB +! + IMPLICIT NONE +! +! Define some parameters to match those in the resource file +! + include 'd.inc' + INCLUDE 'TXFRM.COM' + + REAL HSIZE,scratio + COMMON /SSIZE/ HSIZE + +! + INTEGER :: IBASEV =40042 + INTEGER :: I,IRES,N2,M2,ID1,ID2 + INTEGER :: ITYPE, IX, IY, IWIDTH, IHEIGHT, KEY,IYES + INTEGER :: MOUSEX, MOUSEY, MBUTTON, ITIME, IWINDOW + INTEGER :: IDFIELDOLD, IDFIELDNEW, IDBUTN, IDFIELD,TOOLID(4) + INTEGER :: LNNAM,K,LMPNAM,IMP,IIN,MENUS,IOT,IOT1,impf,IGFG,ITRIAN,INFO(3) + INTEGER , DIMENSION(5) :: WIDSTAT + INTEGER*2 :: N1,STATUS,lnnnam,iswtfl,n + CHARACTER(LEN=255) :: FNAME,FNAMD,FILTER + CHARACTER(LEN=3) :: SUB,SUB1 + CHARACTER(LEN=4) :: SUB2 + CHARACTER(LEN=1000) :: HEADR + INTEGER ,EXTERNAL :: LENSTR + LOGICAL :: OPENED,exists + LOGICAL(4) :: statud + REAL :: XX1,XX2,XX3,XX4,XX5,XX6 + INTEGER :: iw,ih,ihandle,ient,IHAND1,IHAND2,IXPM,IYPX,IXPX,IYPM + common /hands/ ihandle,IHAND1,IHAND2,IXPM,IYPX,IXPX,IYPM + + + INTEGER ISCRWID,ISCRHGT + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + TYPE(WIN_MESSAGE) :: MESSAGE + TYPE (WIN_FONT) :: FONT + +! Define a common block with background file names + + INCLUDE 'BFILES.I90' + +! +! Get initial directory and add help name + + fname = FILE$CURDRIVE + IRES=GETDRIVEDIRQQ (fname) +! lnnnam=windowstringlength(fname) + lnnnam=lenstr(fname) + direct=fname(1:lnnnam)//'\doc\rmagen83d.htm' + +! write(128,*) fname,lnnnam,direct + +! +! +! Initialise WiSK +! + CALL WInitialise() +! +! Create a root window with : +! - System menu +! - Minimise button +! - Maximise button +! +! WINDOW%FLAGS = SysMenuOn + MinButton + MaxButton + StatusBar + + ISCRWID = WInfoScreen(1) ! Get screen width + ISCRHGT = WInfoScreen(2) ! Get screen height + scratio=float(iscrwid)/float(iscrhgt) + HSIZE=scratio*8. + +! +! Centre the window on the screen at 80% of screen size +! + WINDOW%X = -1 + WINDOW%Y = -1 + WINDOW%WIDTH = 0 + WINDOW%HEIGHT = 0 +! +! Identify the menu to be attached to the window +! and specify the initial window title +! +! WINDOW%MENUID = IDR_MENU1 +! WINDOW%TITLE = 'RMAGEN' +! +! Now open the root window +! + CALL WindowOpen(FLAGS =SysMenuOn+MinButton+MaxButton+StatusBar, & + MENUID=IDR_MENU1, & + TOOLID=(/0,ID_TOOLBAR1,0,0/), & + TITLE ='RMAGEN') +! CALL WindowOpen(WINDOW,TITLE ='RMAGEN') ! Open root window + +! +! Add a toolbar +! +! CALL WMenuToolbar(ID_TOOLBAR1) +! +! Main message loop +! +! initialise palette +! + CALL IGrPaletteInit +! +! set fill style to solid +! + CALL IGrFillPattern(Solid) + + FONT%IBCOL = TextWhite + CALL WindowFont(FONT) +! CALL WindowClear(RGB=RGB_yellow) ! clear window to yellow +! IRGB = WRGB(220,220,220) +! IRGB = WRGB(191,191,191) + IRGB = WRGB(227,227,227) + CALL WindowClear(rgb=irgb) ! clear to yellow + + WIDSTAT(1) = 1000 + WIDSTAT(2) = 2000 + WIDSTAT(3) = 1500 + WIDSTAT(4) = 1000 + WIDSTAT(5) = 2500 + CALL WindowStatusBarParts(5, WIDSTAT) + CALL WindowOutStatusBar(1, ' X and Y location') + CALL WindowOutStatusBar(4, ' Active File Name') + CALL IgrUnits(0.,0.,HSIZE,8.0) + +! IF(ISW .EQ. 1) THEN +! CALL WMessageEnable(MouseMove , Enabled) +! MENUS=-3 +! CALL RMAGEN(MENUS,IMP,IIN,1,IOT,IOT1,IGFG) +! ENDIF + + +! CALL WMenuSetState(ID_NETWD,ItemChecked,1) +! DO I=1,12 +! CALL WMenuSetState(IBASEV+I,ItemChecked,1) +! ENDDO + IDDSW=-1 + IHANDLE=0 + IHAND1=0 + IHAND2=0 + N2=0 + M2=0 + TXSCAL = 1. + XS=0. + YS=0. + NBKFL=0 + IRDONE=-1 + DO I=1,10 + ISWBKFL(I)=0 + ENDDO + IACTVFIL=0 + ITOTFIL=0 + IOT=0 + IOT1=0 + IMP=0 + + CALL INITSIZ(IIN,N2,M2,0) + + CALL WMenuSetState(ID_loadrm1,ItemEnabled,0) + CALL WMenuSetState(ID_sbin,ItemEnabled,0) + CALL WMenuSetState(ID_crsf,ItemEnabled,0) + CALL WMenuSetState(ID_savcrs,ItemEnabled,0) + CALL WMenuSetState(ID_LAYFL,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM13,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM14,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM18,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM15,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM16,ItemEnabled,0) + CALL WMenuSetState(ID_ICOPY,ItemEnabled,0) + CALL WMenuSetState(ID_Clip,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM24,ItemEnabled,0) + CALL WMenuSetState(ID_MMAP,ItemEnabled,0) + CALL WMenuSetState(ID_MAPM,ItemEnabled,0) + CALL WMenuSetState(ID_NETWORK,ItemEnabled,0) + CALL WMenuSetState(ID_NODE,ItemEnabled,0) + CALL WMenuSetState(ID_ELTS,ItemEnabled,0) + CALL WMenuSetState(ID_ORDR,ItemEnabled,0) + CALL WMenuSetState(ID_CCLN,ItemEnabled,0) + CALL WMenuSetState(ID_CONTR,ItemEnabled,0) + CALL WMenuSetState(ID_CSEC,ItemEnabled,0) + CALL WMenuSetState(ID_CSEC1,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM20,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM26,ItemEnabled,0) + CALL WMenuSetState(ID_ZOOM,ItemEnabled,0) + CALL WMenuSetState(ID_DRAW,ItemEnabled,0) + CALL WMenuSetState(ID_UNDOM,ItemEnabled,0) + CALL WMenuSetState(ID_NMAP,ItemEnabled,0) + CALL WMenuSetState(ID_CDATA,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM56,ItemEnabled,0) + CALL WMenuSetState(ID_SECGRP,ItemEnabled,0) + + iswtfl=0 + N1=1 + CALL GETARG(N1,FNAME,STATUS) + if(status .ne. -1 ) then + + CALL SHORTNAME(FNAME,FNAMEDISP) + do n=status,1,-1 + if(fname(n:n) .eq. '\') then + lnnnam=n-1 + go to 99 + endif + enddo + 99 continue + if(lnnnam .gt. 0) then + fnamd=fname(1:lnnnam) + statud = CHANGEDIRQQ(fnamd) + endif + iswtfl=1 + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + ITRIAN=0 + IF(SUB .EQ. 'geo') then + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',form='binary',ACTION='READ') + FNAMKEP=FNAME + READ(IIN) HEADR + READ(IIN) N2,M2 + REWIND (IIN) + + ELSEIF(SUB .EQ. 'gfg') then + IIN = 10 + IGFG=1 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ELSEIF(SUB .EQ. '2dm') then + IIN = 10 + IGFG=3 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ELSEIF(SUB .EQ. 'rst') then + IIN=11 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') +! OPEN(IIN,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + IGFG=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. 'bin') then + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') + IGFG=2 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. 'ele') then + IIN=10 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=1 + IGFG=0 + FNAMKEP=FNAME + CALL SETGFGTRIAN(IGFG,ITRIAN,N2,M2) + ELSEIF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'shp') then + IMP=113 + OPEN(113,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + sub='dbf' + call addsub(fname,sub) + OPEN(114,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + ELSE + IIN = 10 + IGFG=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ENDIF + IF(IMP .EQ. 0) THEN + IACTVFIL=1 + ITOTFIL=1 + FNAMEOUT(1)=FNAME + ENDIF + CALL WMenuSetState(ID_loadrm1,ItemEnabled,1) + CALL WMenuSetState(ID_sbin,ItemEnabled,1) + CALL WMenuSetState(ID_crsf,ItemEnabled,1) + CALL WMenuSetState(ID_savcrs,ItemEnabled,1) + CALL WMenuSetState(ID_LAYFL,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM13,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM14,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM18,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM15,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM16,ItemEnabled,1) + CALL WMenuSetState(ID_ICOPY,ItemEnabled,1) + CALL WMenuSetState(ID_Clip,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM24,ItemEnabled,1) + CALL WMenuSetState(ID_MMAP,ItemEnabled,1) + CALL WMenuSetState(ID_MAPM,ItemEnabled,1) + CALL WMenuSetState(ID_NETWORK,ItemEnabled,1) + CALL WMenuSetState(ID_NODE,ItemEnabled,1) + CALL WMenuSetState(ID_ELTS,ItemEnabled,1) + CALL WMenuSetState(ID_ORDR,ItemEnabled,1) + CALL WMenuSetState(ID_CCLN,ItemEnabled,1) + CALL WMenuSetState(ID_CONTR,ItemEnabled,1) +! CALL WMenuSetState(ID_CSEC,ItemEnabled,0) + CALL WMenuSetState(ID_CSEC1,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM20,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM26,ItemEnabled,1) + CALL WMenuSetState(ID_ZOOM,ItemEnabled,1) + CALL WMenuSetState(ID_DRAW,ItemEnabled,1) + CALL WMenuSetState(ID_UNDOM,ItemEnabled,1) + CALL WMenuSetState(ID_NMAP,ItemEnabled,1) + CALL WMenuSetState(ID_CDATA,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM56,ItemEnabled,1) + CALL WMenuSetState(ID_RESETLIM,ItemEnabled,0) + CALL WMessageEnable(MouseMove , Enabled) + + IF(IMP .GT. 0) THEN + MENUS=-2 + CALL INITSIZ(IIN,N2,M2,1) + go to 500 + ENDIF + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to load '//& + CHAR(13)//'a map file?' ,& + 'Map File Input?') +! +! If answer 'No' skip out +! + IMP=0 + IF (WInfoDialog(4) .NE. 2) then + + fname=' ' + CALL WSelectFile(ID_STRING1,PromptOn,FNAME,'Load Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'mpb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='unformatted',action='read') + ELSEIF(SUB .EQ. 'mbb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='binary',action='read') + ELSEIF(SUB .EQ. 'rm1') then + imp=13 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'shp') then + IMP=113 + OPEN(113,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + SUB='DBF' + CALL ADDSUB(FNAME,SUB) + OPEN(114,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + ENDIF + ENDIF + END IF + MENUS=-2 + CALL INITSIZ(IIN,N2,M2,1) + + go to 500 + endif + + + + DO WHILE (.TRUE.) ! Loop until user terminates + + 100 continue + CALL WMessage(ITYPE, MESSAGE) + SELECT CASE (ITYPE) + CASE (KeyDown) ! Key pressed + KEY = MESSAGE%VALUE1 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + CASE (MenuSelect) ! Menu item selected + SELECT CASE (MESSAGE%VALUE1) +! CASE (ID_FILE) ! File option selected + CASE (ID_RESETLIM) + CALL RESETSIZ + + CASE (ID_ITEM11) ! New option + IMP=0 + IIN=0 + CALL INITSIZ(IIN,N2,M2,1) + CALL WMenuSetState(ID_loadrm1,ItemEnabled,1) + CALL WMenuSetState(ID_sbin,ItemEnabled,1) + CALL WMenuSetState(ID_crsf,ItemEnabled,1) + CALL WMenuSetState(ID_savcrs,ItemEnabled,1) + CALL WMenuSetState(ID_LAYFL,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM13,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM14,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM18,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM15,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM16,ItemEnabled,1) + CALL WMenuSetState(ID_ICOPY,ItemEnabled,1) + CALL WMenuSetState(ID_Clip,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM24,ItemEnabled,1) + CALL WMenuSetState(ID_MMAP,ItemEnabled,1) + CALL WMenuSetState(ID_MAPM,ItemEnabled,1) + CALL WMenuSetState(ID_NETWORK,ItemEnabled,1) + CALL WMenuSetState(ID_NODE,ItemEnabled,1) + CALL WMenuSetState(ID_ELTS,ItemEnabled,1) + CALL WMenuSetState(ID_ORDR,ItemEnabled,1) + CALL WMenuSetState(ID_CCLN,ItemEnabled,1) + CALL WMenuSetState(ID_CONTR,ItemEnabled,1) +! CALL WMenuSetState(ID_CSEC,ItemEnabled,0) + CALL WMenuSetState(ID_CSEC1,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM20,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM26,ItemEnabled,1) + CALL WMenuSetState(ID_ZOOM,ItemEnabled,1) + CALL WMenuSetState(ID_DRAW,ItemEnabled,1) + CALL WMenuSetState(ID_UNDOM,ItemEnabled,1) + CALL WMenuSetState(ID_NMAP,ItemEnabled,1) + CALL WMenuSetState(ID_CDATA,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM56,ItemEnabled,1) + CALL WMenuSetState(ID_RESETLIM,ItemEnabled,0) + CALL WMessageEnable(MouseMove , Enabled) + + + MENUS=-2 + EXIT + CASE (ID_ITEM12) ! Open option + IMP=0 + IIN=0 + if(iswtfl .eq. 1) go to 200 + fname=' ' + FILTER ="Network Files|*.rm1;*.geo;*.gfg;*.bin;*.ele;*.2dm|Rm1 file -- *.rm1|*.rm1|Geo file -- *.geo|*.geo|GFGEN file -- *.gfg|*.gfg|GFGEN bin file -- *.bin|*.bin|Rst file -- *.rst|*.rst|ele file -- *.ele|*.ele|MESH2D file -- *.2dm|*.2dm|All files|All files|*.*|" + CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + GO TO 200 + ELSE + GO TO 250 + ENDIF + 200 CONTINUE + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'geo') then + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',form='binary',ACTION='READ') + FNAMKEP=FNAME + READ(IIN) HEADR + READ(IIN) N2,M2 + REWIND (IIN) + + ITRIAN=0 + ELSEIF(SUB .EQ. 'gfg') then + IIN = 10 + IGFG=1 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. '2dm') then + IIN = 10 + IGFG=3 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. '2dm') then + IIN = 10 + IGFG=3 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. 'bin') then + IIN=12 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') + IGFG=2 + ITRIAN=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. 'rst') then + IIN=11 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',FORM='UNFORMATTED') +! OPEN(IIN,FILE=FNAME,STATUS='OLD',FORM ='BINARY') + IGFG=0 + ITRIAN=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ELSEIF(SUB .EQ. 'ele') then + IIN=10 + OPEN(IIN ,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=1 + IGFG=0 + FNAMKEP=FNAME + CALL SETGFGTRIAN(IGFG,ITRIAN,N2,M2) + ELSE + IIN = 10 + IGFG=0 + OPEN(10,FILE=FNAME,STATUS='OLD',ACTION='READ') + ITRIAN=0 + CALL SETGFGTRIAN(IGFG,ITRIAN,ID1,ID2) + ENDIF + IACTVFIL=1 + ITOTFIL=1 + FNAMEOUT(1)=FNAME + CALL SHORTNAME(FNAME,FNAMEDISP) + 250 CONTINUE + fname=' ' + filter="Map file -- *.map |*.map|Bin Map file -- *.mpb|*.mpb|Bin Map file (no head) -- *.mbb|*.mbb|RM1 file (as map) -- *.rm1|*.rm1|ESRI ASC file -- *.asc|*.asc|SURFER GRD file -- *.grd|*.grd|ESRI SHP file -- *.shp|*.shp|" + CALL WSelectFile(filter,PromptOn,FNAME,'Load Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD',action='read') + ELSEIF(SUB .EQ. 'shp') then + IMP=113 + OPEN(113,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + SUB='DBF' + CALL ADDSUB(FNAME,SUB) + OPEN(114,FILE=FNAME,STATUS='OLD',FORM ='BINARY',action='read') + ELSEIF(SUB .EQ. 'mpb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='unformatted',action='read') + ELSEIF(SUB .EQ. 'mbb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='binary',action='read') + ELSEIF(SUB .EQ. 'rm1') then + imp=13 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',action='read') + ENDIF + ENDIF + CALL WMenuSetState(ID_loadrm1,ItemEnabled,1) + CALL WMenuSetState(ID_sbin,ItemEnabled,1) + CALL WMenuSetState(ID_crsf,ItemEnabled,1) + CALL WMenuSetState(ID_savcrs,ItemEnabled,1) + CALL WMenuSetState(ID_LAYFL,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM13,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM14,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM18,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM15,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM16,ItemEnabled,1) + CALL WMenuSetState(ID_ICOPY,ItemEnabled,1) + CALL WMenuSetState(ID_Clip,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM24,ItemEnabled,1) + CALL WMenuSetState(ID_MMAP,ItemEnabled,1) + CALL WMenuSetState(ID_MAPM,ItemEnabled,1) + CALL WMenuSetState(ID_NETWORK,ItemEnabled,1) + CALL WMenuSetState(ID_NODE,ItemEnabled,1) + CALL WMenuSetState(ID_ELTS,ItemEnabled,1) + CALL WMenuSetState(ID_ORDR,ItemEnabled,1) + CALL WMenuSetState(ID_CCLN,ItemEnabled,1) + CALL WMenuSetState(ID_CONTR,ItemEnabled,1) + CALL WMenuSetState(ID_CSEC1,ItemEnabled,1) +! CALL WMenuSetState(ID_CSEC,ItemEnabled,0) + CALL WMenuSetState(ID_ITEM20,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM26,ItemEnabled,1) + CALL WMenuSetState(ID_ZOOM,ItemEnabled,1) + CALL WMenuSetState(ID_DRAW,ItemEnabled,1) + CALL WMenuSetState(ID_UNDOM,ItemEnabled,1) + CALL WMenuSetState(ID_NMAP,ItemEnabled,1) + CALL WMenuSetState(ID_CDATA,ItemEnabled,1) + CALL WMenuSetState(ID_ITEM56,ItemEnabled,1) + CALL WMenuSetState(ID_RESETLIM,ItemEnabled,0) + CALL WMessageEnable(MouseMove , Enabled) + + + MENUS=-2 + CALL INITSIZ(IIN,N2,M2,1) + EXIT + CASE (ID_ITEM13) ! Save option + WRITE(90,*) 'NWRM ITEM13' + INQUIRE(20, OPENED=OPENED) + if(.not. opened) then + FILTER ="Network Files|*.rm1;*.gfg;*.ele|Rm1 file -- *.rm1|*.rm1|GFGEN file -- *.gfg|*.gfg|ele file -- *.ele|*.ele|All files|*.*|" + + CALL WSelectFile(FILTER,SaveDialog+PromptOn,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='rm1' + CALL ADDSUB(FNAME,SUB) + + WRITE(90,*) 'IN ITEM13-NEW',IOT + WRITE(90,'(A)') FNAME,SUB + IOT = 20 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN',ACTION='READWRITE') + + call wrtout(1) + ENDIF + else + call wrtout(1) + endif + + CASE (ID_ITEM14) ! Save option + WRITE(90,*) 'NWRM ITEM14' + + INQUIRE(22, OPENED=OPENED) + if(.not. opened) then + CALL WSelectFile(ID_STRING4,SaveDialog+PromptOn,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='geo' + CALL ADDSUB(FNAME,SUB) + + WRITE(90,*) 'IN ITEM14-NEW',IOT1 + WRITE(90,'(A)') FNAME,SUB + IOT1=22 + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='binary',ACTION='READWRITE') + call wrtout(2) + ENDIF + else + call wrtout(2) + endif + + CASE (ID_ITEM18) ! Save As option + + CALL WSelectFile(ID_STRING5,SaveDialog+PromptOn,FNAME,'Save Bin Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='mpb' + CALL ADDSUB(FNAME,SUB) + impf=93 + OPEN(IMPF ,FILE=fname,STATUS='unknown',form='unformatted',ACTION='READWRITE') + + call wrtmap(1) + + ENDIF + + CASE (ID_ITEM15) ! Save As option + + CALL WSelectFile(ID_STRING3,SaveDialog+PromptOn,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='rm1' + CALL ADDSUB(FNAME,SUB) + + IOT = 20 + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN',ACTION='READWRITE') + call wrtout(1) + ENDIF + + CASE (ID_ITEM16) ! Save As option + + CALL WSelectFile(ID_STRING4,SaveDialog+PromptOn,FNAME,'Save Network File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + SUB='geo' + CALL ADDSUB(FNAME,SUB) + + IOT1 = 22 + OPEN(IOT1 ,FILE=FNAME,STATUS='UNKNOWN',form='binary',ACTION='READWRITE') + call wrtout(2) + ENDIF + + CASE (ID_BKF) ! Read background option + + fname=' ' + FILTER ="Background File|*.wmf;*.bmp;*.pcx;*.png;*.cgm;*.pic;*.jpg|wmf file -- *.wmf|*.wmf|bmp file -- *.bmp|*.bmp|pcx file -- *.pcx|*.pcx|png file -- *.png|*.png|jpeg file -- *.jpg|*.jpg|cgm file -- *.cgm|*.cgm|pic file -- *.pic|*.pic|" + CALL WSelectFile(FILTER,PromptOn+DirChange,FNAME,'Load Background file') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + NBKFL=NBKFL+1 + BFNAME(NBKFL)=FNAME + SUB1=SUB + IF(SUB .EQ. 'bmp') then + ISWBKFL(NBKFL) = 2 + ELSEIF(SUB .EQ. 'pcx') then + ISWBKFL(NBKFL) = 2 + ELSEIF(SUB .EQ. 'png' .or. sub .eq. 'jpg') then + ISWBKFL(NBKFL) = 2 + ELSE + ISWBKFL(NBKFL)=1 + ENDIF + SUB='ORG' + CALL ADDSUB(FNAME,SUB) + BFNAMR(NBKFL)=FNAME + INQUIRE (FILE = fname, EXIST = exists) + IF (.NOT. exists) THEN + IF(SUB1 .EQ. 'PNG' .or. SUB1 .EQ. 'png') SUB2='PNGW' + IF(SUB1 .EQ. 'JPG' .or. SUB1 .EQ. 'jpg') SUB2='JPGW' + CALL ADDSUB(FNAME,SUB2) + BFNAMR(NBKFL)=FNAME + INQUIRE (FILE = fname, EXIST = exists) + IF (.NOT. exists) THEN + IF(SUB2 .EQ. 'JPGW') THEN + SUB1='JGW' + CALL ADDSUB(FNAME,SUB1) + BFNAMR(NBKFL)=FNAME + ENDIF + ENDIF + INQUIRE (FILE = fname, EXIST = exists) + IF (.NOT. exists) THEN + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'ORG file does not exist!!'//CHAR(13)// & + 'Do you wish to create file and view image','Looking for ORG file') +! If answer 'Yes' set ifrmel to 0 +! + IF (WInfoDialog(4) .ne. 2) then + OPEN(104,FILE=FNAME,STATUS ='NEW', FORM ='FORMATTED') + BFMINMAX(NBKFL,1) = - XS + BFMINMAX(NBKFL,2) = - YS + BFMINMAX(NBKFL,3) = HSIZE*TXSCAL - XS + BFMINMAX(NBKFL,4) = 7.50*TXSCAL - YS + WRITE(104,'(4G16.8)') (BFMINMAX(NBKFL,I),I=1,4) + CLOSE(104) + + EXIT + ELSE + NBKFL=NBKFL-1 + EXIT + ENDIF + ENDIF +! yes + OPEN(104,FILE=FNAME,STATUS ='OLD', FORM ='FORMATTED') + READ(104,'(G16.8)') XX1 + READ(104,'(G16.8)') XX2 + READ(104,'(G16.8)') XX3 + READ(104,'(G16.8)') XX4 + READ(104,'(G16.8)') XX5 + READ(104,'(G16.8)') XX6 + CLOSE(104) + call IGrFileInfo(BFNAME(NBKFL),INFO,3) + + BFMINMAX(NBKFL,1) = XX5 + BFMINMAX(NBKFL,2) = XX6+INFO(3)*XX4 + BFMINMAX(NBKFL,3) = XX5+INFO(2)*XX1 + BFMINMAX(NBKFL,4) = XX6 + + CLOSE(104) + GO TO 125 + ENDIF + + OPEN(104,FILE=FNAME,STATUS ='OLD', FORM ='FORMATTED') + READ(104,'(4G16.8)') (BFMINMAX(NBKFL,I),I=1,4) + CLOSE(104) + 125 CONTINUE + ENDIF + + CASE (ID_ITEM24) ! Print option is selected + CALL WHardcopyOptions(3) +! +! If the user clicked OK on page setup dialog then output the contents +! of the subroutine DOPLOT to the selected printer +! + IF (WinfoDialog(ExitButtonCommon).EQ.CommonOK) THEN + CALL IGrInit('HP') ! hardcopy only output + CALL IGrFillPattern(Solid) + + CALL IgrUnits(0.,0.,HSIZE,7.5) + CALL IGrHardcopy(' ') ! Start print manager + call clscrn + CALL PLOTOT(0) ! plot graph + call rblack + CALL IGrRectangle(0.,0.,HSIZE,7.5) + + CALL IGrHardcopy('S') ! Send data to the printer + CALL IGrInit('P') ! Turn graphics back on + CALL IGrFillPattern(Solid) + + CALL IgrUnits(0.,0.,HSIZE,8.0) + CALL PLOTOT(0) + CALL HEDR + call rblack + CALL IGrRectangle(0.,0.,HSIZE,7.5) + END IF + + CASE (ID_ITEM19) ! Demo option + MENUS=-1 + IMP=0 + IIN=0 + EXIT + CASE (ID_ITEM17) ! Exit option + call rquit(iyes) + if(iyes .ne. 1) go to 100 + MENUS=0 + EXIT + CASE (ID_EXIT) ! Exit program (menu option) + call rquit(iyes) + if(iyes .ne. 1) go to 100 + MENUS=0 + EXIT + CASE (ID_NODE) + MENUS=2 + EXIT + CASE (ID_ELTS) + MENUS=1 + EXIT + CASE (ID_ORDR) + MENUS=3 + EXIT + CASE (ID_CCLN) + MENUS=6 + EXIT + CASE (ID_CSEC) + MENUS=7 + EXIT + CASE (ID_ZOOM) + MENUS=8 + EXIT + CASE (ID_DRAW) + MENUS=9 + EXIT + + CASE (ID_HELP1) + call helps(0) + go to 100 + + CASE (ID_HELP2) + call RMINFO + go to 100 + + CASE (ID_ITEM20) + CALL GDIST + CYCLE + + CASE (ID_ITEM22) + CALL SELNODE(0) + CYCLE + + CASE (ID_ALLNODES) + CALL SELNODE(1) + CYCLE + + CASE (ID_UNUSNODES) + CALL SELNODE(2) + CYCLE + + CASE (ID_ITEM23) + CALL SELELT(0) + CYCLE + END SELECT + CASE (PushButton) ! Dialog button pressed + IDBUTN = MESSAGE%VALUE1 + IDFIELD = MESSAGE%VALUE2 + CASE (MouseButDown,MouseButUp) ! Mouse button down/up + MBUTTON = MESSAGE%VALUE1 + ITIME = MESSAGE%VALUE2 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + CASE (MouseMove) ! Mouse moved + ITIME = MESSAGE%VALUE2 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + CASE (Expose) ! Window partly/wholly exposed + IX = MESSAGE%X + IY = MESSAGE%Y + IWIDTH = MESSAGE%VALUE1 + IHEIGHT = MESSAGE%VALUE2 + CASE (Resize) ! Window resized + IWIDTH = MESSAGE%VALUE1 + IHEIGHT = MESSAGE%VALUE2 + CASE (CloseRequest) ! Close window (e.g. Alt/F4) + IWINDOW = MESSAGE%WIN + call rquit(iyes) + if(iyes .ne. 1) go to 100 + menus=0 + exit +! IF (IWINDOW.EQ.0) EXIT ! Root window : exit program +! CALL WindowCloseChild(IWINDOW) + CASE (FieldChanged) ! Field change in modeless dialog + IDFIELDOLD = MESSAGE%VALUE1 + IDFIELDNEW = MESSAGE%VALUE2 + END SELECT + END DO + +500 continue + IF(MENUS .NE. 0) THEN + CALL RMAGEN(MENUS,IMP,IIN,0,IOT,IOT1,IGFG,ITRIAN,N2,M2) + ENDIF + close(90) + CALL WindowClose ! Remove program window + stop +!! CALL WindowClose ! Remove program window + END PROGRAM NEWRMAGEN + + SUBROUTINE GETSUB(FNAME,SUB) + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + INTEGER ,EXTERNAL :: LENSTR + INTEGER :: LNNAM,K + + LNNAM=LENSTR(FNAME) + SUB=' ' + DO K=LNNAM,1,-1 + IF(FNAME(K:K) .EQ. '.') THEN + IF(LNNAM .GT. K+2) THEN + SUB=FNAME(K+1:K+3) + ELSE + SUB=' ' + ENDIF + GO TO 110 + ENDIF + ENDDO +110 CONTINUE + RETURN + END + + SUBROUTINE ADDSUB(FNAME,SUB) + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=*) :: SUB + INTEGER ,EXTERNAL :: LENSTR + INTEGER :: LNNAM,K,LMPNAM + + LNNAM=LENSTR(FNAME) + DO K=LNNAM,1,-1 + IF(FNAME(K:K) .EQ. '.') THEN + lmpnam=k + FNAME=FNAME(1:LMPNAM)//SUB + GO TO 110 + ENDIF + ENDDO + FNAME=FNAME(1:LNNAM)//'.'//SUB +110 CONTINUE + RETURN + END + + SUBROUTINE SHORTNAME(FNAMELL,FNAMES) + CHARACTER(LEN=255) :: FNAMELL + CHARACTER(LEN=48) :: FNAMES + INTEGER ,EXTERNAL :: LENSTR + INTEGER :: LNNAM,K,KSTART,KEND + + LNNAM=LENSTR(FNAMELL) + DO K=1,48 + FNAMES(K:K)=' ' + ENDDO + KSTART=1 + DO K=LNNAM,1,-1 + IF(FNAMELL(K:K) .EQ. '\') THEN + KSTART=K+1 + GO TO 200 + ENDIF + ENDDO +200 KEND=LNNAM-KSTART+1 + IF(KEND .GT. 48) KEND=48 + + FNAMES(1:KEND)=FNAMELL(KSTART:KSTART+KEND-1) + RETURN + END + \ No newline at end of file diff --git a/src/src83e/NODEDISP.F90 b/src/src83e/NODEDISP.F90 new file mode 100644 index 0000000..93582c8 --- /dev/null +++ b/src/src83e/NODEDISP.F90 @@ -0,0 +1,149 @@ + Subroutine NodeDisp(nin) + + USE WINTERACTER + USE BLK1MOD +! + include 'd.inc' +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: N,IBOX,NN + INTEGER :: IERR + CHARACTER*1 :: IFLAG + + if(nin .eq. 0) then + n=1 + else + n=nin + endif + ims=0 + 100 continue + call wdialogload(IDD_NODEDATA) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,N) + NN=N + XTEMP=XUSR(N) + YTEMP=YUSR(N) + WDTEMP=WIDTH(N) + CALL WDialogPutReal(IDF_REAL1,XTEMP,'(F10.2)') + CALL WDialogPutReal(IDF_REAL2,YTEMP,'(F10.2)') + CALL WDialogPutReal(IDF_REAL3,WD(N),'(F10.2)') + CALL WDialogPutReal(IDF_REAL4,WDTEMP,'(F10.2)') + CALL WDialogPutReal(IDF_REAL5,SS1(N),'(F10.2)') + CALL WDialogPutReal(IDF_REAL6,SS2(N),'(F10.2)') + CALL WDialogPutReal(IDF_REAL7,WIDS(N),'(F10.2)') + CALL WDialogPutReal(IDF_REAL8,WIDBS(N),'(F10.2)') + CALL WDialogPutReal(IDF_REAL9,SSO(N),'(F10.2)') + CALL WDialogPutReal(IDF_REAL10,BS1(N),'(F10.4)') + IF(LOCK(N) .NE. 0) then + CALL WDialogPutCheckBox(IDF_CHECK1,1) + ELSE + CALL WDialogPutCheckBox(IDF_CHECK1,0) + ENDIF + + CALL WDialogSelect(IDD_NODEDATA) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modeless) + ierr=infoerror(1) + + if(ims .eq. 1 .or. nin .gt. 0) go to 200 + 150 CONTINUE + call wdialogload(IDD_SELNODE) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,N) + + CALL WDialogSelect(IDD_SELNODE) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,ModaL) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + ims=1 + go to 100 + endif +!ipk sep02 + ims=1 + go to 100 + enddo + + 200 continue +! CALL WDialogSelect(IDD_NODEDATA) +! ierr=infoerror(1) +! Branch depending on type of message. +! +! CALL WDialogGetInteger(IDF_INTEGER1,N) +! WRITE(90,*) 'IN NODEDISP N,NN', N,NN +! IF(N .NE. NN) go to 100 + + DO +!WHILE(.NOT.QUIT) + CALL WMessage(ITYPE,MESSAGE) + SELECT CASE (ITYPE) + CASE (PushButton) + IF(MESSAGE%VALUE1.EQ.IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL WDialogGetReal(IDF_REAL1,XTEMP) + CALL WDialogGetReal(IDF_REAL2,YTEMP) + XUSR(N)=XTEMP + YUSR(N)=YTEMP + CALL WDialogGetReal(IDF_REAL3,WD(N)) + CALL WDialogGetReal(IDF_REAL4,WDTEMP) + CALL WDialogGetReal(IDF_REAL5,SS1(N)) + CALL WDialogGetReal(IDF_REAL6,SS2(N)) + CALL WDialogGetReal(IDF_REAL7,WIDS(N)) + CALL WDialogGetReal(IDF_REAL8,WIDBS(N)) + CALL WDialogGetReal(IDF_REAL9,SSO(N)) + CALL WDialogGetReal(IDF_REAL10,BS1(N)) + CORD(N,1)=(XUSR(N)+XS)/TXSCAL + CORD(N,2)=(YUSR(N)+YS)/TXSCAL + call WDialogHide() + call wdialogUNload() + WIDTH(N)=WDTEMP + RETURN + ELSEIF(MESSAGE%VALUE1.EQ.IDNEXT) THEN + CALL WDialogGetInteger(IDF_INTEGER1,N) + CALL WDialogGetReal(IDF_REAL1,XTEMP) + CALL WDialogGetReal(IDF_REAL2,YTEMP) + XUSR(N)=XTEMP + YUSR(N)=YTEMP + CALL WDialogGetReal(IDF_REAL3,WD(N)) + CALL WDialogGetReal(IDF_REAL4,WDTEMP) + CALL WDialogGetReal(IDF_REAL5,SS1(N)) + CALL WDialogGetReal(IDF_REAL6,SS2(N)) + CALL WDialogGetReal(IDF_REAL7,WIDS(N)) + CALL WDialogGetReal(IDF_REAL8,WIDBS(N)) + CALL WDialogGetReal(IDF_REAL9,SSO(N)) + CALL WDialogGetReal(IDF_REAL10,BS1(N)) + CORD(N,1)=(XUSR(N)+XS)/TXSCAL + CORD(N,2)=(YUSR(N)+YS)/TXSCAL + WIDTH(N)=WDTEMP + GO TO 150 + ELSEIF(MESSAGE%VALUE1.EQ.IDCANCEL) THEN + call WDialogHide() + call wdialogUNload() + RETURN + ENDIF + END SELECT + END DO + + + + RETURN + END + + \ No newline at end of file diff --git a/src/src83e/NODES.F90 b/src/src83e/NODES.F90 new file mode 100644 index 0000000..7335da5 --- /dev/null +++ b/src/src83e/NODES.F90 @@ -0,0 +1,911 @@ +!IPK LAST UPDATE SEP 23 2015 ADD TESTING FOR CHNAGED ELEMENTS/NODES +! Last change: IPK 13 Jan 98 10:01 am +!ipk last update to add deletion opton when moving nodes +!ipk last update Jan 12 1998 +!ipk last update Nov18 1997 +! +!**************************************************************** +! + SUBROUTINE ADDNOD +! +! Input additional node locations from screen +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +!IPK MAY02 + INCLUDE 'TXFRM.COM' +! + CHARACTER*1 IFLAG,ANS,ANSW(0:9) + CHARACTER*32 JUNK + CHARACTER*20 NODH +!ipk jan98 + CHARACTER*80 LIND + DATA ANSW/'a','m','d','f','g','e','h','z','r','q'/ + data itime/0/ + + if(itime .eq. 0) then + nodsh=1 + itime=1 + endif + ISWT=3 +! +! Draw box around selections +! + 2 CONTINUE + NHTP=4 + NMESS=0 + NBRR=0 + CALL HEDR +! +! Get answer +! + 3 call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + + IF(ANS .EQ. 'c') THEN + if(ibox .eq. 0) go to 3 + I=IBOX-1 + ANS=ANSW(I) + ENDIF +! + IF(ANS .EQ. 'a') THEN + ISWT=1 + NHTP=0 + NBRR=0 + NMESS=16 + ELSEIF(ANS .EQ. 'm') THEN + ISWT=0 + NHTP=0 + NBRR=0 + NMESS=17 + ELSEIF(ANS .EQ. 'd') THEN +! +! Call deleting operations +! + CALL DELOP + IF(IRMAIN .EQ. 1) RETURN + GO TO 2 + ELSEIF(ANS .EQ. 'e') THEN + CALL GRIDSB(0) + IF(IRMAIN .EQ. 1) RETURN + GO TO 2 + ELSEIF(ANS .EQ. 'q') THEN + RETURN + ELSEIF(ANS .EQ. 'f') THEN +! +! Search for a plot a grid centered around a node +! + NHTP=0 + NBRR=0 + NMESS=1 + CALL HEDR + NMESS=1 + CALL GETINT(NODSH) + IF(INEW(NODSH) .LE. 0) GO TO 2 + DO 4 I=1,NP + IF(CORD(I,1) .GT. VOID) THEN + INSKP(I)=0 + ENDIF + 4 CONTINUE + DO 5 I=1,NE + IF(IMAT(I) .GT. 0) THEN + IESKP(I)=0 + ENDIF + 5 CONTINUE + XP=CORD(NODSH,1) + YP=CORD(NODSH,2) + XMIN=XP-5.0*PSCALE + YMIN=YP-3.5*PSCALE +!ipk nov97 add (1) + CALL PLOTOT(1) + FPN=NODSH + HT=0.15 + XP=CORD(NODSH,1) + YP=CORD(NODSH,2) + CALL RCYAN + CALL NUMBR(XP,YP+0.07,HT,FPN,0.0,-1) + CALL RBLUE +! + GO TO 2 + ELSEIF(ANS .EQ. 'g') THEN +! +! This option generates nodes on a line +! + CALL GNODE(1) + IF(IRMAIN .EQ. 1) RETURN + GO TO 2 + ELSEIF(ANS .EQ. 'h') THEN + CALL HELPS(3) + IF(IRMAIN .EQ. 1) RETURN + GO TO 2 + ELSE + GO TO 3 + ENDIF + 6 CONTINUE +! +! Test for adding operation +! + IF(ISWT .EQ. 1) THEN +! + CALL GETNOD(J) + CALL GETNOD(J) + CALL GETNOD(J) + IF(IRMAIN .EQ. 1) RETURN +! +! Get number of node nearest cursor (if ISWT = 0) +! + ELSE + 61 IBOX=1 +! CALL CLRBOX + CALL HEDR +!ipk jan98 + call wrtbox(idelv) + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +!ipk jan98 add option for deleting elevation on move + IF(IBOX .EQ. 7 .or. iflag .eq. 'e') THEN + IDELV=MOD(IDELV+1,2) + GO TO 61 + ENDIF + J=INODE +!ipk jan98 + if(idelv .eq. 1) then + WD(J)=-9999. + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. + WIDBS(J)=0. + SSO(J)=0. + endif +!ipk jan98 +! + IF(IFLAG .EQ. 'q') THEN +!ipk feb94 CALL WRTOUT(0) + GO TO 2 + ENDIF + CALL PLTNOD(J,1) +! + ENDIF +! +! Deleting operation +! + IF(ISWT .EQ. 2) THEN + WRITE(NODH,5000) j +! CALL CLRBOX + CALL HEDR + CALL SYMBL(0.,7.70,0.20,NODH,0.,20) + CALL DELETN(J) + GO TO 6 + ENDIF + WRITE(NODH,5000) j + 5000 FORMAT('Processing node',i5) + 7 CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,NODH,0.,20) + NHTP=0 +! NMESS=0 + NBRR=3 + IF(ISWT .EQ. 0) then + NMESS=16 + endif + CALL HEDR +! + IF (J .GE. MAXP) THEN + CALL SETD(23) +!IPK JAN98 WRITE(*,*) ' Node number exceeds MAXP ' +!IPK JAN98 WRITE(*,*) ' Enter -save- to save the file as is' +!IPK JAN98 WRITE(*,*) ' Enter -quit- to terminate' +!IPK JAN98 READ(*,'(A)') JUNK + CALL CLSCRN() + WRITE(LIND,*) ' Node number exceeds MAXP ' + call symbl & + & (1.1,4.6,0.25,LIND,0.0,80) + WRITE(LIND,*) ' Enter -save- to save the file as is' + call symbl & + & (1.1,4.1,0.25,LIND,0.0,80) + WRITE(LIND,*) ' Enter -quit- to terminate' + call symbl & + & (1.1,3.8,0.25,LIND,0.0,80) + ndig=4 + CALL GTCHARX(JUNK,NDIG,5.0,4.0) + IF(JUNK .NE. 'save') THEN + CALL WRTOUT(0) + CALL Quit_Pgm() + stop + else + call wrtout(1) + CALL Quit_Pgm() + stop + ENDIF +!ipk an97 RETURN + ENDIF +! +! Get screen coordinate of node +! + CALL XYLOC(XX,YY,IFLAG,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN +!ipk feb94 CALL WRTOUT(0) +! IF(ISWT .EQ. 2) NP=NP-1 + if(inew(j) .eq. 0 .and. j .eq. np) np=np-1 + GO TO 2 + ENDIF +! + IF (IFLAG .EQ. 'c') THEN +! + IF(YY .GT. 7.5) THEN + CALL DELETN(J) + GO TO 6 + ENDIF + INSKP(J)=0 + CORD(J,1) = XX + CORD(J,2) = YY + INEW(J) = 1 +! + XUSR(J) = XX*TXSCAL - XS + YUSR(J) = YY*TXSCAL - YS + IF (J .GT. NP) NP = J +! WRITE(IOT,'(I10,2F10.3)') J, XUSR(J),YUSR(J) + CALL PLTNOD(J,0) + ICHG=0 +! + IF(ISWT .EQ. 0) NMESS=17 + GOTO 6 + ENDIF + RETURN +! + END +! +!**************************************************************** +! + SUBROUTINE ADDPTH +! +! Add nodal bottom elevations +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 IFLAG,ANSW(10) + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + DATA NTYPP,NLOCC,BELEV/1,0,0./ +! + 4 CONTINUE + NHTP = 0 + NMESS = 45 + NBRR = 0 + CALL HEDR + xprt=3.2 + NMESS = 14 +! + CALL ADJUSTOPT(NTYPP,NLOCC) + + CALL GETFPN(BELEV) +! +! Write out current depths +! + 7 HT = .15 + DO 10 J=1,NP + IF(INSKP(J) .EQ. 0) THEN + IF (CORD(J,1) .GT. VDX) THEN +!!SEP02 FPN = WD(J)*10. + FPN = WD(J) + X = CORD(J,1) + Y = CORD(J,2) + .07 + IF(X .GT. 0. .AND. X .LT. 10.0 .AND. & + & Y .GT. 0. .AND. Y .LT. 7.5) THEN +!!SEP02 CALL NUMBR(X,Y,HT,FPN,0.0,-1) + call numbr(x,y,0.12,fpn,0.0,1) + ENDIF + ENDIF + ENDIF + 10 END DO +! +! Input new depths +! + NMESS = 15 + NBRR = 4 + CALL HEDR + 5 IBOX=1 + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF +! + IF(IFLAG .EQ. 'q') THEN +!ipk feb94 CALL WRTOUT(0) + RETURN + ELSEIF(IFLAG .EQ. 'e' .OR. IFLAG .EQ. 'n') THEN +!ipk nov97 add (1) + CALL PLOTOT(1) + GO TO 4 + ENDIF + XPRT=XPRT+0.5 + IF(XPRT .GT. 10.) XPRT=0. + FPN= INODE + CALL RRED + CALL NUMBR(XPRT,7.70,HT,FPN,0.0,-1) + IF (IFLAG .EQ. 'c') THEN + IF(NTYPP .EQ. 1) THEN + WD(INODE) = BELEV + ELSE + WD(INODE) = WD(INODE)+BELEV + ENDIF + IF(NLOCC .EQ. 1) THEN + LOCK(INODE)=1 + ENDIF + ichg=0 + FPN = WD(INODE) + X = CORD(INODE,1) + Y = CORD(INODE,2) -0.10 + call numbr(x,y,0.12,fpn,0.0,1) +!!SEP02 CALL NUMBR(X,Y,HT,FPN,0.0,-1) + CALL RBLUE +! + ELSEIF(IFLAG .EQ. 'a') THEN + CALL RRED + ichg=0 + DO 100 J=1,NP + IF (CORD(J,1) .GE. VDX) THEN + WD(J)=BELEV + FPN=BELEV + X = CORD(J,1) + Y = CORD(J,2) + .11 + CALL NUMBR(X,Y,HT,FPN,0.0,-1) + ENDIF + 100 CONTINUE + CALL RBLUE + CALL WRTOUT(0) + ELSEIF(IFLAG .EQ. 'f') THEN + CALL RRED + DO 110 J=1,NP + IF (CORD(J,1) .GE. VDX .AND. WD(J) .LT. -9000.) THEN + WD(J)=BELEV + ichg=0 + FPN=BELEV + X = CORD(J,1) + Y = CORD(J,2) + .11 + CALL NUMBR(X,Y,HT,FPN,0.0,-1) + ENDIF + 110 CONTINUE + CALL RBLUE + CALL WRTOUT(0) +! + ELSE +!ipk jan98 WRITE(*,*) CHAR(7),CHAR(7) + ENDIF +! + GOTO 5 +! + END +! + SUBROUTINE JUNGEN(J,I,IERR) +! +! Find elements coming into node J, change all but first node +! Form a new junction element +! +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +!IPK MAY02 + INCLUDE 'TXFRM.COM' + +! + KOUNT=1 + DO 200 N=1,NE +!IPKOCT93 IF(IMAT(N) .GT. 0 .AND. IMAT(N) .LT. 901) THEN + IF(IMAT(N) .GT. 0 .AND. (IMAT(N) .LT. 901 .OR. & + & IMAT(N) .GT. 903) ) THEN + DO 180 K=1,8 + IF(NOP(N,K) .EQ. I) THEN + IF(K .GT. 3) THEN + IERR=1 + RETURN + ENDIF + IF(KOUNT .EQ. 1) THEN + NOP(J,1)=I + IJUN(J)=1 + KOUNT=2 + ELSE + CALL GETNOD(N2) + NOP(J,KOUNT)=N2 + IJUN(N2)=KOUNT + KOUNT=KOUNT+1 + CORD(N2,1) = CORD(I,1) + CORD(N2,2) = CORD(I,2) + WD(N2)=WD(I) + WIDTH(N2) = WIDTH(I) + SS1(N2)=SS1(I) + SS2(N2)=SS2(I) + WIDS(N2)=WIDS(I) + INSKP(N2)=0 + INEW(N2) = 1 + NOP(N,K) = N2 +! + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + CALL PLTNOD(N2,1) + GO TO 200 + ENDIF + ENDIF + 180 CONTINUE + ENDIF + 200 END DO + IF(KOUNT .LT. 9) THEN + DO 300 K=KOUNT,8 + NOP(J,K)=0 + 300 CONTINUE + ENDIF + IMAT(J)=901 + IESKP(J)=1 + RETURN + END +! +!**************************************************************** +! + SUBROUTINE ELDAT +! +! Add bottom elevations to message file and display +! + USE BLKMAP + USE BLK1MOD + USE WINTERACTER + + include 'd.inc' + +! INCLUDE 'BLK1.COM' + +!IPK MAY02 + INCLUDE 'TXFRM.COM' +! + CHARACTER*1 IFLAG,ANSW(10) + CHARACTER(LEN=256) :: FILTER + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + LOGICAL :: OPENED + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ +! +!ipk mar00 + jp=2 + DO 200 N=1,MAXLIN + IF(LINTYP(N) .EQ. -999) THEN + NLIN=N + GO TO 205 + ENDIF + 200 END DO + 205 CONTINUE + IF(NLIN .GT. 1) THEN + IF(LINTYP(NLIN-1) .NE. 2) THEN + LINTYP(NLIN)=2 + ELSE + NLIN=NLIN-1 + ENDIF + ENDIF + DO 250 J=MAXPL,1,-1 + IF(CMAP(J,1) .GE. VDX) THEN + JP=J+1 + GO TO 255 + ENDIF + 250 END DO + 255 JP=JP-1 + IPSW(6)=1 +!ipk nov97 add (1) + CALL PLOTOT(1) + write(90,6010) + 6010 format(' The lines that follow are locations and new bottom ' & + & ,'elevations.'/' Note that a zoom operation may insert'& + & ,' other information') +! + 4 CONTINUE + NHTP = 0 + NMESS = 45 + NBRR = 0 + CALL HEDR +! + NMESS = 14 + CALL GETFPN(BELEV) +! +! Input new depths +! + 7 CONTINUE + NMESS = 15 + NBRR = 4 + CALL HEDR +! +! Get screen coordinates +! + IBOX = 0 + CALL XYLOC(XX,YY,IFLAG,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF + IF(IFLAG .EQ. 'q')THEN + RETURN + ENDIF + IF(IFLAG .EQ. 'e') THEN + RETURN + ENDIF + IF(IFLAG .EQ. 'n')THEN + GO TO 4 + ENDIF +! + IF (IFLAG .EQ. 'c') THEN +! + JP=JP+1 + CMAP(JP,1) = XX + CMAP(JP,2) = YY + VAL(JP)=BELEV +! + XMAP(JP) = XX*TXSCAL - XS + YMAP(JP) = YY*TXSCAL - YS + IMAPOUT=27 + INQUIRE(27, OPENED=OPENED) + if(.not. opened) then + Filter='MAP file -- *.map|*.map|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Map Data File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(IMAPOUT,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + WRITE(IMAPOUT,*) '2,0' + ELSE + GO TO 260 + ENDIF + ENDIF + WRITE(IMAPOUT,6000) XMAP(JP),YMAP(JP),VAL(JP) + 260 CONTINUE + WRITE(90,6000) XMAP(JP),YMAP(JP),VAL(JP) + 6000 FORMAT(3F16.4) + FPN = BELEV + HT=0.15 + CALL RRED + CALL NUMBR(XX,YY,HT,FPN,0.0,-1) +! + GOTO 7 +! + ELSE +!ipk jan98 WRITE(*,*) CHAR(7),CHAR(7) + ENDIF +! + GOTO 7 +! + END +! + SUBROUTINE DELOP +! +! Input additional delete options from screen +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +!IPK MAY02 + INCLUDE 'TXFRM.COM' + + INCLUDE 'BFILES.I90' + +! + CHARACTER*1 IFLAG,ANS,ANSW(0:9) + CHARACTER*20 NODH + DATA ANSW/'l','m','g','u','f','j','h','z','r','q'/ +! +! Draw box around selections +! + 2 CONTINUE + NHTP=10 + NMESS=0 + NBRR=0 + CALL HEDR +! +! Get answer +! + 3 call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF(ANS .EQ. 'c') THEN + if(ibox .eq. 0) go to 3 + I=IBOX-1 + ANS=ANSW(I) + ENDIF + IF(ANS .EQ. 'l') THEN +! +! Delete all midside nodes +! + CALL DELETM(0) + ELSEIF(ANS .EQ. 'm') THEN +! +! Delete all center located midsides +! + CALL DELETM(1) + ELSEIF(ANS .EQ. 'g') THEN +! +! Deleting operation for nodes +! + NHTP=0 + NBRR=3 + NMESS=18 + + 6 CONTINUE +! + IBOX=1 + CALL HEDR + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + J=INODE +! + IF(IFLAG .EQ. 'q') THEN +!ipk feb94 CALL WRTOUT(0) + GO TO 2 + ENDIF + CALL PLTNOD(J,1) +! + WRITE(NODH,5000) j + 5000 FORMAT('Processing node',i5) + CALL HEDR + CALL SYMBL(0.,7.70,0.20,NODH,0.,20) + CALL DELETN(J) + IRDONE=0 + GO TO 6 + ELSEIF(ANS .EQ. 'u') THEN +! +! Delete all unused nodes +! + CALL DELETM(2) + ELSEIF(ANS .EQ. 'j') THEN +! +! Join two nodes together in the element lists +! + CALL JOIN(1) + ELSEIF(ANS .EQ. 'f') THEN +! +! Fill midside nodes +! +!ipk aug02 + CALL FILM(0) + ELSEIF(ANS .EQ. 'h') THEN + CALL HELPS(7) + ELSEIF(ANS .EQ. 'q') THEN + RETURN + ENDIF + GO TO 2 + END +! + SUBROUTINE JOIN(ISWTJ) +! +! Routine to join references to two nodes +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 IFLAG +! + 61 IBOX=1 + NHTP=0 + NBRR=3 + NMESS=15 + CALL HEDR + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,INODE,IFLAG,INSKP,IBOX) + IF(IFLAG .EQ. 'q') THEN + RETURN + ENDIF + FPN= INODE + CALL NUMBR(2.0,7.70,0.2,FPN,0.0,-1) +! CALL PROX(CORD(1,1),CORD(1,2),NP,XX2,YY2,INODE2,IFLAG,INSKP,IBOX) +! IF(IFLAG .EQ. 'q') THEN +! RETURN +! ELSEIF(INODE2 .EQ. INODE) THEN +! +! Get second node +! + CALL PROX2(CORD(1,1),CORD(1,2),NP,XX,YY,INODE, & + & XX2,YY2,INODE2,IFLAG,INSKP,IBOX) + IF(IFLAG .EQ. 'q') THEN + RETURN + ENDIF +! ENDIF +! FPN= INODE2 +! CALL NUMBR(2.5,7.70,0.2,FPN,0.0,-1) + + INODE1=INODE + CALL JOINDEL(INODE1,INODE2) + + CALL PLOTOT(1) + GO TO 61 +! ENDIF + END + + SUBROUTINE JOINDEL(INODE1,INODE2) +! Routine to join references to two nodes +! + USE BLK1MOD +! +! Search for references to INODE2 +! + DO N=1,NE + NCN=NCORN(N) + IF(NCN .GT. 0) THEN + DO M=1,NCN + IF(NOP(N,M) .EQ. INODE2) THEN +! +! Change them to INODE +! + NOP(N,M)=INODE1 + ENDIF + ENDDO + ENDIF + ENDDO +! +! Remove node now +! + CORD(INODE2,1)=VOID + CORD(INODE2,2)=VOID + XUSR(INODE2) = VOID + YUSR(INODE2) = VOID + INSKP(INODE2)=1 + INEW(INODE2) = 0 + WD(INODE2)=-9999. + WIDTH(INODE2)=0. + SS1(INODE2)=0. + SS2(INODE2)=0. + WIDS(INODE2)=0. +!IPK MAY03 + ICHG=0 +!ipk nov97 add (1) + RETURN + END + + SUBROUTINE JOINALL + USE BLK1MOD + + NMESS = 46 + TOLER=0.1 + CALL GETFPN(TOLER) + + DO N=1,NP-1 + IF(CORD(N,1) .EQ. VOID) CYCLE + DO M=N+1,NP + IF(CORD(M,1) .EQ. VOID) CYCLE + DIST=SQRT((YUSR(M)-YUSR(N))**2+(XUSR(M)-XUSR(N))**2) + IF(DIST .LT. TOLER) THEN + CALL JOINDEL(N,M) + GO TO 100 + ENDIF + ENDDO + 100 CONTINUE + ENDDO + + CALL PLOTOT(1) + RETURN + END +!**************************************************************** +! + SUBROUTINE ADDPTH2(nodlist,ndlist) +! +! Add nodal bottom elevations +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 IFLAG,ANSW(10) + + dimension nodlist(*) + + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + DATA NTYPP,NLOCC/1,0/ +! + 4 CONTINUE + NHTP = 0 + NMESS = 45 + NBRR = 0 + CALL HEDR + xprt=3.2 + NMESS = 14 +! + CALL ADJUSTOPT(NTYPP,NLOCC) + + CALL GETFPN(BELEV) +! +! Write out current depths +! + 7 HT = .15 + DO 10 J=1,NP + IF(INSKP(J) .EQ. 0) THEN + IF (CORD(J,1) .GT. VDX) THEN +!!SEP02 FPN = WD(J)*10. + FPN = WD(J) + X = CORD(J,1) + Y = CORD(J,2) + .07 + IF(X .GT. 0. .AND. X .LT. HSIZE .AND. & + & Y .GT. 0. .AND. Y .LT. 7.5) THEN +!!SEP02 CALL NUMBR(X,Y,HT,FPN,0.0,-1) + call numbr(x,y,0.12,fpn,0.0,1) + ENDIF + ENDIF + ENDIF + 10 END DO +! +! Input new depths +! + DO J=1,NDLIST + INODE=NODLIST(J) + FPN= INODE + CALL RRED + + IF(NTYPP .EQ. 1) THEN + WD(INODE) = BELEV + ELSE + WD(INODE) = WD(INODE)+BELEV + ENDIF + IF(NLOCC .EQ. 1) THEN + LOCK(INODE)=1 + ENDIF + ichg=0 + FPN = WD(INODE) + X = CORD(INODE,1) + Y = CORD(INODE,2) -0.10 + call numbr(x,y,0.12,fpn,0.0,1) +!!SEP02 CALL NUMBR(X,Y,HT,FPN,0.0,-1) + CALL RBLUE + ENDDO +! +! + RETURN +! + END +! + SUBROUTINE FINDNOD +! +! Search for a plot a grid centered around a node +! +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +!IPK MAY02 + INCLUDE 'TXFRM.COM' +! + NHTPSAV=NHTP + NMESSAV=NMESS + NBRRSAV=NBRR + NHTP=0 + NBRR=0 + NMESS=1 + CALL HEDR + NMESS=1 + CALL GETINT(NODSH) + IF(INEW(NODSH) .LE. 0) RETURN + DO 4 I=1,NP + IF(CORD(I,1) .GT. VOID) THEN + INSKP(I)=0 + ENDIF + 4 CONTINUE + DO 5 I=1,NE + IF(IMAT(I) .GT. 0) THEN + IESKP(I)=0 + ENDIF + 5 CONTINUE + XP=CORD(NODSH,1) + YP=CORD(NODSH,2) + XMIN=XP-5.0*PSCALE + YMIN=YP-3.5*PSCALE +!ipk nov97 add (1) + CALL PLOTOT(1) + FPN=NODSH + HT=0.15 + XP=CORD(NODSH,1) + YP=CORD(NODSH,2) + CALL RCYAN + CALL NUMBR(XP,YP+0.07,HT,FPN,0.0,-1) + CALL RBLUE + NHTP=NHTPSAV + NMESS=NMESSAV + NBRR=NBRRSAV + CALL HEDR +! + RETURN + END \ No newline at end of file diff --git a/src/src83e/OK.ICO b/src/src83e/OK.ICO new file mode 100644 index 0000000..e95f890 Binary files /dev/null and b/src/src83e/OK.ICO differ diff --git a/src/src83e/OUTLINES.F90 b/src/src83e/OUTLINES.F90 new file mode 100644 index 0000000..19c7c1c --- /dev/null +++ b/src/src83e/OUTLINES.F90 @@ -0,0 +1,303 @@ + SUBROUTINE OUTLINES(ISWT) + + USE WINTERACTER + USE BLK1MOD + include 'd.inc' +! INCLUDE 'BLK1.COM' + +! INTEGER*2 MSN +! COMMON /MID/ MSN(MAXP) + + CHARACTER(LEN=255) :: FNAME,FILTER + CHARACTER(LEN=4) :: SUB + REAL XCEN(10),YCEN(10),MTYP(10) + LOGICAL OPENED,LSTAT + CHARACTER*1 IFLAG,ANS(10) + DATA ANS/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + DATA PI2/1.5708/ + IF(.NOT. ALLOCATED(ICONNCT)) THEN + ALLOCATE (ICONNCT(MAXP,3),IOUTLST(10,5000),NOUTLST(10),NKEP(MAXP)) + ENDIF + IF(.NOT. ALLOCATED(XOUT)) THEN + ALLOCATE (XOUT(5000,10),YOUT(5000,10)) + ENDIF + NOUTLST=0 + IOUTSW=2 + IPOS=2 + IF(ISWT .EQ. 1) GO TO 80 + IOUTOUT=26 + INQUIRE(26, OPENED=OPENED) + if(.not. opened) then + Filter='OUTLINE file -- *.dat|*.dat|POLY file -- *.poly|*.poly|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Outline File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(IOUTOUT,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + ELSE + GO TO 1 + ENDIF + ENDIF + + 1 CONTINUE + + call wdialogload(IDD_DIALOG08) + ierr=infoerror(1) + + + call wdialogputRadioButton(idf_radio1) + + + CALL WDialogSelect(IDD_DIALOG08) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ipos) + ipos=3-ipos + go to 50 + endif + ipos= 0 + go to 50 + enddo + ipos= 2 + 50 continue + IF(SUB(1:3) .EQ. 'dat') THEN + IOUTSW=0 + ELSE + IOUTSW=1 + ENDIF +! +! FORM LIST OF ELEMENT SIDES THAT ARE ON THE OUTSIDE + 80 CONTINUE + DO N=1,NP + MSN(N)=0 + ENDDO + ILINEL=0 + DO N=1,NE + IF(IMAT(N) .LE. 0) CYCLE + IF(IMAT(N) .NE. 999 .AND. NCORN(N) .GT. 5 .AND. (IMAT(N) .LT. 900 .OR. IMAT(N) .GT. 903)) THEN + NCN=NCORN(N) + DO K=2,NCN,2 + J = NOP(N,K) + if(J .gt. 0) then + MSN(J) = MSN(J) + 1 + ICONNCT(J,3)=N + ICONNCT(J,1)=NOP(N,K-1) + IF(K .EQ. NCN) THEN + ICONNCT(J,2)=NOP(N,1) + ELSE + ICONNCT(J,2)=NOP(N,K+1) + ENDIF + endif + ENDDO + ELSEIF(IMAT(N) .NE. 999 .AND. NCORN(N) .LE. 5 .AND. (IMAT(N) .LT. 900 .OR. IMAT(N) .GT. 903)) THEN + ILINEL=1 + IF(NCORN(N) .EQ. 5) THEN + DO K=1,5,4 + J=NOP(N,K) + MSN(J)=MSN(J)-1 + ICONNCT(J,-MSN(J))=N + ENDDO + ELSE + DO K=1,3,2 + J=NOP(N,K) + MSN(J)=MSN(J)-1 + ICONNCT(J,-MSN(J))=N + ENDDO + ENDIF + ENDIF + ENDDO + +! WORK THROUGH OUTSIDE NODES FORMING UP TO 10 CONTIUOUS SEQUENCES + + DO K=1,10 + JJ=0 + DO J=1,NP + IF(MSN(J) .EQ. 1) THEN + MTYP(K)=1 +! +! THIS IS A STARTING POINT EXTRACT A CORNER NODE + IOUTLST(K,1)=ICONNCT(J,1) + if(ipos .eq. 1) then + IOUTLST(K,2)=ICONNCT(J,2) + JJ=2 + else + IOUTLST(K,2)=J + IOUTLST(K,3)=ICONNCT(J,2) + JJ=3 + endif + N=ICONNCT(J,3) + IF(NOP(N,7) .EQ. 0) THEN + XCEN(K)=(XUSR(NOP(N,1))+XUSR(NOP(N,3))+XUSR(NOP(N,5)))/3. + YCEN(K)=(YUSR(NOP(N,1))+YUSR(NOP(N,3))+YUSR(NOP(N,5)))/3. + ELSE + XCEN(K)=(XUSR(NOP(N,1))+XUSR(NOP(N,3))+XUSR(NOP(N,5))+XUSR(NOP(N,7)))/4. + YCEN(K)=(YUSR(NOP(N,1))+YUSR(NOP(N,3))+YUSR(NOP(N,5))+YUSR(NOP(N,7)))/4. + ENDIF + MSN(J)=0 + ICONNCT(J,1)=0 + ICONNCT(J,2)=0 + +! NOW LOOK FOR A CONNECTION TO ICONNCT(J,2) + + 100 CONTINUE + DO L=1,NP + IF(MSN(L) .EQ. 1) THEN + IF(ICONNCT(L,1) .EQ. IOUTLST(K,JJ)) THEN + +! FOUND ONE + + if(ipos .eq. 2) then + IOUTLST(K,JJ+1)=ICONNCT(L,2) + JJ=JJ+1 + else + IOUTLST(K,JJ+1)=L + IOUTLST(K,JJ+2)=ICONNCT(L,2) + JJ=JJ+2 + endif + MSN(L)=0 + ICONNCT(L,1)=0 + JTEMP=ICONNCT(L,2) + ICONNCT(L,2)=0 + IF(JTEMP .EQ. IOUTLST(K,1)) GO TO 200 + GO TO 100 + ELSEIF(ICONNCT(L,2) .EQ. IOUTLST(K,JJ)) THEN + +! FOUND ONE THE OPPOSITE WAY + + IOUTLST(K,JJ+1)=L + IOUTLST(K,JJ+2)=ICONNCT(L,1) + JJ=JJ+2 + MSN(L)=0 + JTEMP=ICONNCT(L,1) + ICONNCT(L,1)=0 + ICONNCT(L,2)=0 + IF(JTEMP .EQ. IOUTLST(K,1)) GO TO 200 + GO TO 100 + ENDIF + + ENDIF + ENDDO + ELSEIF(MSN(J) .EQ. -1) THEN + MTYP(K)=-1 + JJ=J + JO=J + LL=1 + NN=ICONNCT(JJ,LL) + IOUTLST(K,LL)=JJ + 130 LL=LL+1 + IF(NCORN(NN) .EQ. 5) THEN + NNOP=5 + ELSE + NNOP=3 + ENDIF + IF(NOP(NN,1) .EQ. JJ) THEN + JJ=NOP(NN,NNOP) + JL=NOP(NN,3) + IOUTLST(K,LL)=JL + ELSE + JJ=NOP(NN,1) + JL=JJ + IOUTLST(K,LL)=JJ + ENDIF + CALL GETLINANG(ANGL,JO,JJ) + ANGL1=ANGL-PI2 + IF(LL .EQ. 2) THEN + XOUT(1,K)=XUSR(JO)+WIDTH(JO)/2.*COS(ANGL1) + YOUT(1,K)=YUSR(JO)+WIDTH(JO)/2.*SIN(ANGL1) + XOUT(4999,K)=XUSR(JO)-WIDTH(JO)/2.*COS(ANGL1) + YOUT(4999,K)=YUSR(JO)-WIDTH(JO)/2.*SIN(ANGL1) + ENDIF + XOUT(LL,K)=XUSR(JL)+WIDTH(JL)/2.*COS(ANGL1) + YOUT(LL,K)=YUSR(JL)+WIDTH(JL)/2.*SIN(ANGL1) + XOUT(5000-LL,K)=XUSR(JL)-WIDTH(JL)/2.*COS(ANGL1) + YOUT(5000-LL,K)=YUSR(JL)-WIDTH(JL)/2.*SIN(ANGL1) + + IF(MSN(JJ) .EQ. -1) GO TO 150 + IF(ICONNCT(JJ,1) .EQ. NN) THEN + NN=ICONNCT(JJ,2) + ELSE + NN=ICONNCT(JJ,1) + ENDIF + GO TO 130 +150 MSN(JJ)=0 + JJ=LL + DO JJJ=LL,1,-1 + JJ=JJ+1 + XOUT(JJ,K)=XOUT(5000-JJJ,K) + YOUT(JJ,K)=YOUT(5000-JJJ,K) + ENDDO + JJ=JJ+1 + XOUT(JJ,K)=XOUT(1,K) + YOUT(JJ,K)=YOUT(1,K) + MSN(J)=0 + GO TO 200 + ENDIF + ENDDO + GO TO 300 + 200 CONTINUE + NOUTLST(K)=JJ + IF(JJ .GT. 0) THEN + IF(IOUTSW .EQ. 1) THEN + NDIM=2 + NZERO=0 + NONE=1 + WRITE(IOUTOUT,*)NOUTLST(K)-1,NDIM,NZERO,NZERO + DO L=1,NOUTLST(K)-1 + WRITE(IOUTOUT,*) L,XUSR(IOUTLST(K,L)),YUSR(IOUTLST(K,L)) + ENDDO + WRITE(IOUTOUT,*) NOUTLST(K)-1,NZERO + DO I=1,NOUTLST(K)-2 + WRITE(IOUTOUT,*) I,I,I+1 + ENDDO + WRITE(IOUTOUT,*) NOUTLST(K)-1,NOUTLST(K)-1,NONE + + WRITE(IOUTOUT,*) NZERO + ELSE + DO L=1,NOUTLST(K) + IF(MTYP(K) .EQ. 1) THEN + XOUT(L,K)=XUSR(IOUTLST(K,L)) + YOUT(L,K)=YUSR(IOUTLST(K,L)) + ENDIF + IF(IOUTSW .EQ. 0) THEN + WRITE(IOUTOUT,*) XOUT(L,K),YOUT(L,K) + ENDIF + ENDDO + ENDIF + ENDIF + ENDDO +300 CONTINUE + DO K=1,10 + IF(NOUTLST(K) .EQ. 0) GO TO 400 + IF(MTYP(K) .EQ. 1) THEN + LSTAT=IGrInsidePolygon(XOUT(1,K),YOUT(1,K),NOUTLST(K),XCEN(K),YCEN(K)) + ELSE + LSTAT=.TRUE. + ENDIF + IF(LSTAT) THEN + NOUTLST(K)=ABS(NOUTLST(K)) + ELSE + NOUTLST(K)=-ABS(NOUTLST(K)) + ENDIF + ENDDO + 400 CONTINUE + RETURN + END + + SUBROUTINE GETLINANG(angle,n1,n2) + USE BLK1MOD +! use ATAN2 and angle into range 0 to 2*pi + ANGLE=ATAN2(YUSR(N2)-YUSR(N1),XUSR(N2)-XUSR(N1)) + IF(ANGLE .LT. 0.) ANGLE=ANGLE+6.28318515 + RETURN + END + \ No newline at end of file diff --git a/src/src83e/PARAM.COM b/src/src83e/PARAM.COM new file mode 100644 index 0000000..1374108 --- /dev/null +++ b/src/src83e/PARAM.COM @@ -0,0 +1,65 @@ +!IPK LAST UPDATED JULY 17 1998 +!ipk last update Dec 10 1997 +!IPK LAST UPDATED OCT 18 1996 +! + SAVE +! +! This version is compiled for: LARGE +! MAXE = maximum number of elements = 200000 +! MAXP = maximum number of nodes =400000 +! MAXPL = maximum number of map data points =1800000 +! MAXLIN = maximum number of map lines = 3000 +! MAXLN = maximum number of reordering lines = 20 +! MAELN = maximum number of elements in a reodering list = 300 +! MAXPGEN= maximum number elements in a genreated block = 2000 +! MAXGRD = maximum number of grid points = 3000 +! +! +! +! PARAMETER (MAXE= 200000,MAXP=400000,MAXLIN=6000,MAXECON=60) +! PARAMETER (MAXLN=20,MAELN=300,MAXPGEN=2000,MAXGRD=3000,MAXSTO=2) +! PARAMETER (MAXE8=8*MAXE,MAXP2=2*MAXP) + +! This version is compiled for: MEDIUM +! MAXE = maximum number of elements =130000 +! MAXP = maximum number of nodes =200000 +! MAXPL = maximum number of map data points =1500000 +! MAXLIN = maximum number of map lines = 3000 +! MAXLN = maximum number of reordering lines = 20 +! MAELN = maximum number of elements in a reodering list = 300 +! MAXPGEN= maximum number elements in a genreated block = 2000 +! MAXGRD = maximum number of grid points = 1000 +! MAXSTO = maximum storage locations = 2 +! +! + PARAMETER (MAXPGEN=20000,MAXGRD=1000) +! PARAMETER (MAXE8=8*MAXE,MAXP2=2*MAXP) + PARAMETER (MCRS=1000,MPTS=75) + +! This version is compiled for: STANDARD +! MAXE = maximum number of elements = 40000 +! MAXP = maximum number of nodes = 50000 +! MAXPL = maximum number of map data points = 200000 +! MAXLIN = maximum number of map lines = 3000 +! MAXLN = maximum number of reordering lines = 20 +! MAELN = maximum number of elements in a reodering list = 300 +! MAXPGEN= maximum number elements in a genreated block = 2000 +! MAXGRD = maximum number of grid points = 300 +! MAXSTO = maximum storage locations = 2 +! +! +! PARAMETER (MAXE= 40000,MAXP=50000,MAXLIN=6000,MAXECON=60) +! PARAMETER (MAXLN=20,MAELN=300,MAXPGEN=2000,MAXGRD=3000,MAXSTO=2) +! PARAMETER (MCRS=600,MPTS=50) +! PARAMETER (MAXE8=8*MAXE,MAXP2=2*MAXP) + +! +! CORD is the screen scale variable +! XUSR is the map scale variable +! To get to CORD from XUSR use +! CORD(N,1)=(XUSR(N)+XS)/TXSCAL +! To get to XUSR from CORD use +! XUSR(N2) = CORD(N2,1)*TXSCAL - XS +! XS,YS and TXSCAL are kept in TXFRM.COM +! REAL*8 XS,YS,TXSCAL +! COMMON /TXFRM/ XS, YS, TXSCAL \ No newline at end of file diff --git a/src/src83e/PLOTORDS.F90 b/src/src83e/PLOTORDS.F90 new file mode 100644 index 0000000..049dbd0 --- /dev/null +++ b/src/src83e/PLOTORDS.F90 @@ -0,0 +1,41 @@ + SUBROUTINE PLOTORDS + + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + NLSTP=NLST+1 + call getxc + DO N=1,NLSTP + FPN=N + DO M=1,NE + +! Get element in list + + IF(N .LT. NLSTP) THEN + J=ILIST(N,M) + ELSE + J=ilisttmp(M) + ENDIF +! IF(IMAT(J) .EQ. 0) THEN +! ENDIF + + IF(J .GT. 0) THEN + IF(XC(J) .GT. 0. .AND. XC(J) .LT. HSIZE) THEN + IF(YC(J) .GT. 0. .AND. YC(J) .LT. 7.5) THEN + xxc=xc(j) + yyc=yc(j) + CALL NUMBR(XXC,YYC,0.15,FPN,0.0,-1) + ENDIF + ENDIF + ELSE + GO TO 300 + ENDIF + + ENDDO + 300 CONTINUE + ENDDO + + RETURN + END \ No newline at end of file diff --git a/src/src83e/PLOTR.F90 b/src/src83e/PLOTR.F90 new file mode 100644 index 0000000..52c5fa5 --- /dev/null +++ b/src/src83e/PLOTR.F90 @@ -0,0 +1,204 @@ +!ipk last change July 14 updating of cycw changes in 97 +! Last change: IPK 12 Jan 98 1:55 pm +!ipk last update Nov 18 1997 +!ipk last updated Oct 17 1996 +!ipk last updated Oct 14 1996 + + SUBROUTINE RDRW(IS) + +! Determine how to draw grid according to switch setting + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 ANS,ANSW(10) + character*38 mesg + +! Draw box around selections + + DATA ANSW/'m','o','e','n','t','y','l','d','b','r'/ +! m 1 o 2 e 5 n 3 t 4 u 7 g 8 d 6 b 9 + NHTP=5 + NMESS=0 + NBRR=0 + 100 CONTINUE + CALL HEDR + +! Get answer + + call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN + if(ibox .le. 0) go to 100 + IF(ANS .EQ. 'c') THEN + ANS=ANSW(IBOX) + ENDIF + IF(ANS .EQ. 'm') THEN +!ipk oct96 + if(ipsw(1) .eq. 0) then + call getmpcl + NHTP=5 + endif +!ipk oc96 end addition + IPSW(1)=MOD(IPSW(1)+1,2) + GO TO 100 + ELSEIF(ANS .EQ. 'o') THEN + IPSW(2)=MOD(IPSW(2)+1,2) + GO TO 100 + ELSEIF(ANS .EQ. 'n') THEN + IPSW(3)=MOD(IPSW(3)+1,2) + IF(IPSW(3) .EQ. 1) IPSW(9)=0 + IF(IPSW(3) .EQ. 1) IPSW(14)=0 + GO TO 100 + ELSEIF(ANS .EQ. 't') THEN + IPSW(4)=MOD(IPSW(4)+1,2) + GO TO 100 + ELSEIF(ANS .EQ. 'e') THEN + IPSW(5)=MOD(IPSW(5)+1,2) + if(ipsw(5) .eq. 1) ipsw(7)=0 + GO TO 100 + ELSEIF(ANS .EQ. 'd') THEN + IPSW(6)=MOD(IPSW(6)+1,2) + if(ipsw(6) .eq. 1) then +!ipk apr02 + call getmdis(nmapf,nsigf,icolsw,rad,colint) +! write(mesg,*) 'Enter output frequency for map display' +! call symbl (1.1,7.3,0.25,mesg,0.0,38) +! call getint(nmapf) + endif + GO TO 100 + ELSEIF(ANS .EQ. 'y') THEN + IPSW(7)=MOD(IPSW(7)+1,2) + if(ipsw(7) .eq. 1) ipsw(5)=0 + GO TO 100 +!ipk feb01 drop this option in favour of ccline ELSEIF(ANS .EQ. 'g') THEN +!ipk feb01 IPSW(8)=MOD(IPSW(8)+1,2) +!ipk feb01 GO TO 100 + ELSEIF(ANS .EQ. 'l') THEN + IPSW(10)=MOD(IPSW(10)+1,2) + GO TO 100 + ELSEIF(ANS .EQ. 'b') THEN + IPSW(9)=MOD(IPSW(9)+1,2) + IF(IPSW(9) .EQ. 1) IPSW(3)=0 + IF(IPSW(9) .EQ. 1) IPSW(14)=0 + GO TO 100 + ELSEIF(ANS .EQ. 'r') THEN + +! CALL PLOTS(IS) +!ipk nov97 add (0) + CALL PLOTOT(1) + RETURN + ENDIF + GO TO 100 + END + + SUBROUTINE GETMPCL + +! Determine how to draw grid according to switch setting + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 ANS,ANSW(10) + +! Draw box around selections + + DATA ANSW/'e','o','t','h','f','i','s','v','g','q'/ +! m 1 o 2 e 5 n 3 t 4 u 7 g 8 d 6 b 9 + NHTP=12 + 100 CONTINUE + CALL HEDR + +! Get answer + + call xyloc(XPT,YPT,ANS,IBOX) + IF(ANS .NE. 'c') then + DO K=1,10 + IF(ANS .EQ. ANSW(K)) THEN + IBOX=K + GO TO 102 + ENDIF + ENDDO + 102 CONTINUE + ENDIF + IF(IBOX .EQ. 10) GO TO 150 + ICOLON(IBOX)=MOD(ICOLON(IBOX)+1,2) + CALL HEDR + GO TO 100 + 150 NHTP=5 + RETURN + END + + SUBROUTINE GDIST + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*1 ANS,ANSW(10) + + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + DATA ANSW/6*' ','n','z','r','q'/ +! + NHTPSV=NHTP + NMESSV=NMESS + NBRRSV=NBRR + 100 CONTINUE + NHTP=0 + NMESS=41 + NBRR=4 + CALL CLRBOX + CALL HEDR + call xyloc(XPT1,YPT1,ANS,IBOX) + call xyloc(XPT2,YPT2,ANS,IBOX) + DIST=SQRT((YPT2-YPT1)**2+(XPT2-XPT1)**2)*TXSCAL + CALL CLRBOX + NMESS=0 + NBRR=4 + CALL HEDR + CALL NUMBR(0.5,7.55,0.20,DIST,0.0,2) + CALL XYLOC(XPT1,YPT1,ANS,IBOX) + IF(ANS .NE. 'c') then + DO K=1,10 + IF(ANS .EQ. ANSW(K)) THEN + IBOX=K + GO TO 102 + ENDIF + ENDDO + 102 CONTINUE + ENDIF + IF(IBOX .EQ. 7) GO TO 100 + NHTP=NHTPSV + NMESS=NMESSV + NBRR=NBRRSV + CALL CLRBOX + CALL HEDR + + RETURN + END + + + SUBROUTINE CHEXIT + USE WINTERACTER + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: ITYPE + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + + CALL WMessagePeek(ITYPE, MESSAGE) + + SELECT CASE (ITYPE) + CASE (-1) + RETURN + CASE (KeyDown) ! Key pressed + IPSW(1)=0 + IPSW(2)=1 + IPSW(3)=0 + IPSW(4)=0 + IPSW(5)=0 + IPSW(6)=0 + IPSW(7)=0 + IPSW(8)=0 + IPSW(9)=0 + IPSW(12)=0 + RETURN + ENDSELECT + RETURN + END diff --git a/src/src83e/PLOTR1.F90 b/src/src83e/PLOTR1.F90 new file mode 100644 index 0000000..7911c95 --- /dev/null +++ b/src/src83e/PLOTR1.F90 @@ -0,0 +1,1647 @@ +!ipk last update March 6 2000 fix IMAT display bug +!ipk last update Feb 22 1999 add element type option +!ipk last update Jan 21 1999 add plotting of storage widths +!ipk lsat update oct 23 1998 change location of label in pgrid +! +!**************************************************************** +! +!ipk nov97 change call + SUBROUTINE PLOTOT(imz) +! +! Display grid according to switch setting +! + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' + include 'TXFRM.COM' + DIMENSION XLIN(350),YLIN(350) + CHARACTER*1 IFLAG + CHARACTER*80 LIND + !ycw mar97 add for cross section + REAL XPL(5),YPL(5) + DATA IFIRST/0/ + IF(IFIRST .EQ. 0) THEN + NTTRAC=0 + IFIRST=1 + ENDIF + HT=0.2 +! CALL CHEXIT +! + if(imz .ne. 2) CALL CLSCRN +! +!ipk oct97 output to backup file +! +!ipk test for write to backup + if(imz .eq. 1) then + rewind ibak + call wrtout(0) + endif +! +!ycw mar97 add for cross section + if(LCROSS) then +!! call plotcs + return + endif +!ycw +! +! Rescale coordinates for plotting +! + CALL SCLMAP +!rrr + IF (IPSW(8) .EQ. 1) CALL PGRID +! + CALL SCLCRD +!ycw mar97 add for cross section + if(ICRS.ne.0) then + do i=1,2 + XPCS(i)=(XPCS(i)-XMIN)/PSCALE + YPCS(i)=(YPCS(i)-YMIN)/PSCALE + enddo + do i=1,NCSNOD + XCND(i)=(XCND(i)-XMIN)/PSCALE + YCND(i)=(YCND(i)-YMIN)/PSCALE + enddo + endif +!ycw + PSCALE = 1. + XMIN = 0. + YMIN = 0. +! if(np .gt. 100000) call backc(1) + +! if(ipsw(4) .eq. 1) then +! do j=1,ne +! if(ieskp(j) .eq. 0 .and. imz .ne. 2) call fillemC(j,1) +! enddo +! endif +! write(90,*) 'going to drawbk',nbkfl,iswbkfl(1) +! IF(NBKFL .GT. 0) THEN +! DO I=1,NBKFL +! IF(ISWBKFL(I) .EQ. 1) CALL DRAWBK(I,IMZ) +! IF(ISWBKFL(I) .EQ. 2) CALL DRAWBKBM(I,IMZ) +! ENDDO +! ENDIF + IF(IDDSW .EQ. -1) THEN + IF(NP .GT. 100000) THEN + IDDSW=0 + ELSE + IDDSW=1 + ENDIF + ENDIF + if(IDDSW .EQ. 0) call backc(1) + + if(ipsw(4) .eq. 1) then + do j=1,ne + if(ieskp(j) .eq. 0 .and. imz .ne. 2) call fillemC(j,1) + enddo + endif + + IF(NBKFL .GT. 0) THEN + DO I=1,NBKFL + IF(ISWBKFL(I) .EQ. 1) CALL DRAWBK(I,IMZ) + IF(ISWBKFL(I) .EQ. 2) CALL DRAWBKBM(I,IMZ) + ENDDO + ENDIF +! write(90,*) 'finished drawbk' +! +! Plot map data +! + IF(IMP .NE. 0) THEN + IF(IPSW(1) .EQ. 1) THEN + CALL PLTMAP + ENDIF + ENDIF +! +! If IPSW(1) = 1 plot map or plot outline if no map +! + IF(IMP .EQ. 0) THEN + IF(IPSW(1) .EQ. 1) IPSW(2)=1 +!ipk sep94 allow plotting of outline after map +! ELSE +! IF(IPSW(1) .EQ. 1) GO TO 10 + ENDIF +! +! Plot outline of grid only +! + IF(IPSW(2) .EQ. 1) THEN + CALL OUTLN +! GO TO 250 + ENDIF +! +! Plot nodes when IPSW(3) .EQ. 1 +! + 10 CONTINUE + IF(IPSW(3) .EQ. 1 .OR. IPSW(9) .EQ. 1 .OR. IPSW(14) .EQ. 1) THEN + IF(NP .GT. 0) THEN + IF(IPSW(3) .EQ. 1) ITP=0 + IF(IPSW(14) .EQ. 1) ITP=2 + IF(IPSW(9) .EQ. 1) then + ITP=-1 + wdmin=1.e10 + wdmax=-1.e10 + do j=1,np + IF(INSKP(J) .EQ. 1) cycle + IF(CORD(J,1) .GT. 0. .AND. CORD(J,1) .LT. HSIZE) THEN + IF(CORD(J,2) .GT. 0. .AND. CORD(J,2) .LT. 7.5) THEN + wdmin=min(wdmin,wd(j)) + wdmax=max(wdmax,wd(j)) + else + cycle + endif + else + cycle + endif + enddo + if(abs(wdmin) .gt. abs(wdmax)) then + temp=log10(abs(wdmin)) + elseif(wdmin .eq. 0) then + temp=2.5 + else + temp=log10(wdmax) + endif + if(temp .gt. 2.) then + itp=-3 + elseif(temp .gt. 1.) then + itp=-4 + else + itp=-5 + endif + endif + DO 15 J=1,NP +! IF(MOD(J,10) .EQ. 0) THEN +! CALL CHINT(IFLAG) +! IF(IFLAG .EQ. 'i') GO TO 250 +! ENDIF + IF(INSKP(J) .EQ. 1) GO TO 15 + IF(CORD(J,1) .GT. 0. .AND. CORD(J,1) .LT. HSIZE) THEN + IF(CORD(J,2) .GT. 0. .AND. CORD(J,2) .LT. 7.5) THEN + CALL PLTNOD(J,ITP) + GO TO 15 + ENDIF + ENDIF + INSKP(J)=1 + 15 CONTINUE + ENDIF + ENDIF +! +! Plot data points +! + IF(IPSW(6) .EQ. 1) THEN + FCT=10**NSIGF + DO 80 J=1,MAXPTS,nmapf + IF(VAL(J) .GT. -9000.) THEN + X=CMAP(J,1) + Y=CMAP(J,2) + IF(X .GT. 0. .AND. X .LT. HSIZE) THEN + IF(Y .GT. 0. .AND. Y .LT. 7.5) THEN + CALL PLOTT(X,Y,3) + if(icolsw .eq. 0) then + CALL PLOTT(X,Y,2) + + CALL Rblack +! ipk mar01 +! ipk jun04 CALL NUMBR(X,Y,0.15,VAL(J)*FCT,0.0,-1) + if(nsigf .lt.1) then + nsigff=1 + else + nsigff=nsigf + endif + call numbr(x,y,0.12,val(j),0.0,nsigff) + CALL RBlue + else + if(colint .eq. 0.) colint=1. + if(val(j) .ge. 0.) then + ncoln=val(j)/colint + else + ncoln=-val(j)/colint + endif + ncoln=mod(ncoln,13)+2 + call change_color(ncoln) + raddisp=rad/txscal + if(raddisp .lt. 0.01) raddisp=0.01 + call circle(x,y,raddisp) + endif + ENDIF + ENDIF + ENDIF + 80 CONTINUE + Call RBlue +! GO TO 250 + ENDIF +! +! Plot existing elements +! +!ipk add element type option + IF(IPSW(5) .EQ. 1 .OR. IPSW(4) .EQ. 1 .or. ipsw(7) .eq. 1) THEN +! CALL PLOTT(0.,7.0,3) +! CALL PLOTT(10.,7.0,2) +!IPK JAN98 + IERC=imz + if(ne .gt. 0) then + DO 20 J=1,NE + XC(J)=VOID + YC(J)=VOID +! IF(MOD(J,10) .EQ. 0) THEN +! CALL CHINT(IFLAG) +! IF(IFLAG .EQ. 'i') GO TO 250 +! ENDIF + IF(IESKP(J) .EQ. 0) THEN +!IPK JAN98 ADD IERC + IF (IMAT(J) .NE. 0) CALL PLTELM(J,IERC) + ENDIF +20 CONTINUE + IF(IERC .GT. 0) THEN +! call clscrn() +! WRITE(LIND,*) ' Zero node corner nodes' +! call symbl & +! & (1.1,5.5,0.25,LIND,0.0,80) +! WRITE(LIND,*) ' See MESSAGES.OUT file for details' +! call symbl & +! & (1.1,5.2,0.25,LIND,0.0,80) +! WRITE(LIND,*) ' Press enter to terminate' +! call symbl & +! & (1.1,4.9,0.25,LIND,0.0,80) +! ndig=1 +! CALL GTCHARX(IFLAG,NDIG,5.0,5.5) +! CALL QUIT_PGM() +! stop + CALL WMessageBox(0,0,0,'Error in element connnection'//& + CHAR(13)//'Zero corner node found'//& + CHAR(13)//'See Mesgen.out for details',& + 'ERROR IN ELEMENT CONNECTIONS') + + ENDIF + endif + ENDIF + if(IDDSW .EQ. 0) then + call backc(2) + endif +!ycw mar97 add for cross section + if(ICRS.ne.0) then + call plott(XPCS(1),YPCS(1),3) + call RRED + call plott(XPCS(2),YPCS(2),2) + do i=1,NCSNOD + xpl(1)=XCND(i)-0.04 + ypl(1)=YCND(i)-0.04 + xpl(2)=XCND(i)+0.04 + ypl(2)=ypl(1) + xpl(3)=xpl(2) + ypl(3)=YCND(i)+0.04 + xpl(4)=xpl(1) + ypl(4)=ypl(3) + xpl(5)=xpl(1) + ypl(5)=ypl(1) + call polyfl(xpl,ypl,5,1) + enddo + call RBLACK + endif +!ycw +250 continue + IF(NTRACT .GT. 0) THEN + DO KK=1,NTRACT + XLIN(KK)=CORD(ITRAC(KK),1) + YLIN(KK)=CORD(ITRAC(KK),2) + ENDDO + CALL RRED +!ipk jan01 + CALL THICKL + CALL DASHLN(XLIN,YLIN,NTRAC,0) +!ipk jan01 + CALL RBLACK + CALL THINL + call pltnod(ITRAC(1),0) + call pltnod(ITRAC(NTRACT),0) + ENDIF + + IF (IPSW(8) .EQ. 1) CALL PGRID + +!IPK JAN01 + IF(IPSW(10) .EQ. 1) CALL PLOTCC + +!ipk oct02 + IF(IPSW(11) .EQ. 1) CALL PLOTCSTR + +!ipk oct03 + IF(IPSW(12) .EQ. 1) CALL PLOTCRSS(0) + + if(ipsw(13) .eq. 1) call plotcrss(1) + + IF(INREORD .EQ. 1) THEN + CALL PLOTORDS + ENDIF + + IF(IMZ .NE. 1) THEN + CALL DOPLOT(IMZ) + ENDIF + CALL CHEXIT + RETURN + END +! +!**************************************************************** +! + SUBROUTINE PLTNOD(J,ICOL) +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +! Plot nodes on screen +! + HT = .20 + IF (CORD(J,1) .LT. VDX) RETURN + X = CORD(J,1) + Y = CORD(J,2) + CALL PLOTT(X,Y,3) + CALL PLOTT(X,Y,2) + IF(ICOL .EQ. 0 .OR. ICOL .EQ. 1) THEN + Y = Y+0.07 + FPN = J + ELSEIF(ICOL .EQ. 2) THEN + Y = Y+0.07 + FPN = LAY(J) + IF(LAY(J) .EQ. -9999) GO TO 500 + ELSE +!ipk jul02 Y = Y-0.11 + Y = Y+0.10 +!ipk jul02 FPN=WD(J)*10. + fpn=wd(j) + if(icrin .eq. 23) fpn=wd1(j) + ENDIF + IF(IJUN(J) .NE. 0) THEN + Y=Y-0.17*FLOAT(IJUN(J)-2) + ENDIF + IF(ICOL .LT. 1) THEN + CALL RRed + if(lock(j) .eq. 1) call rgreen + ELSE + CALL RBlack + ENDIF + IF(X .GT. 0. .AND. X .LT. HSIZE) THEN + IF(Y .GT. 0. .AND. Y .LT. 7.5) THEN +! ipk mar01 +! ipk jul02 + if(icol .lt. 0) then + call numbr(x,y,0.12,fpn,0.0,-icol) + else + CALL NUMBR(X,Y,0.15,FPN,0.0,-1) + endif + ENDIF + ENDIF + 500 CONTINUE + CALL RBlue +! + END +! +!**************************************************************** +! +!IPK JAN98 SUBROUTINE PLTELM(J) + SUBROUTINE PLTELM(J,IERC) + + USE BLK1MOD +!ipk jan99 + + INCLUDE 'TXFRM.COM' + INCLUDE 'BFILES.I90' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + DIMENSION XLIN(9),YLIN(9),BLVL(9) +! +! INCLUDE 'BLK1.COM' + CHARACTER*1 IJNK + CHARACTER*80 LIND +! +! Plot elements already formed +! + imz=ierc + ierc=0 + call rblue + IF (IMAT(J) .EQ. 0 ) RETURN + NCN = NCORN(J) +! + XXC = 0. + YYC = 0. + NLINP=0 + IESKP(J)=1 + DO 15 K=1,NCN + N = NOP(J,K) + IF (N .EQ. 0 .AND. MOD(K,2) .EQ. 1) THEN + CALL SETD(23) +! CALL CLSCRN() +!IPK JAN98 WRITE(*,*) ' Zero node corner node' +!IPK JAN98 WRITE(*,*) ' ELEM, NOP(ELEM,K) ' +!IPK JAN98 WRITE(*,'(I5,I10,7I5)') J,(NOP(J,KK),KK=1,NCN) + WRITE(90,*) ' ELEM, NOP(ELEM,K) ' + WRITE(90,'(I5,I10,7I5)') J,(NOP(J,KK),KK=1,NCN) +!IPK JAN98 WRITE(*,*) 'Press enter to exit' +!IPK JAN98 READ(*,'(A)') IJNK +!IPK JAN98 CALL Quit_Pgm +!IPK JAN98 STOP + IERC=IERC+1 + do kk=1,8 + nop(j,kk)=0 + enddo + imat(j)=0 + RETURN + ENDIF +! +! IF (N .EQ. 0 .OR. CORD(N,1) .LT. VDX) GOTO 15 + IF (N .EQ. 0) GO TO 15 + IF(MOD(K,2) .EQ. 1 .AND. CORD(N,1) .LT. VDX) GOTO 15 + IF(CORD(N,1) .LT. VDX) THEN + IF(K .EQ. NCN) THEN + X=(CORD(NOP(J,K-1),1)+CORD(NOP(J,1),1))/2. + Y=(CORD(NOP(J,K-1),2)+CORD(NOP(J,1),1))/2. + ELSE + X=(CORD(NOP(J,K-1),1)+CORD(NOP(J,K+1),1))/2. + Y=(CORD(NOP(J,K-1),2)+CORD(NOP(J,K+1),1))/2. + ENDIF + ELSE +! + X = CORD(N,1) + Y = CORD(N,2) + ENDIF + IF(X .GT. 0. .AND. X .LT. HSIZE) THEN + IF(Y .GT. 0. .AND. Y .LT. 7.5) THEN + IESKP(J)=0 + GO TO 16 + ENDIF + ENDIF + 15 END DO + 16 CONTINUE +! + IF(IESKP(J) .EQ. 1) GO TO 26 + + if(ipsw(7) .eq. 1 .and. iqsw(2) .GT. 0) then + IF(IQSW(2) .EQ. 1) ittmp=imat(j) + IF(IQSW(2) .EQ. 2) ittmp=igrpser(j) + IF(ITTMP .GT. 900 ) THEN + ICCT=MOD(ITTMP+1,10)+4 + ELSE + icct=MOD(ittmp,10)+4 + ENDIF + if(imz .ne. 2) then + call fillemc(j,icct) + endif + endif + + DO 25 K=1,NCN + N = NOP(J,K) +! + IF (N .EQ. 0) go to 25 + IF (CORD(N,1) .LT. VDX) GOTO 25 +! + X = CORD(N,1) + Y = CORD(N,2) +! + IF (NCN .NE. 5 .OR. K .LT. 5) THEN + IF (MOD(K,2) .EQ. 1) THEN + XXC = XXC + X + YYC = YYC + Y + ENDIF + ENDIF + NLINP=NLINP+1 +! + XLIN(NLINP)=X + YLIN(NLINP)=Y + BLVL(NLINP)=WD(N) + IF (K .EQ. 1) THEN + X1 = X + Y1 = Y + ENDIF + 25 END DO + IF(NCN .GT. 5) THEN + NLINP=NLINP+1 + XLIN(NLINP)=X1 + YLIN(NLINP)=Y1 + BLVL(NLINP)=WD(NOP(J,1)) + ENDIF + if(i3dview .eq. 1) then + do k=1,nlinp + YLIN(K)=YLIN(K)+(BLVL(K)-VRTORIG)*COS(VANG/57.29578)/VRTSCAL + enddo + endif +!ipkoct93 + if(ipsw(4) .eq. 1) then + if(ncn .eq. 8 .or. imat(j) .lt. 901) then + CALL DASHLN(XLIN,YLIN,NLINP,0) + endif + endif +! IF(IMAT(J) .LT. 901 .AND. IPSW(4) .EQ. 1) +! + CALL DASHLN(XLIN,YLIN,NLINP,0) +!ipkoct93 +! +! Plot elem number at center if IPSW(5) = 1 +! + CALL RCyan + IF (NCN .EQ. 3 .OR. NCN .EQ. 5) NCN = 4 + XC(J) = 2.*XXC/NCN + YC(J) = 2.*YYC/NCN +! IF(IMAT(J) .GT. 900 ) THEN + IF(IMAT(J) .GT. 900 .and. ncorn(j) .ne. 8) THEN + CALL RBlue + RETURN + ENDIF +!ipk feb99 add element type option + IF(IPSW(5) .EQ. 1 .or. ipsw(7) .eq. 1) THEN + HT = .20 + if(ipsw(5) .eq. 1) then + FPN = J +!ipk mar00 fix imat display bug + elseif((iqsw(1) .gt. 0) .or. (iqsw(1) .eq. 0 .and. iqsw(2) .eq. 0) ) then + CALL RBLACK + if(iqsw(1) .eq. 1) fpn=imat(j) + if(iqsw(1) .eq. 2) fpn=igrpser(j) +! elseif(iqsw(2) .eq. 1) then +! CALL RBLACK +! fpn=imat(j) + else + go to 30 + endif + IF(XC(J) .GT. 0. .AND. XC(J) .LT. HSIZE) THEN + IF(YC(J) .GT. 0. .AND. YC(J) .LT. 7.5) THEN +!ipkoct93 +! IF(IMAT(J) .LT. 901) CALL NUMBR(XC(J),YC(J),HT,FPN,0.0,-1) +! ipk mar01 +!ipk jun02 + xxc=xc(j) + yyc=yc(j) + CALL NUMBR(XXC,YYC,0.15,FPN,0.0,-1) + ENDIF +! elseif(iqsw(2) .eq. 1) then +! CALL RBLACK +! fpn=imat(j) + endif + 30 continue + ENDIF + +!ipk jan99 add plot of 1-d element widths + if(ncorn(j) .eq. 3 .or. ncorn(j) .eq. 5) then + ncn=3 + n1=nop(j,1) + n2=nop(j,3) +! +!...... first for widths + + IF(IPW1 .EQ. 1) THEN + wd11=width(n1)/txscal + wd2=width(n2)/txscal + ELSE + IF(NRIVCR1(N1) .EQ. 0 .AND. NRIVCR2(N1) .EQ. 0) RETURN + IF(NRIVCR1(N2) .EQ. 0 .AND. NRIVCR2(N2) .EQ. 0) RETURN + BT1= & + CRSDAT(NRIVCR1(N1),1,1)*WTRIVCR1(N1)+ & + CRSDAT(NRIVCR2(N1),1,1)*WTRIVCR2(N1) + BT2= & + CRSDAT(NRIVCR1(N2),1,1)*WTRIVCR1(N2)+ & + CRSDAT(NRIVCR2(N2),1,1)*WTRIVCR2(N2) + H1=WIDEL-BT1 + H2=WIDEL-BT2 + CALL INTERPWLV(N1,H1,AR1,WR1,DWR1) + CALL INTERPWLV(N2,H2,AR2,WR2,DWR2) + WIDTH(N1)=WR1 + WIDTH(N2)=WR2 + IF(IPW1 .EQ. 2) THEN + WD11=WR1*WIDSCL/TXSCAL + WD2=WR2*WIDSCL/TXSCAL + ELSE + WD11=AR1*WIDSCL/TXSCAL + WD2=AR2*WIDSCL/TXSCAL + ENDIF + + ENDIF + if(wd11 .gt. 0. .and. wd2 .gt. 0.) then + x1= cord(n1,1) + x2= cord(n2,1) + y1= cord(n1,2) + y2= cord(n2,2) + eldir=atan2(y2-y1,x2-x1) + elnorm=eldir-1.5708 + xlin(1)=x1+cos(elnorm)*wd11/2. + xlin(5)=xlin(1) + xlin(4)=x1-cos(elnorm)*wd11/2. + xlin(2)=x2+cos(elnorm)*wd2/2. + xlin(3)=x2-cos(elnorm)*wd2/2. + ylin(1)=y1+sin(elnorm)*wd11/2. + ylin(5)=ylin(1) + ylin(4)=y1-sin(elnorm)*wd11/2. + ylin(2)=y2+sin(elnorm)*wd2/2. + ylin(3)=y2-sin(elnorm)*wd2/2. + call dashln(xlin,ylin,5,0) + endif + +!...... then for storage widths + + wd11=(wids(n1)+width(n1))/txscal + wd2=(wids(n2)+width(n2))/txscal + if(wids(n1) .gt. 0. .and. wids(n2) .gt. 0.) then + x1= cord(n1,1) + x2= cord(n2,1) + y1= cord(n1,2) + y2= cord(n2,2) + eldir=atan2(y2-y1,x2-x1) + elnorm=eldir-1.5708 + xlin(1)=x1+cos(elnorm)*wd11/2. + xlin(5)=xlin(1) + xlin(4)=x1-cos(elnorm)*wd11/2. + xlin(2)=x2+cos(elnorm)*wd2/2. + xlin(3)=x2-cos(elnorm)*wd2/2. + ylin(1)=y1+sin(elnorm)*wd11/2. + ylin(5)=ylin(1) + ylin(4)=y1-sin(elnorm)*wd11/2. + ylin(2)=y2+sin(elnorm)*wd2/2. + ylin(3)=y2-sin(elnorm)*wd2/2. + call dashln(xlin,ylin,5,1) + endif + endif + + + CALL RBlue + 26 CONTINUE +! + RETURN + END +! +!**************************************************************** +! + SUBROUTINE PLTMAP +! + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +! Plot map of input data +! +! Determine how long each line is +! + JS=1 +! + K=0 + CALL RCyan + DO 20 J=1,MAXPTS + MLEN=J-JS +! write(90,*) 'j,mlen',j,mlen,cmap(j,1),k+1,lintyp(k+1),vdx +! write(123,*) 'j,mlen',j,mlen,cmap(j,1),k+1,lintyp(k+1),vdx + IF(XMAP(J) .LE. VDX .or. j .eq. maxpts) THEN + if(j .eq. maxpts .and. xmap(j) .gt. vdx) mlen=mlen+1 +! +! Now draw it. +! + K=K+1 + IF(MLEN .GT. 1) THEN + LTP=LINTYP(K) +!ipk oct96 + if(icolon(ltp+1) .eq. 1) then + + IF(LTP .NE. 2) THEN +!ipk oct96 IF(LTP .LT. 2) THEN + CALL RRed + +! write(90,*) 'at nwpen ltp',ltp + IF(LTP .GT. 0) CALL NWPEN(2*LTP+1) + IF(LTP .GT. 2) LTP=0 + CALL DBDASHLN(cmap(js,1),cmap(js,2),MLEN,LTP) + ENDIF + ENDIF + ENDIF + IF(MLEN .EQ. 0 .AND. LINTYP(K) .EQ. -999) GO TO 30 + JS=J+1 + ENDIF + 20 CONTINUE + 30 CONTINUE + CALL RBlue + RETURN +! + END +! +!*********************************************************************** +! + SUBROUTINE SCLMAP +! +! Scale map coordinates for plotting +! Keep track and update information for mapping +! screen coordinates back to user coordinates +! + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! +!ipk may94 moved to blk1.com DATA XREF,YREF / 0.0, 0.0 / +! + DO 10 J=1,MAXPTS + IF (CMAP(J,1) .LT. VDX) GOTO 10 + CMAP(J,1) = (CMAP(J,1)-XMIN)/PSCALE + CMAP(J,2) = (CMAP(J,2)-YMIN)/PSCALE + 10 END DO +! + XREF = (XREF-XMIN)/PSCALE + YREF = (YREF-YMIN)/PSCALE + IF(IASPCT .EQ. 1) THEN + VRTSCAL=VRTSCAL*PSCALE + ENDIF + TXSCAL = TXSCAL*PSCALE + XS = XREF*TXSCAL + YS = YREF*TXSCAL + write(90,*) ' The line that follows gives the values used for a te& + &mporary origin and scale' + write(90,6000) xs,ys,txscal + 6000 format(3f15.4) +! + RETURN + END +! +!*********************************************************************** +! + SUBROUTINE SCLCRD +! +! Scale coordinates for plotting +! Keep track and update information for mapping +! screen coordinates back to user coordinates +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + REAL*8 ANGPT,ANGNEW,DRAD,DVANG,DVANGOLD + + DATA PI/3.14159265/,ITIME/0/,DRAD/57.29577957855/ + IF(ITIME .EQ. 0) THEN + VANGOLD=90. + VANG=90. + HANG=0. + HANGOLD=0. +! DRAD=180./PI + ITIME=1 + ENDIF + DVANG=VANG + DVANGOLD=VANGOLD +! + +! ROTATE BACK IF NEEDED + + + IF((HANGOLD .EQ. HANG) .AND. (VANGOLD .EQ. VANG)) GO TO 5 + IF(HANGOLD .NE. 0. .OR. VANGOLD .NE. 90.) THEN + IF(NP .GT. 0) THEN + DO J=1,NP + IF (CORD(J,1) .GE. VDX) THEN + + IF(VANGOLD .LT. 90.) THEN + CORD(J,2)=4.+(CORD(J,2)-4.)/DSIN(DVANGOLD/DRAD) + ENDIF + + ANGPT=DATAN2D(CORD(J,2)-4,CORD(J,1)-5.) + VLEN=SQRT((CORD(J,1)-5.)**2+(CORD(J,2)-4.)**2) + ANGNEW=ANGPT+HANGOLD +! IF(J .EQ. 1) THEN +! WRITE(90,*) 'ROTBACK',ANGPT,VLEN,ANGNEW,CORD(J,1),CORD(J,2) +! ENDIF + CORD(J,1)=5.+VLEN*DCOS(ANGNEW/DRAD) + CORD(J,2)=4.+VLEN*DSIN(ANGNEW/DRAD) +! IF(J .EQ. 1) THEN +! WRITE(90,*) CORD(J,1),CORD(J,2) +! ENDIF + ENDIF + ENDDO + ENDIF + ENDIF + + 5 CONTINUE + + IF(NP .GT. 0) THEN + DO 10 J=1,NP + IF (CORD(J,1) .LT. VDX) GOTO 10 + CORD(J,1) = (CORD(J,1)-XMIN)/PSCALE + CORD(J,2) = (CORD(J,2)-YMIN)/PSCALE + 10 CONTINUE + ENDIF +! +! ROTATE IF NEEDED + + IF((HANGOLD .EQ. HANG) .AND. (VANGOLD .EQ. VANG)) GO TO 15 + + IF(HANG .NE. 0 .OR. VANG .LT. 90.) THEN + IF(NP .GT. 0) THEN + DO J=1,NP + IF (CORD(J,1) .GE. VDX) THEN + ANGPT=DATAN2D(CORD(J,2)-4,CORD(J,1)-5.) + VLEN=SQRT((CORD(J,1)-5.)**2+(CORD(J,2)-4.)**2) + ANGNEW=ANGPT-HANG +! IF(J .EQ. 1) THEN +! WRITE(90,*) 'ROT',ANGPT,VLEN,ANGNEW,CORD(J,1),CORD(J,2) +! ENDIF + CORD(J,1)=5.+VLEN*DCOS(ANGNEW/DRAD) + CORD(J,2)=4.+VLEN*DSIN(ANGNEW/DRAD) + IF(VANG .LT. 90.) THEN + CORD(J,2)=4.+(CORD(J,2)-4.)*DSIN(DVANG/DRAD) + ENDIF +! IF(J .EQ. 1) THEN +! WRITE(90,*) CORD(J,1),CORD(J,2) +! ENDIF + ENDIF + ENDDO + ENDIF + ENDIF + HANGOLD=HANG + VANGOLD=VANG + + 15 CONTINUE + + RETURN +! + END + SUBROUTINE BOX(HEAD,NSIZ) +! +! Routine to draw NSIZ header boxes at top of page with the HEAD label +! + CHARACTER*8 HEAD(*) + XSY=0. + XLMT=FLOAT(NSIZ) + DO 200 N=1,NSIZ + CALL SYMBL(XSY,7.65,0.20,HEAD(N),0.0, 8) + XSY=XSY+1.0 + 200 CONTINUE +! +! Draw box around selections +! + CALL PLOTT(0.0,7.0,3) + CALL PLOTT(XLMT,7.0,2) + CALL PLOTT(XLMT,7.495,2) + CALL PLOTT(0.0,7.495,2) + CALL PLOTT(0.0,7.0,2) + XPT=0. + DO 205 I=1,NSIZ + XPT=XPT+1.0 + CALL PLOTT(XPT,7.0,3) + CALL PLOTT(XPT,7.495,2) + 205 CONTINUE + RETURN + END + SUBROUTINE BOXR(NBOX) + SAVE +! +! Routine to draw header box at top right of page with the HEAD label +! + CHARACTER*24 HEAD + CHARACTER*16 HEAD1 + CHARACTER*24 HEAD2 + DIMENSION X(5),Y(5) + DATA HEAD /' (z)oom r(d)raw (q)uit '/ + DATA HEAD1 /' r(d)raw (q)uit '/ + DATA HEAD2 /' (n)ext (z)oom (q)uit '/ +! +! Draw box around selections +! + NBX=IABS(NBOX) + XLEFT=10-NBX + Y(1)=7.5 + Y(2)=7.5 + Y(3)=7.995 + Y(4)=7.995 + Y(5)=7.5 +! CALL PLOTT(XLEFT,7.0,3) +! CALL PLOTT(10.0,7.0,2) +! CALL PLOTT(10.0,7.495,2) +! CALL PLOTT(XLEFT,7.495,2) +! CALL PLOTT(XLEFT,7.0,2) +! IF(NBOX .GT. 1) THEN + DO 200 K=1,NBX + X(1)=XLEFT + X(4)=XLEFT + X(5)=XLEFT + XLEFT=XLEFT+1.0 + X(2)=XLEFT + X(3)=XLEFT + IBLK=4 + CALL POLYFL(X,Y,5,IBLK) + CALL RBLACK + CALL PLOTT(X(1),Y(1),3) + CALL PLOTT(X(2),Y(2),2) + CALL PLOTT(X(3),Y(3),2) + CALL PLOTT(X(4),Y(4),2) + CALL PLOTT(X(1),Y(1),2) +! DO 200 K=1,NBOX-1 +! XLEFT=XLEFT+1. +! CALL PLOTT(XLEFT,7.0,3) +! CALL PLOTT(XLEFT,7.495,2) + 200 END DO +! ENDIF +! +! Establish label +! + IF(NBOX .EQ. 3) THEN + CALL SYMBL(7.0,7.65,0.20,HEAD,0.0,24) + ELSEIF(NBOX .EQ. -3) THEN + CALL SYMBL(7.0,7.65,0.20,HEAD2,0.0,24) + ELSEIF(NBOX .EQ. 2) THEN + CALL SYMBL(8.0,7.65,0.20,HEAD1,0.0,16) + ENDIF + RETURN + END +! +! + SUBROUTINE OUTLN +!- +!......OUTLN DRAWS BOUNDARIES FOR THE SYSTEM +!- + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +! INTEGER*2 MSN +! COMMON /MID/ MSN(MAXP) +! + DATA IFIRST / 1 / +!- +!- +! DATA MAXB/MAXE/ + YMAXX = 7.50 +!- +!-.....PLOT BOUNDARY OUTLINE..... +!- +! 100 DO 110 J=1,MAXB +! NBP(J) = 0 +! 110 CONTINUE +! + IF (IFIRST .EQ. 1) GOTO 185 + IFIRST = 0 +! + NPTS=-1 +! READ(5,5020) NPTS +! 5020 FORMAT( 16I5 ) + IF( NPTS .EQ. 0 ) RETURN + 185 CONTINUE + DO 186 I=1,NP + 186 MSN(I) = 0 + DO 187 J=1,NE + IF(IESKP(J) .NE. 0) GO TO 187 + IF (IMAT(J) .LE. 0) GOTO 187 + IF (IMAT(J) .GT. 900) GO TO 187 + NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + IF (NOP(J,6) .EQ. 0) NCN=3 + DO 188 K=2,NCN,2 + N = NOP(J,K) + if(n .gt. 0) then + MSN(N) = MSN(N) + 1 + endif + 188 CONTINUE + 187 END DO + DO 195 J = 1, NE + IF(IESKP(J) .NE. 0) GO TO 195 + IF(IMAT(J) .LE. 0) GO TO 195 +!ipkoct93 +! IF(IMAT(J) .GT. 900) GO TO 195 + IF(IMAT(J) .GT. 900 .and. nop(j,7) .eq. 0) GO TO 195 + NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + IF (NOP(J,6) .EQ. 0) NCN=3 + DO 194 K = 2,NCN , 2 + L=NOP(J,K) + IF(L .EQ. 0) GO TO 194 + IF(MSN(L) .EQ. 1) THEN + N1 = NOP(J,K-1) + N2 = NOP(J,K) + N3 = MOD(K+1,NCN) + IF(N3 .EQ. 0) N3=NCN + N3 = NOP(J,N3) + X1 = CORD(N1,1) + Y1 = CORD(N1,2) + X2 = CORD(N2,1) + Y2 = CORD(N2,2) + X3 = CORD(N3,1) + Y3 = CORD(N3,2) + CALL FIT(X1,Y1,X2,Y2,X3,Y3) + ENDIF + 194 CONTINUE + 195 END DO + RETURN + END + SUBROUTINE AROHD(XPAGE,YPAGE,XTIP,YTIP,AHLEN,AHWID,ICODE) +!*********************************** .....AROHD..... + SAVE +! + IF(AHWID.LE.0.001) AHWID=AHLEN + I1=ICODE/10+3 + IF(I1.NE.3) I1=2 + KK=MOD(ICODE,10) + I2=2 + I3=2 + I4=2 + IF(KK.EQ.2) GO TO 10 + IF(KK.NE.4) GO TO 20 + I3=3 + GO TO 10 + 20 IF(KK.NE.5) GO TO 30 + I2=3 + I3=3 + GO TO 10 + 30 IF(KK.NE.8) GO TO 10 + I2=3 + I3=3 + I4=4 + 10 CONTINUE + CALL PLOTT(XPAGE,YPAGE,3) + CALL PLOTT(XTIP,YTIP,I1) + TX=XTIP-XPAGE + TY=YTIP-YPAGE + XLEN=SQRT(TX**2+TY**2) + IF(XLEN .GT. 0.001) GO TO 200 + XLEN=0.001 + IF(ABS(TX) .LT. 0.001) TX=SIGN(0.001,TX) + IF(ABS(TY) .LT. 0.001) TY=SIGN(0.001,TY) + 200 CONTINUE + TA=AHLEN/XLEN + XX=XTIP-TA*TX + YY=YTIP-TA*TY + AH=(AHWID/2.)**2 + DY=SQRT(AH*TX**2/(TX**2+TY**2)) + DY = SIGN(DY,TX) + DX=SQRT(AH*TY**2/(TX**2+TY**2)) + DX = SIGN(DX,TY) + X1=XX+DX + X2=XX-DX + Y1=YY+DY + Y2=YY-DY + CALL PLOTT(X2,Y1,I2) + CALL PLOTT(X1,Y2,I3) + CALL PLOTT(XTIP,YTIP,I4) + RETURN + END +! +!$$$ AUG 1987 +! SUBROUTINE TEST(X,Y,IG) +! +!...... Routine to that plot is on paper +! +! SAVE +! +! +! IG=0 +! IF(X .LT. 0. ) RETURN +! IF(X .GT. 10.) RETURN +! IF(Y .LT. 0. ) RETURN +! IF(Y .GT. 7.0) RETURN +! IG=1 +! RETURN +! END +! + SUBROUTINE FIT(X1,Y1,X2,Y2,X3,Y3) + SAVE +! + INTEGER I2,I3,IG + common /tek/ itek + + DATA I2/2/,I3/3/ + NPTS = 7 + DS = 1.0/FLOAT(NPTS) + S = 0.0 +! IG=0 +! CALL TEST(X1,Y1,IT) +! IF(IT .GT. 0) THEN + CALL PLOTT(X1,Y1,I3) + IG=I3 +! ENDIF + + dx3 = x1-x3 + dx2 = x1-x2 + dy3 = y1-y3 + dy2 = y1-y2 + if (abs(dx2) .le. 1.E-8) dx2 = 1.E-8 + if (abs(dx3) .le. 2.E-8) dx3 = 2.E-8 +! call test(x3,y3,itt) + if (abs(dy3/dx3 - dy2/dx2) .le. abs(.01*dy2/dx2)) then +! .and. +! + itt .gt. 0 .and. it .gt. 0) then + call plott(x3,y3,i2) + else + + DO 100 J = 1, NPTS + S = S + DS + XN1 = 1.0-3.0*S+2.0*S**2 + XN2 = 4.0*S*(1.0-S) + XN3 = S*(2.0*S-1.0) + X= XN1*X1 + XN2*X2 + XN3*X3 + Y = XN1*Y1 + XN2*Y2 + XN3*Y3 +! CALL TEST(X,Y,IT) +! IF(IT .GT. 0) THEN +! IF(IG .EQ. 0) THEN +! IG=I3 +! ELSE + IG=I2 +! ENDIF + CALL PLOTT(X,Y,IG) +! ELSE +! IG=0 +! ENDIF + 100 END DO + endif + + RETURN + END +! +!**************************************************************** +! + SUBROUTINE PGRID +! +! Form rectangular grid for guide lines by filling map arrays +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + + INCLUDE 'TXFRM.COM' + +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + DIMENSION XG(2),YG(2) +! + DATA IFIRST / 1 / +! + IF (IFIRST .EQ. 1) THEN + DX = 10. + DY = 10. + X0 = -100. +!ipk sep94 update to 7.5 size Y0 = -70. + Y0 = -75. + X9 = HSIZE*10. +!ipk sep94 update to 7.5 size Y9 = 70. + Y9 = 75. +! + IF (XMIN .GT. -VDX) THEN + XMIN = -100. + XMAX = -XMIN + IPSW(8) = 1 + ENDIF + IF (YMIN .GT. -VDX) THEN +!ipk sep94 update to 7.5 size YMIN = -70. + YMIN = -75. + YMAX = -YMIN + IPSW(8) = 1 + ENDIF +! + IFIRST = 0 + RETURN +! + ELSE +! XDIF = TXSCAL * 10.5 + XDIF = TXSCAL * HSIZE*1.05 + IXDIF = IFIX( LOG10(XDIF) ) + XRANGE = 10**IXDIF + XFAC = XDIF/XRANGE + DX = XRANGE/10. + IF ( XFAC .GE. 5.) THEN + DX = 5.*DX + ELSEIF (XFAC .GE. 2.) THEN + DX = 2.*DX + ENDIF +! + X0 = -NINT(XS/DX - .5) * DX - DX + X9 = X0 + XDIF +! + DY = DX +!ipk sep94 update to 7.5 scale YDIF = .70*XDIF + YDIF = .75*XDIF + Y0 = -NINT(YS/DY -.5) * DY - DY + Y9 = Y0 + YDIF + + ENDIF +! +! vertical-grid lines + LTP = 0 + MLEN = 2 + HT = .18 +! + DO 10 CX = X0,X9, DX + XG(1) = (CX + XS)/TXSCAL + YG(1) = (Y0 + YS)/TXSCAL + XG(2) = XG(1) + YG(2) = (Y9 + YS)/TXSCAL + CALL NWPEN(8) + CALL DASHLN(XG,YG,MLEN,LTP) +! + FPN = CX + IF (AMOD(FPN,1.) .EQ. 0. .OR. ABS(FPN) .LT. 0.01) THEN + IPLC = -1 + ELSE + IPLC = 1 + ENDIF + X = XG(1) +! Y = YG(1) + .02 +!ipk oct98 change y location + Y = .20 + IF ( (X .GT. 0. .AND. X .LT. HSIZE) .AND. & + & (Y .GT. 0. .AND. Y .LT. 7.5) ) THEN +!ipk sep94 change colour CALL NWPEN(12) + CALL NWPEN(8) +! ipk mar01 + CALL NUMBR(X,Y,0.15,FPN,0.0,IPLC) + ENDIF + 10 END DO +! +! horizontal-grid lines + DO 20 CY = Y0,Y9, DY + XG(1) = (X0 + XS)/TXSCAL + YG(1) = (CY + YS)/TXSCAL + XG(2) = (X9 + XS)/TXSCAL + YG(2) = YG(1) + CALL NWPEN(8) + CALL DASHLN(XG,YG,MLEN,LTP) +! + FPN = CY + IF (AMOD(FPN,1.) .EQ. 0. .OR. ABS(FPN) .LT. 0.01) THEN + IPLC = -1 + ELSE + IPLC = 1 + ENDIF +! X = XG(1) + X = .02 + Y = YG(1) + IF ( (X .GT. 0. .AND. X .LT. HSIZE) .AND. & + & (Y .GT. 0. .AND. Y .LT. 7.5) ) THEN +!ipk sep94 change color CALL NWPEN(12) + CALL NWPEN(8) +! ipk mar01 + CALL NUMBR(X,Y,0.15,FPN,0.0,IPLC) + ENDIF + 20 END DO +! + CALL RBlue +! + END + + SUBROUTINE RESCAL +! +! Scale for plotting +! +! + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' + + INCLUDE 'BFILES.I90' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + VDX = - 1.0E+10 + XREF=0. + YREF=0. +! +! Reset map coordinates to original scale +! + IF(MAXPTS .GT. 0) THEN + DO J=1,MAXPTS + IF(CMAP(J,1) .GE. VDX) THEN + CMAP(J,1)=TXSCAL*CMAP(J,1) - XS + CMAP(J,2)=TXSCAL*CMAP(J,2) - YS + ENDIF + ENDDO + ENDIF +! +! Reset nodal coordinates +! + IF(NP .GT. 0) THEN + DO J=1,NP + CORD(J,1) = XUSR(J) + CORD(J,2) = YUSR(J) + ENDDO + ENDIF +!ycw mar97 add for cross section + if(ICRS.ne.0) then + do i=1,2 + XPCS(i)=XPCS(i)*TXSCAL - XS + YPCS(i)=YPCS(i)*TXSCAL - YS + enddo + do i=1,NCSNOD + XCND(i)=XCND(i)*TXSCAL - XS + YCND(i)=YCND(i)*TXSCAL - YS + enddo + endif +!ycw +! +! Reset controlling scales +! + TXSCAL = 1. + XS=0. + YS=0. + XMIN = 1.E+20 + XMAX = -XMIN + YMIN = 1.E+20 + YMAX = -YMIN + IF(IMP .GT. 0) THEN +! +! Find max and min +! +! + DO J=1,MAXPTS + IF (CMAP(J,1) .GT. VDX) THEN + IF (CMAP(J,1) .LT. XMIN) XMIN = CMAP(J,1) + IF (CMAP(J,1) .GT. XMAX) XMAX = CMAP(J,1) + IF (CMAP(J,2) .LT. YMIN) YMIN = CMAP(J,2) + IF (CMAP(J,2) .GT. YMAX) YMAX = CMAP(J,2) + ENDIF + ENDDO + ENDIF +! + IF(NP .GT. 0) THEN + DO J=1,NP + IF (CORD(J,1) .GT. VDX) THEN + INSKP(J)=0 + IF (CORD(J,1) .LT. XMIN) XMIN = CORD(J,1) + IF (CORD(J,1) .GT. XMAX) XMAX = CORD(J,1) + IF (CORD(J,2) .LT. YMIN) YMIN = CORD(J,2) + IF (CORD(J,2) .GT. YMAX) YMAX = CORD(J,2) + ENDIF + ENDDO + ENDIF + IF(NE .GT. 0) THEN + DO J=1,NE + IF(NOP(J,1) .NE. 0) THEN + IESKP(J)=0 + ENDIF + ENDDO + ENDIF +! +! + DO J=1,NBKFL + XMAX=MAX(XMAX,BFMINMAX(J,1),BFMINMAX(J,3)) + XMIN=MIN(XMIN,BFMINMAX(J,1),BFMINMAX(J,3)) + YMAX=MAX(YMAX,BFMINMAX(J,2),BFMINMAX(J,4)) + YMIN=MIN(YMIN,BFMINMAX(J,2),BFMINMAX(J,4)) + ENDDO + AMAP=(XMAX-XMIN)*(YMAX-YMIN) + XSCALE = (XMAX-XMIN)/(hsize-0.5) + YSCALE = (YMAX-YMIN)/6.5 + PSCALE = MAX(XSCALE,YSCALE) +! + XAVE = (XMIN + XMAX) /2.0 + YAVE = (YMIN + YMAX) /2.0 + XMIN = XAVE - hsize/2.*PSCALE + YMIN = YAVE - 3.5*PSCALE + XMAX = XAVE + (hsize-0.5)/2.*PSCALE + YMAX = YAVE + 3.25*PSCALE +! +! Plot all data +! + CALL PLOTSV(0) +!ipk nov97 add (0) + CALL PLOTOT(0) + RETURN + END + +!IPK JAN01 NEW ROUTINE + + SUBROUTINE PLOTCC + + USE BLK1MOD + use blk2mod +! INCLUDE 'BLK1.COM' + DIMENSION XLIN(350),YLIN(350) + + IF(NCLM .GT. 0) THEN + +!Process each line + CALL RBLUE + + DO NCLL=1,NCLM + WRITE(90,*) 'PLOTR1-1130 NCLL,NCLM',NCLL,NCLM + DO KK=1,350 + IF(ICCLN(NCLL,KK) .NE. 0) THEN + IF(KK .EQ. 1) THEN + X=CORD(ICCLN(NCLL,KK),1)+0.1 + Y=CORD(ICCLN(NCLL,KK),2)+0.1 + IF(X .GT. 0. .AND. X .LT. HSIZE) THEN + IF(Y .GT. 0. .AND. Y .LT. 7.5) THEN + FPN=NCLL +! ipk mar01 + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + ENDIF + ENDIF + ENDIF + XLIN(KK)=CORD(ICCLN(NCLL,KK),1) + YLIN(KK)=CORD(ICCLN(NCLL,KK),2) + ELSE + if(kk .eq. 1) GO TO 510 + NTRAC=KK-1 + X=CORD(ICCLN(NCLL,KK-1),1)+0.1 + Y=CORD(ICCLN(NCLL,KK-1),2)+0.1 + IF(X .GT. 0. .AND. X .LT. HSIZE) THEN + IF(Y .GT. 0. .AND. Y .LT. 7.5) THEN + FPN=NCLL +! ipk mar01 + CALL NUMBR(X,Y,0.2,FPN,0.0,-1) + ENDIF + ENDIF + if(ntrac .eq. 1) then + call IGrCharSize(0.5,0.5) + call IGrMarker(x-0.1,y-0.1,14) + call IGrCharSize(1.0,1.0) + endif +! +! Draw along line +! + IF(NTRAC .GT. 1) THEN + CALL THICKL + CALL DASHLN(XLIN,YLIN,NTRAC,0) + CALL THINL + ENDIF + GO TO 400 + ENDIF + 359 CONTINUE + ENDDO + 400 CONTINUE + IF(NTRAC .EQ. 1) THEN + NODL=ICCLN(NCLL,1) + DO N=1,NE + IF(IMAT(N) .LT. 900 .AND. IMAT(N) .GT. 0) THEN + IF(NCORN(N) .EQ. 5 .OR. NCORN(N) .EQ. 3) THEN + IF(NOP(N,1) .EQ. NODL) THEN + DIRX=CORD(NOP(N,3),1)-CORD(NOP(N,1),1) + DIRY=CORD(NOP(N,3),2)-CORD(NOP(N,1),2) + GO TO 420 + ELSEIF(NOP(N,3) .EQ. NODL) THEN + DIRX=CORD(NOP(N,1),1)-CORD(NOP(N,3),1) + DIRY=CORD(NOP(N,1),2)-CORD(NOP(N,3),2) + GO TO 420 + ENDIF + ENDIF + ENDIF + ENDDO + 420 DIR=ATAN2(DIRX,-DIRY) + D1=CORD(NODL,1) + D2=CORD(NODL,2) + ELSE + +! Plot arrows on continuity line + + DIRX=CORD(ICCLN(NCLL,1),1)-CORD(ICCLN(NCLL,NTRAC),1) + DIRY=CORD(ICCLN(NCLL,1),2)-CORD(ICCLN(NCLL,NTRAC),2) + IF(DIRX .EQ. 0. .AND. DIRY .EQ. 0.) THEN + DIR=0. + ELSE + DIR=ATAN2(DIRX,-DIRY) + D1=(CORD(ICCLN(NCLL,1),1)+CORD(ICCLN(NCLL,NTRAC),1))/2. + D2=(CORD(ICCLN(NCLL,1),2)+CORD(ICCLN(NCLL,NTRAC),2))/2. + ENDIF + ENDIF + DIR1=DIR+2.35619 + DIR2=DIR-2.35619 + DE1=D1+0.4*COS(DIR) + DE2=D2+0.4*SIN(DIR) + DEA1=DE1+0.1*COS(DIR1) + DEA2=DE2+0.1*SIN(DIR1) + DEB1=DE1+0.1*COS(DIR2) + DEB2=DE2+0.1*SIN(DIR2) + CALL RBLUE + CALL PLOTT(D1,D2,3) + CALL PLOTT(DE1,DE2,2) + CALL PLOTT(DEA1,DEA2,2) + CALL PLOTT(DE1,DE2,3) + CALL PLOTT(DEB1,DEB2,2) + CALL RBLUE +510 CONTINUE + ENDDO + ENDIF + + RETURN + END + + SUBROUTINE PLOTCSTR + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +! Plot arrows on control structures + + DO N=1,NE + IF(IMAT(N) .GT. 903) THEN + + DIRX=CORD(NOP(N,3),1)-CORD(NOP(N,1),1) + DIRY=CORD(NOP(N,3),2)-CORD(NOP(N,1),2) + IF(DIRX .EQ. 0. .AND. DIRY .EQ. 0.) THEN + DIR=0. + ELSEIF(NCORN(N) .LT. 6) THEN + DIR=ATAN2(DIRY,DIRX) + D1=CORD(NOP(N,1),1) + D2=CORD(NOP(N,1),2) + ELSE + DIR=ATAN2(DIRX,-DIRY) + D1=CORD(NOP(N,2),1) + D2=CORD(NOP(N,2),2) + ENDIF + DIR1=DIR+2.35619 + DIR2=DIR-2.35619 + IF(IESKP(N) .EQ. 0) THEN + D1=CORD(NOP(N,2),1) + D2=CORD(NOP(N,2),2) + DE1=D1+0.4*COS(DIR) + DE2=D2+0.4*SIN(DIR) + DEA1=DE1+0.1*COS(DIR1) + DEA2=DE2+0.1*SIN(DIR1) + DEB1=DE1+0.1*COS(DIR2) + DEB2=DE2+0.1*SIN(DIR2) + CALL RRED + CALL PLOTT(D1,D2,3) + CALL PLOTT(DE1,DE2,2) + CALL PLOTT(DEA1,DEA2,2) + CALL PLOTT(DE1,DE2,3) + CALL PLOTT(DEB1,DEB2,2) + CALL RBLUE + ENDIF + ENDIF + ENDDO + RETURN + END + + SUBROUTINE PLOTCRSS(isw) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'TXFRM.COM' +! COMMON/ICN1/ ICN(MAXP) + + CHARACTER*11 PART1,PART2 + + if(isw .eq. 0) then + CALL RGREEN + + DO NN=1,NCRSEC + N=IVMIL(NN) + xpt=(xcrs(n)+xs)/txscal + ypt=(ycrs(n)+ys)/txscal + a=NOREACH(N)/1000. + fpn=n+a + IF(XPT .GT. 0. .AND. XPT .LT. HSIZE) THEN + IF(YPT .GT. 0. .AND. YPT .LT. 7.5) THEN + call plotcr(xpt,ypt,0.05) + CALL NUMBR(xpt,ypt-0.1,0.13,FPN,0.0,3) + ENDIF + ENDIF + ENDDO + ENDIF + + IF(ISW .EQ. 1) THEN + + DO J=1,MAXP + ICN(J)=0 + END DO +! First sort out the potential midsides +! Note that transition elements caues a problem +! Find these first + DO 200 N=1,NE + if(NCORN(N) .GT. 5) GO TO 200 + IF(NCORN(N) .EQ. 5 .AND. IMAT(N) .LT. 901) THEN +! +! We have a transition mark node number as if it were corner +! + ICN(NOP(N,3))=1 + ICN(NOP(N,1))=2 + ICN(NOP(N,4))=2 + ICN(NOP(N,5))=2 + ELSE +! +! Store ICN = 2 for corner nodes +! + NCN=NCORN(N) +!IPKOCT93 IF(IMAT(N) .GT. 900) THEN + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) THEN + MST=1 + ELSE + MST=2 + ENDIF + DO 180 M=1,NCN,MST + ICN(NOP(N,M))=2 + 180 CONTINUE + ENDIF + 200 END DO + + DO J=1,NP + + IF(ICN(J) .EQ. 2) THEN + WRITE(PART1,'(I5,F6.3)') & + ,NRIVCR1(J),WTRIVCR1(J) + + WRITE(PART2,'(I5,F6.3)') & + ,NRIVCR2(J),WTRIVCR2(J) + + IF (CORD(J,1) .LT. VDX) GO TO 300 + X = CORD(J,1) + Y = CORD(J,2) + + CALL RBlack + IF(X .GT. 0. .AND. X .LT. HSIZE) THEN + IF(Y .GT. 0. .AND. Y .LT. 7.5) THEN + CALL SYMBL(X-0.25,Y+.24,0.10,PART1,0.0,11) + CALL SYMBL(X-0.25,Y+.12,0.10,PART2,0.0,11) + endif + ENDIF + 300 CONTINUE + ENDIF + ENDDO + ENDIF + CALL RBlue + RETURN + END diff --git a/src/src83e/RDOUTLIN.F90 b/src/src83e/RDOUTLIN.F90 new file mode 100644 index 0000000..5b30624 --- /dev/null +++ b/src/src83e/RDOUTLIN.F90 @@ -0,0 +1,46 @@ + MODULE BLKOUT + ALLOCATABLE XOUTL(:),YOUTL(:) + INTEGER NOUTLIN + ENDMODULE + + SUBROUTINE RDOUTLIN +! +! ROUTINE TO READ COORDINATES OF MESH OUTLINE + + USE WINTERACTER + USE BLKOUT + + CHARACTER(LEN=255) :: FNAME +! CHARACTER(LEN=3) :: SUB,SUB1 + CHARACTER(LEN=256) :: FILTER + CHARACTER*3 SUB + + FILTER ="Outline files -- *.txt|*.txt|map files -- |*.map|All files -- |*.*|" + CALL WSelectFile(FILTER,PromptOn,FNAME,'Load Outline File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + OPEN(99,FILE=FNAME,STATUS='OLD') + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + KTYP=2 + ELSE + KTYP=1 + ENDIF + ELSE + RETURN + ENDIF + + ALLOCATE (XOUTL(5000),YOUTL(5000)) + IF(KTYP .EQ. 2) READ(99,*) INDM + DO N=1,5000 + READ(99,*,END=500,ERR=500) XOUTL(N),YOUTL(N) + ENDDO + close(99) +500 CONTINUE + NOUTLIN=N-1 + RETURN + END + diff --git a/src/src83e/RDRM1.F90 b/src/src83e/RDRM1.F90 new file mode 100644 index 0000000..c1968e3 --- /dev/null +++ b/src/src83e/RDRM1.F90 @@ -0,0 +1,111 @@ + SUBROUTINE RDRM1(IFILE,NPTEMP,NETEMP,IMIDS) + + SAVE + + REAL*8 CX,CY + CHARACTER DLINE*140,ID1*3,BLANK*20 + DIMENSION ILN(8) + + data blank/' '/ + + + REWIND (IFILE) + READ(ifile,'(A80)') TITLE + READ(IFILE,'(100X,I5)') IFORM1 + READ(IFILE,'(A80)') DLINE(1:80) + + IMIDS=0 + NP=0 + NE=0 + NPTEMP=0 + NETEMP=0 + + 100 CALL GINPT1(IFILE,DLINE) + + +!ipk feb12 add format test + IF(MOD(IFORM1,2) .EQ. 1) THEN + READ(DLINE,'(10I6,F10.3,I6)') J,ILN,IMT,EDIR,INU + ELSE + READ(DLINE,'(10I5,F10.3,I5)') J,ILN,IMT,EDIR,INU + ENDIF + IF(ILN(1) .EQ. 0 .AND. (J .EQ. 9999 .OR. J .EQ. 99999)) THEN + GO TO 120 + ELSE + IF(ILN(7) .NE. 0) THEN + NCN=8 + ELSEIF(ILN(5) .NE. 0) THEN + NCN=6 + ELSEIF(ILN(3) .NE. 0) THEN + NCN=3 + ENDIF + + DO K=1,NCN + NPTEMP=MAX(NPTEMP,ILN(K)) + NETEMP=MAX(NETEMP,J) + IF(MOD(K,2) .EQ. 0 .AND. ILN(K) .EQ. 0) IMIDS=1 + ENDDO + GO TO 100 + ENDIF + + 120 continue + + CALL GINPT1(IFILE,DLINE) + + IF(IFORM1 .LT. 2) THEN + READ(DLINE,'(I10,9F10.0,I10,F10.0)') J, CX, CY, BELEV,& + WDTHX,SS1X,SS2X,WDSX,WEL,SSSO,LOCK1,BS11 + ELSE +! do kct=1,140 +! if(dline(kct:kct) .eq. '*') then + do kcl=61,140 + dline(kcl:kcl)=' ' + enddo +! go to 8888 +! endif +! enddo +!8888 continue + READ(DLINE,'(I10,2F20.0,7F10.0,I10,F10.0)',err=8888) J, CX, CY, BELEV,& + WDTHX,SS1X,SS2X,WDSX,WEL,SSSO,LOCK1,BS11 + go to 8889 + 8888 do kcl=61,140 + dline(kcl:kcl)=' ' + enddo + READ(DLINE,'(I10,2F20.0,7F10.0,I10,F10.0)') J, CX, CY, BELEV,& + WDTHX,SS1X,SS2X,WDSX,WEL,SSSO,LOCK1,BS11 +8889 continue + ENDIF + + + IF(DLINE(11:30) .eq. blank .AND. (J .EQ. 9999 .OR. J .EQ. 99999)) THEN + GO TO 140 + ELSE + NPTEMP=MAX(NPTEMP,J) + GO TO 120 + ENDIF +140 CONTINUE + + REWIND(IFILE) + RETURN + END + + SUBROUTINE GINPT1(IIN,DLIN) + CHARACTER DLIN*140 + 100 CONTINUE + READ(IIN,7000) DLIN +!IPK SEP08 write(75,7000) dlin + 7000 FORMAT(A140) + do i=1,140 + if(dlin(i:i) .eq. char(9)) go to 200 + enddo + RETURN + 200 continue +!IPK SEP04 + CLOSE(75) + OPEN(75,file='ERROR.OUT') + write(*,*) 'Error Tab character found in the following line' + write(75,*) 'Error Tab character found in the following line' + write(75,7000) dlin + write(*,7000) dlin + stop + END diff --git a/src/src83e/READSHP.FOR b/src/src83e/READSHP.FOR new file mode 100644 index 0000000..f3e8262 --- /dev/null +++ b/src/src83e/READSHP.FOR @@ -0,0 +1,209 @@ + SUBROUTINE READSHP + + USE BLKMAP + USE BLK1MOD + character*4 temp + character*100 header,field + character*4 ai7,aai7,ai8 + integer status,i1,i2,i3,i4,i5,i6,i7,i8,i9 + integer*2 i1s,i2s,i3s + integer*1 i1vs(20),i2vs(20) + real*8 fp1,fp2,fp3,fp4,fp5,fp6,fp7,fp8,vtemp(20) + character*11 label(20),fomat(20) + character*1 type(20),a2,a3,a4 + equivalence (aai7,ia7),(aai8,ia8) + +c read header + + read(113) i1,i2,i3,i4,i5,i6,ai7,i8,i9 + read(113) fp1,fp2,fp3,fp4,fp5,fp6,fp7,fp8 + CALL BTOL(AI7,IA7) + write(90,*) 'file length',ia7 + write(90,*) 'version',i8 + write(90,*) 'shapetype',i9 + +c read data + + read(114) i1,i2,i1s,i2s,i3,i4,i5,i6,i7 + nrecs=i2 + nbytesh=i1s + nrecsh=nbytesh/32-1 + ndytesrec=i2s + nfl=0 + +c now process labels + + do k=1,nrecsh + read(114) label(k),type(k),i3,i1vs(k),i2vs(k),i3s,i4,i5,i6 + if(type(k) .eq. 'F' .or. type(k) .eq. 'N') then + write(fomat(k),6000) i1vs(k),i2vs(k) + 6000 format('(F',i2,'.',i1,')') + else + if(i1vs (k) .lt. 10) then + write(fomat(k),6001) i1vs(k) + 6001 format('(A',i1,')') + else + write(fomat(k),6002) i1vs(k) + 6002 format('(A',i2,')') + endif + endif + nfl=nfl+i1vs(k) + enddo + read(114) a3 + call choosrec(label,nrecsh,nchs) + + + 230 continue + JK=0 + JL=0 + if(i9 .eq. 1) then + do JJ=1,100000 + read(113,end=300) ai7,ai8 + CALL BTOL(AI7,IA7) + CALL BTOL(AI8,IA8) + READ(113) I1,FP1,FP2 + CMAP(JJ,1)=FP1 + CMAP(JJ,2)=FP2 + XMAP(JJ)=FP1 + YMAP(JJ)=FP2 + MAXPTS=JJ +c VAL(JJ)=-2. + ENDDO + 300 CONTINUE + XMAP(MAXPTS+1)= VOID + LINTYP(1)=2 + +! +!c finished shape file now read dbf stat with header +! +! read(114) i1,i2,i1s,i2s,i3,i4,i5,i6,i7 +! nrecs=i2 +! nbytesh=i1s +! nrecsh=nbytesh/32-1 +! ndytesrec=i2s +! nfl=0 +! +!c now process labels +! +! do k=1,nrecsh +! read(114) label(k),type(k),i3,i1vs(k),i2vs(k),i3s,i4,i5,i6 +! if(type(k) .eq. 'F' .or. type(k) .eq. 'N') then +! write(fomat(k),6000) i1vs(k),i2vs(k) +! 6000 format('(F',i2,'.',i1,')') +! else +! if(i1vs (k) .lt. 10) then +! write(fomat(k),6001) i1vs(k) +! 6001 format('(A',i1,')') +! else +! write(fomat(k),6002) i1vs(k) +! 6002 format('(A',i2,')') +! endif +! endif +! nfl=nfl+i1vs(k) +! enddo + !read(114) a3 + !call choosrec(label,nrecsh,nchs) + do j=1,nrecs + do k=1,nrecsh + read(114) field(1:i1vs(k)) + read(field,fomat(k)) vtemp(k) + enddo + val(j)=vtemp(NCHS) + read(114) a3 + enddo + else + do JJ=1,100000 + read(113,end=500) ai7,ai8 + CALL BTOL(AI7,IA7) + CALL BTOL(AI8,IA8) + read(113) istp,FP1,FP2,FP3,FP4,npart,npts,nd1 +! do j=1,nrecs + do k=1,nrecsh + read(114) field(1:i1vs(k)) + read(field,fomat(k)) vtemp(k) + enddo + read(114) a3 +! enddo + JL=JL+1 + LINTYP(JL)=1 + do k=1,npts + read(113) fp1,fp2 + WRITE(155,*) JK,JL,FP1,FP2,VTEMP(NCHS) + jk=jk+1 + CMAP(jk,1)=FP1 + CMAP(jk,2)=FP2 + XMAP(jk)=FP1 + YMAP(jk)=FP2 + MAXPTS=jk + val(jK)=vtemp(NCHS) + + enddo + jk=jk+1 + CMAP(jk,1)=-1.e10 + CMAP(jk,2)=-1.e10 + XMAP(jk)=-1.e10 + YMAP(jk)=-1.e10 + MAXPTS=jk + val(jK)=0. + enddo + 500 continue + MAXPTS=JK-1 + KLINT=JL + JLINT=MAXPTS + endif + CLOSE (113) + RETURN + END + + + SUBROUTINE BTOL(AICHG,ICHG) + INTEGER ICHG,ITEMP + CHARACTER*4 AICHG,AAICHG + EQUIVALENCE(ITEMP,AAICHG) + aaICHG(1:1)=aICHG(4:4) + aaICHG(2:2)=aICHG(3:3) + aaICHG(3:3)=aICHG(2:2) + aaICHG(4:4)=aICHG(1:1) + ICHG=ITEMP + RETURN + END + + subroutine choosrec(label,nrecsh,nchs) + use winteracter + implicit none + include 'D.inc' + SAVE + character*11 label(*) + INTEGER NRECSH,NCHS,IERR,N + + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + call wdialogload(IDD_CHSTYP) + ierr=infoerror(1) + + do n=1,NRECSH + write(90,'(a)') 'file',n,LABEL(N) + CALL WDialogPutString(idf_string25+n-1,LABEL(n)) + call wdialogputradiobutton(idf_radio1) + enddo + CALL WDialogSelect(IDD_CHSTYP) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + call wdialogGetradiobutton(idf_radio1,NCHS) + ENDIF + RETURN + END + + + + \ No newline at end of file diff --git a/src/src83e/REATTACH.F90 b/src/src83e/REATTACH.F90 new file mode 100644 index 0000000..4403408 --- /dev/null +++ b/src/src83e/REATTACH.F90 @@ -0,0 +1,110 @@ + SUBROUTINE REATTACH + + + USE BLK1MOD + USE BLK2MOD + + INTEGER NS1(3,4),NT1(3,4) + CHARACTER*1 IFLAG,ANSW(10) + DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/ + +! SETUP CONNECTIVITY TABLE + CALL KCON(0) +! SELECT FIRST ELEMENT +10 CONTINUE + NHTPSV=NHTP + NMESSSV=NMESS + NBRRSV=NBRR + NHTP=0 + NMESS=20 + NBRR=8 + CALL HEDR + + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + CALL HEDR + RETURN + ENDIF + IF(IFLAG .EQ. 'c' .AND. IBOX .GT. 0) THEN + IFLAG=ANSW(IBOX) + ENDIF +! + IF(IFLAG .EQ. 'q') THEN + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + CALL HEDR + RETURN + ENDIF + call fillem(ielem) +! GET UNATTACHED NOP + kk=0 + DO K=2,NCORN(IELEM),2 + NSX=NOP(IELEM,K) + IF(NDELM(NSX) .EQ. 1) THEN +! FOUND IT + KK=KK+1 + NS1(1,KK)=NOP(IELEM,K-1) + NS1(2,KK)=NSX + KKK=MOD(K,NCORN(IELEM))+1 + NS1(3,KK)=NOP(IELEM,KKK) +! GO TO 280 + ENDIF + ENDDO +280 CONTINUE + + +! SELECT NEXT ELEMENT + + CALL PROX(XC,YC,NE,XX,YY,IELEM1,IFLAG,IESKP,IBOX) + call fillem(ielem1) + +! GET UNNATCHED SIDE +! FIND AN UNATTACHED SIDE (INDICATE OF TRIANGLE OR QUADRILATERAL) + LL=0 + DO K=2,NCORN(IELEM1),2 + NSX=NOP(IELEM1,K) + IF(NDELM(NSX) .EQ. 1) THEN +! FOUND IT + LL=LL+1 + NT1(1,LL)=NOP(IELEM1,K-1) + NT1(2,LL)=NSX + KKK=MOD(K,NCORN(IELEM1))+1 + NT1(3,LL)=NOP(IELEM1,KKK) +! GO TO 300 + ENDIF + ENDDO +300 CONTINUE + +! FORM A NEW ELEMENT ASSIGN TYPE AS INDICATED +! GET THE NEAREST TWO FACES + DISTKP=1.E20 + DO NN=1,KK + DO MM=1,LL + DIST=(XUSR(NS1(2,NN))-XUSR(NT1(2,MM)))**2+(YUSR(NS1(2,NN))-YUSR(NT1(2,MM)))**2 + IF(DIST .LT. DISTKP) THEN + NNN=NN + MMM=MM + DISTKP=DIST + ENDIF + ENDDO + ENDDO + CALL GETELM(J) + DO K=1,3 + NOP(J,K)=NS1(K,NNN) + NOP(J,K+4)=NT1(K,MMM) + ENDDO + NOP(J,4)=0 + NOP(J,8)=0 + IMAT(J)=1 + IESKP(J) = 0 + NCORN(J)=8 + +! GO BACK TO LOOK FOR NEW PAIR + CALL PLOTOT(1) + GO TO 10 + RETURN + END \ No newline at end of file diff --git a/src/src83e/REFINB.F90 b/src/src83e/REFINB.F90 new file mode 100644 index 0000000..72fabb6 --- /dev/null +++ b/src/src83e/REFINB.F90 @@ -0,0 +1,1436 @@ +!IPK LAST UPDATE SEP 23 2015 ADD TESTING FOR CHNAGED ELEMENTS/NODES +! last update Sept 20 1999 +! Last change: IPK 13 Jan 98 10:05 am +!ipk last update Nov 18 1997 +!ipk last update Oct 24 1996 + SUBROUTINE REFB +! +! Routines to control refinement of elements +! + USE BLK1MOD + + INCLUDE 'BFILES.I90' +! INCLUDE 'BLK1.COM' +! + CHARACTER*1 ANS,ANSW(10) + DATA ANSW/'f','l','s','t','v','n',' ','m',' ','q'/ +! +! Draw box around selections +! + 100 CONTINUE + NHTP=8 + NMESS=0 + NBRR=0 + CALL HEDR +! +! Get answer +! +!ipk jan98 + 210 continue + call wrtbox(idelv) + call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN +!ipk jan98 add option for deleting elevation on move + IF(IBOX .EQ. 7 .or. ANS .eq. 'e') THEN + IDELV=MOD(IDELV+1,2) + GO TO 210 + ENDIF + IF(ANS .EQ. 'c') THEN + if(ibox .eq. 0) go to 210 + ANS=ANSW(IBOX) + ENDIF +! +! Element generation +! + IF (ANS .EQ. 'f') THEN +! +! Refine elements by four +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL REFIN(0) + IRDONE=0 + IF(IRMAIN .EQ. 1) RETURN +! + ELSEIF (ANS .EQ. 'l') THEN +! +! Refine elements by two long +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL REFIN(1) + IRDONE=0 + IF(IRMAIN .EQ. 1) RETURN +! + ELSEIF (ANS .EQ. 's') THEN +! +! Refine elements by two short +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL REFIN(2) + IRDONE=0 + IF(IRMAIN .EQ. 1) RETURN +! +! + ELSEIF (ANS .EQ. 't') THEN +! +! Refine elements by splitting quads +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL REFIN(3) + IRDONE=0 + IF(IRMAIN .EQ. 1) RETURN +! +! + ELSEIF (ANS .EQ. 'v') THEN +! +! Reverse element diagonals for quads +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL REFIN(4) + IRDONE=0 + IF(IRMAIN .EQ. 1) RETURN +! + ELSEIF (ANS .EQ. 'n') THEN +! +! Clean up element refinement +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL CLENUP(0) + IRDONE=0 + IF(IRMAIN .EQ. 1) RETURN +! + ELSEIF (ANS .EQ. 'm') THEN + IF(IRMAIN .EQ. 1) RETURN +! +! simplify layout +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL SMFY ! + IRDONE=0 + ELSEIF (ANS .EQ. 'q') THEN + CALL WRTOUT(0) ! + + + RETURN +! +! Look again +! + ENDIF + GO TO 100 + END +! + SUBROUTINE REFIN(ITYPT) +! +! Routine to refine elements +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + DIMENSION NTRAN(9),IELGB(8) + CHARACTER*1 IFLAG + DIST(N1,N2)=SQRT((CORD(N1,1)-CORD(N2,1))**2 & + & +(CORD(N1,2)-CORD(N2,2))**2) +! + ITYP=ITYPT + IF(NEFL .GT. 0) GO TO 150 +!ipk may94 change so that refine does not change display +! DO 2 I=1,9 +! IPSW(I)=0 +! 2 CONTINUE +! IPSW(4)=1 +! CALL PLOTOT +!ipk may94 end changes + 3 CONTINUE + NHTP=0 + NMESS=12 + NBRR=3 + CALL HEDR +! +! Write out +! + NEFL=0 + 4 CONTINUE + IBOX=1 + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN +! + IF (IFLAG .EQ. 'c') THEN + NEFL=NEFL+1 + NEFLAG(NEFL)=IELEM + CALL FILLEM(IELEM) + ELSEIF (IFLAG .EQ. 'U') THEN + NEFLAG(NEFL)=0 + NEFL=NEFL-1 + CALL PLOTOT(1) + CALL HEDR + DO IELEM=1,NEFL + CALL FILLEM(NEFLAG(IELEM)) + ENDDO +! +! ELSEIF(IFLAG .EQ. 'r') THEN +! CALL PLOTS(0) +! CALL PLOTOT +! GO TO 4 + ELSEIF(IFLAG .EQ. 'q' .OR. IFLAG .EQ. 'e') THEN + GO TO 152 +! + ELSE +!IPK JAN98 WRITE(*,*) CHAR(7),CHAR(7) + ENDIF +! + GOTO 4 +! +! + 150 CONTINUE +! IPSWO=IPSW +! IPSW=4 +! CALL PLOTS(0) +!ipk oct96 DO 151 I=1,9 +!ipk oct96 IPSW(I)=0 +!ipk oct96 151 CONTINUE +!ipk oct96 IPSW(4)=1 + +!ipk nov97 add (1) + CALL PLOTOT(1) +! IPSW=IPSWO +! +! Define NEF and process elements +! + 152 CONTINUE + + DO N=1,NE + DO M=1,8 + NOPSV(N,M)=NOP(N,M) + ENDDO + IMATSV(N)=IMAT(N) + ENDDO + NPUNDO=0 + NEUNDO=0 + NESAV=NE + NEFSAV=NENTRY + IF(NENTRY .GT. 0) THEN + DO N=1,NENTRY + DO M=1,3 + NEFSV(N,M)=NEF(N,M) + ENDDO + ENDDO + ENDIF + ITYPSV=ITYP + DO 250 NN=1,NEFL + ITYP=ITYPSV + N=NEFLAG(NN) + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) GO TO 250 +! IF(IMAT(N) .EQ. 999) ITYP=1 + NCN=NCORN(N) +! +! Split a one-dimensional element in two +! + IF(NCN .EQ. 3) THEN + N1=NOP(N,1) + N2=NOP(N,2) + N3=NOP(N,3) + IF(NOP(N,2) .EQ. 0) THEN + CALL GETNOD(N2) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=N2 + ELSEIF(INEW(N2) .EQ. 1) THEN + GO TO 153 + ENDIF + CORD(N2,1)=(CORD(N1,1)+CORD(N3,1))/2. + CORD(N2,2)=(CORD(N1,2)+CORD(N3,2))/2. + IF(LOCK(N1) .EQ. 1 .AND. LOCK(N3) .EQ. 1) LOCK(N2)=1 + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + INEW(N2) = 1 + INSKP(N2) =0 + 153 CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + NOP(NEM,3)=N3 + NOP(N,2)=0 + NOP(N,3)=N2 + NOP(NEM,1)=N2 + NOP(NEM,2)=0. + NOP(NEM,3)=N3 + IMAT(NEM)=IMAT(N) + IESKP(NEM)=0 + NCORN(NEM)=3 +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(N2)=-9999. + WIDTH(N2)=0. + SS1(N2)=0. + SS2(N2)=0. + WIDS(N2)=0. + ELSE + WD(N2)=(WD(N1)+WD(N3))/2. + WIDTH(N2)=(WIDTH(N1)+WIDTH(N3))/2. + SS1(N2)=(SS1(N1)+SS1(N3))/2. + SS2(N2)=(SS2(N1)+SS2(N3))/2. + WIDS(N2)=(WIDS(N1)+WIDS(N3))/2. + IF(ICRIN .EQ. 23) CALL COMPWGT + ENDIF + GO TO 250 + ENDIF +! +! Setup for each type of refinement +! +!ipk jan08 + IF(ITYP .EQ. 0) THEN +! +! Full refinement all nodes are eligible +! +! IF(imat(n) .eq. 999) then +! IELGB(2)=2 +! IELGB(4)=0 +! IELGB(6)=2 +! IELGB(8)=0 +! ELSE + DO M=2,NCN + IELGB(M)=1 + ENDDO +! ENDIF + ELSEIF(ITYP .EQ. 1 .OR. ITYP .EQ. 2) THEN +! +! Setup for long or short side refinement +! + IF(ITYP .EQ. 1) THEN + DISTLL=0. + DISTL=0. + ELSE + DISTLL=-VOID + DISTL=-VOID + ENDIF +! +! Sort out longest or shortest sides +! + DO 165 M=2,NCN,2 + IELGB(M)=0 + N1=NOP(N,M-1) + N2=MOD(M,NCN)+1 + N2=NOP(N,N2) + DSEP=DIST(N1,N2) + IF(ITYP .EQ. 1) THEN + IF(DISTLL .LT. DSEP) THEN +! Separation greater DISTLL + IF(DISTLL .GT. 0.) THEN +! DISTLL already exists then move it down the line + DISTL=DISTLL + NDS=NDSS + ENDIF +! Save separation + DISTLL=DSEP + NDSS=M + GO TO 165 + ELSEIF(DISTL .LT. DSEP) THEN +! 2nd longest + DISTL=DSEP + NDS=M + ENDIF + ELSE + IF(DSEP .LT. DISTLL) THEN +! Separation less than DISTLL + IF(DISTLL .LT. -VDX) THEN +! DISTLL already exists then move it up the line + DISTL=DISTLL + NDS=NDSS + ENDIF + DISTLL=DSEP + NDSS=M + GO TO 165 + ELSEIF(DSEP .LT. DISTL) THEN +! 2nd shortest + DISTL=DSEP + NDS=M + ENDIF + ENDIF + 165 CONTINUE + IELGB(NDSS)=2 + IELGB(NDS)=2 + ELSEIF(ITYP .EQ. 3) THEN +!ipk jan98 IF(NCN .EQ. 8) CALL SPLIT(N) + IF(NCN .GT. 5) CALL SPLIT(N) + GO TO 250 + ELSEIF(ITYP .EQ. 4) THEN + NPL=NEFLAG(NN+1) + CALL REVERS(N,NPL) + GO TO 255 + ENDIF +! +! Loop through element sides +! + DO 200 M=2,NCN,2 + IF(IELGB(M) .EQ. 0) GO TO 200 + N1=NOP(N,M-1) + N3=MOD(M+1,NCN) + N3=NOP(N,N3) +! +! Search table for N1 +! + IF(NENTRY .EQ. 0) GO TO 182 + DO 180 J=1,NENTRY + IF(N1 .EQ. NEF(J,3) .AND. N3 .EQ. NEF(J,1)) THEN +! +! We have found match so use this info +! + NOP(N,M)=NEF(J,2) +! +! For regular ops remove value in NEF(J,1) so that it seems blank and s +! otherwise set value negative + IF(IELGB(M) .EQ. 1) THEN + NEF(J,1)=0 + ELSE + NEF(J,1)=-NEF(J,1) + ENDIF + GO TO 200 + ENDIF + 180 CONTINUE + 182 CONTINUE +! +! Define a node, enter it, initialize it, and make entry in NEF +! + IF(IMAT(N) .EQ. 999 .AND. (M .EQ. 4 .OR. M .EQ. 8)) GO TO 200 + + IF(NOP(N,M) .EQ. 0) THEN + CALL GETNOD(N2) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=N2 + NOP(N,M)=N2 + CORD(N2,1)=(CORD(N1,1)+CORD(N3,1))/2. + CORD(N2,2)=(CORD(N1,2)+CORD(N3,2))/2. + IF(LOCK(N1) .EQ. 1 .AND. LOCK(N3) .EQ. 1) LOCK(N2)=1 + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + INEW(N2) = 1 + INSKP(N2) =0 + ELSE + N2=NOP(N,M) + IF(INEW(N2) .NE. 1) THEN + CORD(N2,1)=(CORD(N1,1)+CORD(N3,1))/2. + CORD(N2,2)=(CORD(N1,2)+CORD(N3,2))/2. + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + INEW(N2) = 1 + INSKP(N2) =0 + ENDIF + ENDIF +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(N2)=-9999. + ELSE + WD(N2)=(WD(N1)+WD(N3))/2. + ENDIF + IF(M .EQ. 2 .AND. IMAT(N) .EQ. 999) THEN + WIDTH(N2)=(WIDTH(N1)+WIDTH(N3))/2. + SS1(N2)=(SS1(N1)+SS1(N3))/2. + SS2(N2)=(SS2(N1)+SS2(N3))/2. + WIDS(N2)=(WIDS(N1)+WIDS(N3))/2. + ELSE + WIDTH(N2)=0. + SS1(N2)=0. + SS2(N2)=0. + WIDS(N2)=0. + ENDIF + NENTRY=NENTRY+1 + NEF(NENTRY,1)=N1 + NEF(NENTRY,2)=N2 + NEF(NENTRY,3)=N3 + 200 CONTINUE + IF(ITYP .GT. 0) GO TO 250 +! +! Copy NOP into temporary NTRAN for processing then delete element +! + DO 220 K=1,8 + NTRAN(K)=NOP(N,K) + NOP(N,K)=0 + 220 CONTINUE + NRMAT=IMAT(N) + IMAT(N)=0 + IESKP(N)=-1 + NTYP=1 + NELAST= MIN(NELAST,N) + IF(NCN .EQ. 8) THEN + IF(NRMAT .EQ. 999) THEN + IF(NTRAN(2) .EQ. 0) THEN + CALL GETNOD(N2) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=N2 + N1=NTRAN(1) + N3=NTRAN(3) + CORD(N2,1)=(CORD(N1,1)+CORD(N3,1))/2. + CORD(N2,2)=(CORD(N1,2)+CORD(N3,2))/2. + INEW(N2) = 1 + IF(LOCK(N1) .EQ. 1 .AND. LOCK(N3) .EQ. 1) LOCK(N2)=1 + NTRAN(2)=N2 + WD(N2)=(WD(N1)+WD(N3))/2. + WIDTH(N2)=(WIDTH(N1)+WIDTH(N3))/2. + SS1(N2)=(SS1(N1)+SS1(N3))/2. + SS2(N2)=(SS2(N1)+SS2(N3))/2. + WIDS(N2)=(WIDS(N1)+WIDS(N3))/2. + ENDIF + IF(NTRAN(6) .EQ. 0) THEN + CALL GETNOD(N6) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=N6 + N5=NTRAN(5) + N7=NTRAN(7) + CORD(N6,1)=(CORD(N5,1)+CORD(N7,1))/2. + CORD(N6,2)=(CORD(N5,2)+CORD(N7,2))/2. + INEW(N6) = 1 + IF(LOCK(N5) .EQ. 1 .AND. LOCK(N7) .EQ. 1) LOCK(N6)=1 + NTRAN(6)=N6 + WD(N6)=(WD(N5)+WD(N7))/2. + WIDTH(N6)=(WIDTH(N5)+WIDTH(N7))/2. + SS1(N6)=(SS1(N5)+SS1(N7))/2. + SS2(N6)=(SS2(N5)+SS2(N7))/2. + WIDS(N6)=(WIDS(N5)+WIDS(N7))/2. + ENDIF + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + NOP(NEM,1)=NTRAN(1) + NOP(NEM,3)=NTRAN(2) + NOP(NEM,5)=NTRAN(6) + NOP(NEM,7)=NTRAN(7) + IMAT(NEM)=999 + IESKP(NEM)=0 + NCORN(NEM)=8 + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + NOP(NEM,1)=NTRAN(2) + NOP(NEM,3)=NTRAN(3) + NOP(NEM,5)=NTRAN(5) + NOP(NEM,7)=NTRAN(6) + IMAT(NEM)=999 + IESKP(NEM)=0 + NCORN(NEM)=8 + ELSE + CALL GETNOD(N2) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=N2 + CORD(N2,1)=(CORD(NTRAN(1),1)+CORD(NTRAN(3),1) & + & +CORD(NTRAN(5),1)+CORD(NTRAN(7),1))/4. + CORD(N2,2)=(CORD(NTRAN(1),2)+CORD(NTRAN(3),2) & + & +CORD(NTRAN(5),2)+CORD(NTRAN(7),2))/4. + INEW(N2) = 1 + IF(LOCK(NTRAN(1)) .EQ. 1 .AND. LOCK(NTRAN(3)) .EQ. 1 .AND. & + & LOCK(NTRAN(5)) .EQ. 1 .AND. LOCK(NTRAN(7)) .EQ. 1) LOCK(N2)=1 + +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(N2)=-9999. + ELSE + WD(N2) =(WD(NTRAN(1))+WD(NTRAN(3)) & + & +WD(NTRAN(5))+WD(NTRAN(7)))/4. + ENDIF + WIDTH(N2)=0. + SS1(N2)=0. + SS2(N2)=0. + WIDS(N2)=0. + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + NTRAN(9)=N2 + INSKP(N2)=0 + CALL RGEN(NTRAN,NTYP,NRMAT) + ENDIF + ELSE + CALL TGEN(NTRAN,NTYP,NRMAT) + ENDIF + IF(MOD(NN,20) .EQ. 0) THEN +! +! Compress NEF for later use +! + NCT=0 + DO 245 N=1,NENTRY + IF(NEF(N,1) .NE. 0) THEN + NCT=NCT+1 + NEF(NCT,1)=NEF(N,1) + NEF(NCT,2)=NEF(N,2) + NEF(NCT,3)=NEF(N,3) + ENDIF + 245 CONTINUE + NENTRY=NCT + ENDIF + 250 END DO + 255 CONTINUE + IF(ITYP .GT. 2) THEN +!ipk nov97 add (1) + call plotot(1) + NEFL=0 + RETURN + ENDIF +! +! Process the ITYP = 1 or 2 situation +! + IF(ITYP .GT. 0) THEN + CALL CLENUP(ITYP) + ENDIF +! +! Search for left over entries NEF +! + DO 600 I=1,NENTRY + DO 500 N=1,NE + IF(IMAT(N) .EQ. 0) GO TO 500 + NCN=NCORN(N) + +!ipk sep99 add test for line element + + if(ncn .eq. 3) go to 500 +! +! Loop on sides +! + DO 400 K=2,NCN,2 + IF(NOP(N,K-1) .EQ. NEF(I,3)) THEN + KP=MOD(K+1,NCN) + IF(NOP(N,KP) .EQ. ABS(NEF(I,1))) THEN +! +! We have a match, quit search for this entry +! + GO TO 600 + ENDIF + ENDIF + 400 CONTINUE + 500 CONTINUE +! +! No match this must be a boundary eliminate NEF value +! + NEF(I,1)=0 + NEF(I,3)=0 + 600 END DO +! +! Now compress remaining NEF for later use +! + NCT=0 + DO 700 N=1,NENTRY + IF(NEF(N,1) .GT. 0) THEN + NCT=NCT+1 + NEF(NCT,1)=NEF(N,1) + NEF(NCT,2)=NEF(N,2) + NEF(NCT,3)=NEF(N,3) + ENDIF + 700 END DO + NENTRY=NCT + NEFL=0 + RETURN + END +! + SUBROUTINE CLENUP(ITYP) +! +! Clean up transitions on the boundary of the refined area +! +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + DIMENSION NTEMP(9),NTRAN(9),NSWT(8) +! +! First loop through elements looking for transitions +! + IF(ITYP .EQ. 0) THEN + NEO=NE + ELSE + NEO=NEFL + ENDIF +! DO KN=1,NEO +! WRITE(234,*) KN,NEFLAG(KN),NEF(KN,1),NEF(KN,2),NEF(KN,3) +! ENDDO + DO 500 KN=1,NEO + IF(ITYP .EQ. 0) THEN + N=KN + IF(IMAT(N) .EQ. 0) GO TO 500 + ELSE + N=NEFLAG(KN) + ENDIF + NCN=NCORN(N) + +!ipk sep99 add test for line element + + if(ncn .eq. 3) go to 500 +! +! Loop on sides +! + IFND=0 + NSWT(8)=0 + DO 400 K=2,NCN,2 +! +! Search for left over entry in NEF +! + DO 350 I=1,NENTRY + IF(NOP(N,K-1) .EQ. NEF(I,3)) THEN + KP=MOD(K+1,NCN) + IF(NOP(N,KP) .EQ. ABS(NEF(I,1))) THEN +! +! We have a match, start building TEMP +! + NTEMP(K-1)=NEF(I,3) + NTEMP(K)=NEF(I,2) + NSWT(K)=1 + IFND=1 + GO TO 400 + ENDIF + ENDIF + IF(ITYP .GT. 0) THEN + IF(NOP(N,K-1) .EQ. ABS(NEF(I,1))) THEN + KP=MOD(K+1,NCN) + IF(NOP(N,KP) .EQ. NEF(I,3)) THEN +! +! We have a match, start building TEMP +! + NTEMP(K-1)=ABS(NEF(I,1)) + NTEMP(K)=NEF(I,2) + NSWT(K)=1 + IFND=1 + GO TO 400 + ENDIF + ENDIF + ENDIF + 350 CONTINUE +! +! No match copy old values +! + NTEMP(K-1)=NOP(N,K-1) + NTEMP(K)=NOP(N,K) + NSWT(K)=0 + 400 CONTINUE + IF(IFND .EQ. 0) GO TO 500 +! +! Now test for match +! + NTOT=NSWT(2)+NSWT(4)+NSWT(6)+NSWT(8) + IF(NTOT .EQ. 0) GO TO 500 +! +! Delete element +! + DO 420 K=1,8 + NOP(N,K)=0 + 420 CONTINUE + NRMAT=IMAT(N) + IMAT(N)=0 + NELAST=MIN(NELAST,N) +! +! Work with triangles first +! + IF(NCN .EQ. 6) THEN +! +! Determine transition type and prepare to rotate connections +! + IF(NTOT .EQ. 1) THEN + NTYP=3 + IF(NSWT(2) .EQ. 1) THEN + ISHIFT=0 + ELSEIF(NSWT(4) .EQ. 1) THEN + ISHIFT=2 + ELSEIF(NSWT(6) .EQ. 1) THEN + ISHIFT=4 + ENDIF + ELSEIF(NTOT .EQ. 2) THEN + NTYP=2 + IF(NSWT(2) .EQ. 0) THEN + ISHIFT=2 + ELSEIF(NSWT(4) .EQ. 0) THEN + ISHIFT=4 + ELSEIF(NSWT(6) .EQ. 0) THEN + ISHIFT=0 + ENDIF + ELSE + NTYP=1 + ISHIFT=0 + ENDIF +! +! Now rotate so that first mid node is refined +! + DO 430 K=1,NCN + KS=MOD(K+ISHIFT,NCN) + IF(KS .EQ. 0) KS=NCN + NTRAN(K)=NTEMP(KS) + 430 CONTINUE +! +! Now generate transition refined elements +! + CALL TGEN(NTRAN,NTYP,NRMAT) +! +! Now work on quadrilateral elements +! + ELSE +! +! Determine transition type and prepare to rotate connections +! + IF(NTOT .EQ. 1) THEN + NTYP=2 + IF(NSWT(2) .EQ. 1) THEN + ISHIFT=0 + ELSEIF(NSWT(4) .EQ. 1) THEN + ISHIFT=2 + ELSEIF(NSWT(6) .EQ. 1) THEN + ISHIFT=4 + ELSEIF(NSWT(8) .EQ. 1) THEN + ISHIFT=6 + ENDIF + ELSEIF(NTOT .EQ. 2) THEN + IF(NSWT(2) .EQ. 1) THEN + IF(NSWT(4) .EQ. 1) THEN + NTYP=3 + ISHIFT=0 + ELSEIF(NSWT(6) .EQ. 1) THEN + NTYP=4 + ISHIFT=0 + ELSE + NTYP=3 + ISHIFT=6 + ENDIF + ELSEIF(NSWT(4) .EQ. 1) THEN + IF(NSWT(6) .EQ. 1) THEN + NTYP=3 + ISHIFT=2 + ELSEIF(NSWT(8) .EQ. 1) THEN + NTYP=4 + ISHIFT=2 + ENDIF + ELSE + NTYP=3 + ISHIFT=4 + ENDIF + ELSEIF(NTOT .EQ. 3) THEN + NTYP=5 + IF(NSWT(2) .EQ. 0) THEN + ISHIFT=2 + ELSEIF(NSWT(4) .EQ. 0) THEN + ISHIFT=4 + ELSEIF(NSWT(6) .EQ. 0) THEN + ISHIFT=6 + ELSEIF(NSWT(8) .EQ. 0) THEN + ISHIFT=0 + ENDIF + ELSE + NTYP=1 + ISHIFT=0 + ENDIF +! +! Now rotate so that first mid node is refined +! + DO 450 K=1,NCN + KS=MOD(K+ISHIFT,NCN) + IF(KS .EQ. 0) KS=NCN + NTRAN(K)=NTEMP(KS) + 450 CONTINUE +! + IF(NTYP .EQ. 1 .OR. NTYP .EQ. 5) THEN +! +! If appropriate define a new node at the centroid +! + CALL GETNOD(N2) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=N2 + CORD(N2,1)=(CORD(NTEMP(1),1)+CORD(NTEMP(3),1) & + & +CORD(NTEMP(5),1)+CORD(NTEMP(7),1))/4. + CORD(N2,2)=(CORD(NTEMP(1),2)+CORD(NTEMP(3),2) & + & +CORD(NTEMP(5),2)+CORD(NTEMP(7),2))/4. + IF(LOCK(NTEMP(1)) .EQ. 1 .AND. LOCK(NTEMP(3)) .EQ. 1 .AND. & + & LOCK(NTEMP(5)) .EQ. 1 .AND. LOCK(NTEMP(7)) .EQ. 1) LOCK(N2)=1 + INEW(N2) = 1 +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(N2)=-9999. + ELSE + WD(N2)= (WD(NTEMP(1))+WD(NTEMP(3)) & + & +WD(NTEMP(5))+WD(NTEMP(7)))/4. + ENDIF + WIDTH(N2)=0. + SS1(N2)=0. + SS2(N2)=0. + WIDS(N2)=0. + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + NTRAN(9)=N2 + INSKP(N2)=0 +! +! Now generate transition refined elements +! + ENDIF + CALL RGEN(NTRAN,NTYP,NRMAT) + ENDIF + 500 END DO + IF(ITYP .EQ. 0) THEN + NENTRY=0 + ELSE + DO 600 I=1,NENTRY + IF(NEF(I,1) .LT. 0) NEF(I,1)=0 + 600 CONTINUE + ENDIF + RETURN + END +! + SUBROUTINE RGEN(NTRAN,NTYP,NRMAT) +! +! Routine to refine quadrilateral elements +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +! IRGEN contains pointers to the various connections +! + INTEGER*2 IRGEN + DIMENSION NTRAN(9),IRGEN(8,5,5) +! + DATA IRGEN /1,0,2,0,9,0,8,0,3,0,4,0,9,0,2,0,5,0,6,0,9,0,4,0, & + & 7,0,8,0,9,0,6,0,8*0, & + & 1,0,2,0,7,8,0,0,3,4,5,0,2,0,0,0,5,6,7,0,2,0,0,0,16*0, & + & 1,0,2,0,7,8,0,0,3,0,4,0,2,0,0,0,5,6,7,0,4,0,0,0, & + & 7,0,2,0,4,0,0,0,8*0, & + & 1,0,2,0,6,0,7,8,2,0,3,4,5,0,6,0,24*0, & + & 1,0,2,0,9,0,0,0,3,0,4,0,9,0,2,0,5,0,6,0,9,0,4,0, & + & 7,0,9,0,6,0,0,0,7,8,1,0,9,0,0,0/ +! + DO 300 N=1,5 + IF(IRGEN(1,N,NTYP) .EQ. 0) GO TO 310 + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + DO 250 K=1,7,2 + INN=IRGEN(K,N,NTYP) + INP=IRGEN(K+1,N,NTYP) + IF(INN .GT. 0) INN=NTRAN(INN) + IF(INP .GT. 0) INP=NTRAN(INP) + NOP(NEM,K)=INN + NOP(NEM,K+1)=INP + 250 CONTINUE + IF(NOP(NEM,7) .EQ. 0) THEN + NCORN(NEM)=6 + ELSE + NCORN(NEM)=8 + ENDIF + IMAT(NEM)=NRMAT + IESKP(NEM)=0 +!IPK JAN98 + IERC=0 + CALL PLTELM(NEM,IERC) + 300 END DO + 310 CONTINUE + RETURN + END +! + SUBROUTINE TGEN(NTRAN,NTYP,NRMAT) +! +! Routine to refine triangular elements +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +! ITGEN contains pointers to the various connections +! + INTEGER*2 ITGEN + DIMENSION NTRAN(9),ITGEN(8,4,3) +! + DATA ITGEN /1,0,2,0,6,0,0,0,3,0,4,0,2,0,0,0, & + & 5,0,6,0,4,0,0,0,2,0,4,0,6,0,0,0, & + & 1,0,2,0,4,0,5,6,2,0,3,0,4,0,0,0,16*0, & + & 1,0,2,0,5,6,0,0,3,4,5,0,2,0,0,0,16*0/ +! + DO 300 N=1,4 + IF(ITGEN(1,N,NTYP) .EQ. 0) GO TO 310 + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + DO 250 K=1,7,2 + INN=ITGEN(K,N,NTYP) + INP=ITGEN(K+1,N,NTYP) + IF(INN .GT. 0) INN=NTRAN(INN) + IF(INP .GT. 0) INP=NTRAN(INP) + NOP(NEM,K)=INN + NOP(NEM,K+1)=INP + 250 CONTINUE + IF(NOP(NEM,7) .EQ. 0) THEN + NCORN(NEM)=6 + ELSE + NCORN(NEM)=8 + ENDIF + IMAT(NEM)=NRMAT + IESKP(NEM)=0 + IERC=0 + CALL PLTELM(NEM,IERC) + 300 END DO + 310 CONTINUE + RETURN + END + SUBROUTINE SPLIT(N) +! +! Routine to split quadrilateral elements in two +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + DIST(N1,N2)=SQRT((CORD(N1,1)-CORD(N2,1))**2 & + & +(CORD(N1,2)-CORD(N2,2))**2) + if(nop(n,7) .eq. 0) go to 100 +! +! Loop around element looking for longest diagonal +! + L1=NOP(N,1) + L5=NOP(N,5) + D15=DIST(L1,L5) + L3=NOP(N,3) + L7=NOP(N,7) + D37=DIST(L3,L7) + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + IF(D15 .LT. D37) THEN + NOP(NEM,1)=L1 + NOP(NEM,2)=0 + NOP(NEM,3)=L5 + NOP(NEM,4)=NOP(N,6) + NOP(NEM,5)=L7 + NOP(NEM,6)=NOP(N,8) + IMAT(NEM)=IMAT(N) + IESKP(NEM)=0 + NCORN(NEM)=6 + NOP(N,6)=0 + NOP(N,7)=0 + NOP(N,8)=0 + NCORN(N)=6 + ELSE + NOP(NEM,1)=L3 + NOP(NEM,2)=NOP(N,4) + NOP(NEM,3)=L5 + NOP(NEM,4)=NOP(N,6) + NOP(NEM,5)=L7 + NOP(NEM,6)=0 + IMAT(NEM)=IMAT(N) + IESKP(NEM)=0 + NCORN(NEM)=6 + NOP(N,4)=0 + NOP(N,5)=L7 + NOP(N,6)=NOP(N,8) + NOP(N,7)=0 + NOP(N,8)=0 + NCORN(N)=6 + ENDIF + +! call plotot + RETURN + 100 continue +! +! triangle split +! + l1=nop(n,1) + l3=nop(n,3) + l5=nop(n,5) + d13=dist(l1,l3) + d35=dist(l3,l5) + d51=dist(l5,l1) + CALL GETELM(NEM) + NEUNDO=NEUNDO+1 + IELDEL(NEUNDO)=NEM + IMAT(NEM)=IMAT(N) + IESKP(NEM)=0 + NCORN(NEM)=6 + write(90,*) l1,l3,l5,d13,d35,d51,nentry + if(d13 .gt. d35) then + if(d13 .gt. d51) then +! +! Search table for L1 +! + IF(NENTRY .NE. 0) THEN + DO J=1,NENTRY + IF(L1 .EQ. NEF(J,3) .AND. L3 .EQ. NEF(J,1)) THEN +! +! We have found match so use this info +! + NOP(N,2)=NEF(J,2) + NEWND=NEF(J,2) +! +! For regular ops remove value in NEF(J,1) so that it seems blank and s +! otherwise set value negative +! IF(IELGB(2) .EQ. 1) THEN +! NEF(J,1)=0 +! ELSE + NEF(J,1)=-NEF(J,1) +! ENDIF + GO TO 200 + ENDIF + ENDDO + ENDIF +! +! Define a node, enter it, initialize it, and make entry in NEF +! + IF(NOP(N,2) .EQ. 0) THEN + CALL GETNOD(NEWND) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=NEWND + NOP(N,2)=NEWND + CORD(NEWND,1)=(CORD(L1,1)+CORD(L3,1))/2. + CORD(NEWND,2)=(CORD(L1,2)+CORD(L3,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + IF(LOCK(L1) .EQ. 1 .AND. LOCK(L3) .EQ. 1 ) LOCK(NEWND)=1 + + INSKP(NEWND) =0 + ELSE + NEWND=NOP(N,2) + IF(INEW(NEWND) .NE. 1) THEN + CORD(NEWND,1)=(CORD(L1,1)+CORD(L3,1))/2. + CORD(NEWND,2)=(CORD(L1,2)+CORD(L3,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + INSKP(NEWND) =0 + ENDIF + ENDIF +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(NEWND)=-9999. + ELSE + WD(NEWND)=(WD(L1)+WD(L3))/2. + ENDIF + WIDTH(NEWND)=0. + SS1(NEWND)=0. + SS2(NEWND)=0. + WIDS(NEWND)=0. + NENTRY=NENTRY+1 + NEF(NENTRY,1)=L1 + NEF(NENTRY,2)=NEWND + NEF(NENTRY,3)=L3 + 200 CONTINUE + + nop(nem,1)=nop(n,1) + nop(nem,3)=newnd + nop(nem,5)=nop(n,5) + nop(nem,6)=nop(n,6) + nop(n,1)=newnd + nop(n,2)=0 + nop(n,6)=0 + else + +! +! Search table for L5 +! + IF(NENTRY .NE. 0) THEN + DO J=1,NENTRY + IF(L5 .EQ. NEF(J,3) .AND. L1 .EQ. NEF(J,1)) THEN +! +! We have found match so use this info +! + NOP(N,2)=NEF(J,2) + NEWND=NEF(J,2) +! +! For regular ops remove value in NEF(J,1) so that it seems blank and s +! otherwise set value negative +! IF(IELGB(2) .EQ. 1) THEN +! NEF(J,1)=0 +! ELSE + NEF(J,1)=-NEF(J,1) +! ENDIF + GO TO 300 + ENDIF + ENDDO + ENDIF +! +! Define a node, enter it, initialize it, and make entry in NEF +! + IF(NOP(N,6) .EQ. 0) THEN + CALL GETNOD(NEWND) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=NEWND + NOP(N,6)=NEWND + CORD(NEWND,1)=(CORD(L5,1)+CORD(L1,1))/2. + CORD(NEWND,2)=(CORD(L5,2)+CORD(L1,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + IF(LOCK(L1) .EQ. 1 .AND. LOCK(L5) .EQ. 1) LOCK(NEWND)=1 + INSKP(NEWND) =0 + ELSE + NEWND=NOP(N,6) + IF(INEW(NEWND) .NE. 1) THEN + CORD(NEWND,1)=(CORD(L5,1)+CORD(L1,1))/2. + CORD(NEWND,2)=(CORD(L5,2)+CORD(L1,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + INSKP(NEWND) =0 + ENDIF + ENDIF +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(NEWND)=-9999. + ELSE + WD(NEWND)=(WD(L5)+WD(L1))/2. + ENDIF + WIDTH(NEWND)=0. + SS1(NEWND)=0. + SS2(NEWND)=0. + WIDS(NEWND)=0. + NENTRY=NENTRY+1 + NEF(NENTRY,1)=L5 + NEF(NENTRY,2)=NEWND + NEF(NENTRY,3)=L1 + 300 CONTINUE + + nop(nem,1)=nop(n,1) + nop(nem,2)=nop(n,2) + nop(nem,3)=nop(n,3) + nop(nem,5)=newnd + nop(n,1)=newnd + nop(n,2)=0 + nop(n,6)=0 + endif + elseif(d35 .gt. d51) then + +! +! Search table for L3 +! + IF(NENTRY .NE. 0) THEN + DO J=1,NENTRY + IF(L3 .EQ. NEF(J,3) .AND. L5 .EQ. NEF(J,1)) THEN +! +! We have found match so use this info +! + NOP(N,4)=NEF(J,2) + NEWND=NEF(J,2) +! +! For regular ops remove value in NEF(J,1) so that it seems blank and s +! otherwise set value negative +! IF(IELGB(2) .EQ. 1) THEN +! NEF(J,1)=0 +! ELSE + NEF(J,1)=-NEF(J,1) +! ENDIF + GO TO 400 + ENDIF + ENDDO + ENDIF +! +! Define a node, enter it, initialize it, and make entry in NEF +! + IF(NOP(N,4) .EQ. 0) THEN + CALL GETNOD(NEWND) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=NEWND + NOP(N,4)=NEWND + CORD(NEWND,1)=(CORD(L3,1)+CORD(L5,1))/2. + CORD(NEWND,2)=(CORD(L3,2)+CORD(L5,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + IF(LOCK(L3) .EQ. 1 .AND. LOCK(L5) .EQ. 1) LOCK(NEWND)=1 + INSKP(NEWND) =0 + ELSE + NEWND=NOP(N,4) + IF(INEW(NEWND) .NE. 1) THEN + CORD(NEWND,1)=(CORD(L3,1)+CORD(L5,1))/2. + CORD(NEWND,2)=(CORD(L3,2)+CORD(L5,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + INSKP(NEWND) =0 + ENDIF + ENDIF +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(NEWND)=-9999. + ELSE + WD(NEWND)=(WD(L3)+WD(L5))/2. + ENDIF + WIDTH(NEWND)=0. + SS1(NEWND)=0. + SS2(NEWND)=0. + WIDS(NEWND)=0. + NENTRY=NENTRY+1 + NEF(NENTRY,1)=L3 + NEF(NENTRY,2)=NEWND + NEF(NENTRY,3)=L5 + 400 CONTINUE + + nop(nem,1)=nop(n,1) + nop(nem,2)=nop(n,2) + nop(nem,3)=nop(n,3) + nop(nem,5)=newnd + nop(n,3)=newnd + nop(n,2)=0 + nop(n,4)=0 + else + +! +! Search table for L5 +! + IF(NENTRY .NE. 0) THEN + DO J=1,NENTRY + IF(L5 .EQ. NEF(J,3) .AND. L1 .EQ. NEF(J,1)) THEN +! +! We have found match so use this info +! + NOP(N,2)=NEF(J,2) + NEWND=NEF(J,2) +! +! For regular ops remove value in NEF(J,1) so that it seems blank and s +! otherwise set value negative +! IF(IELGB(2) .EQ. 1) THEN +! NEF(J,1)=0 +! ELSE + NEF(J,1)=-NEF(J,1) +! ENDIF + GO TO 500 + ENDIF + ENDDO + ENDIF +! +! Define a node, enter it, initialize it, and make entry in NEF +! + IF(NOP(N,6) .EQ. 0) THEN + CALL GETNOD(NEWND) + NPUNDO=NPUNDO+1 + NODDEL(NPUNDO)=NEWND + NOP(N,6)=NEWND + CORD(NEWND,1)=(CORD(L5,1)+CORD(L1,1))/2. + CORD(NEWND,2)=(CORD(L5,2)+CORD(L1,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + IF(LOCK(L1) .EQ. 1 .AND. LOCK(L5) .EQ. 1) LOCK(NEWND)=1 + INSKP(NEWND) =0 + ELSE + NEWND=NOP(N,6) + IF(INEW(NEWND) .NE. 1) THEN + CORD(NEWND,1)=(CORD(L5,1)+CORD(L1,1))/2. + CORD(NEWND,2)=(CORD(L5,2)+CORD(L1,2))/2. + XUSR(NEWND) = CORD(NEWND,1)*TXSCAL - XS + YUSR(NEWND) = CORD(NEWND,2)*TXSCAL - YS + INEW(NEWND) = 1 + INSKP(NEWND) =0 + ENDIF + ENDIF +!ipk jan98 + IF(IDELV .EQ. 1) then + WD(NEWND)=-9999. + ELSE + WD(NEWND)=(WD(L5)+WD(L1))/2. + ENDIF + WIDTH(NEWND)=0. + SS1(NEWND)=0. + SS2(NEWND)=0. + WIDS(NEWND)=0. + NENTRY=NENTRY+1 + NEF(NENTRY,1)=L5 + NEF(NENTRY,2)=NEWND + NEF(NENTRY,3)=L1 + 500 CONTINUE + + nop(nem,1)=nop(n,1) + nop(nem,2)=nop(n,2) + nop(nem,3)=nop(n,3) + nop(nem,5)=newnd + nop(n,1)=newnd + nop(n,2)=0 + nop(n,6)=0 + endif + return + END + SUBROUTINE REVERS(N1,N2) +! +! Routine to reverse diagonal of two quadrilateral elements +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! +! Search for common nodes on the elements +! + DO 300 M=1,NCORN(N1),2 + J=NOP(N1,M) + DO 250 MM=1,NCORN(N2),2 + JJ=NOP(N2,MM) + IF(JJ .EQ. J) THEN +! +! We have a match find the other nodes around element +! + MID1=M+1 + JMID1=NOP(N1,MID1) + write(90,*) n1,mid1,jmid1 + MID2=M+3 + IF(M .EQ. 5) MID2=2 + JMID2=NOP(N1,MID2) + MID3=M+5 + IF(MID3 .GT. 6) MID3=MID3-6 + JMID3=NOP(N1,MID3) +! +! Now find the other node +! + M1=M+2 + IF(M1 .GT. 6) M1=1 + J1=NOP(N1,M1) + MM1=MM-2 + IF(MM1 .LT. 1) MM1=5 + JJ1=NOP(N2,MM1) + IF(J1 .EQ. JJ1) THEN +! +! We have the other match find nodes around the element +! + MID4=MM+1 + JMID4=NOP(N2,MID4) + MID5=MM+3 + IF(MM .EQ. 5) MID5=2 + JMID5=NOP(N2,MID5) + M2=9-M-M1 + MM2=9-MM-MM1 + J2=NOP(N1,M2) + JJ2=NOP(N2,MM2) + NOP(N1,1)=J2 + NOP(N1,2)=JMID3 + NOP(N1,3)=J + NOP(N1,4)=JMID4 + NOP(N1,5)=JJ2 + NOP(N1,6)=JMID1 + NOP(N2,1)=JJ2 + NOP(N2,2)=JMID5 + NOP(N2,3)=J1 + NOP(N2,4)=JMID2 + NOP(N2,5)=J2 + NOP(N2,6)=JMID1 + write(90,*) (nop(n1,i),i=1,6) + write(90,*) (nop(n2,i),i=1,6) + if(jmid1 .gt. 0) then + CORD(JMID1,1) = (CORD(J2,1)+CORD(JJ2,1))/2.0 + CORD(JMID1,2) = (CORD(J2,2)+CORD(JJ2,2))/2.0 + XUSR(JMID1) = CORD(JMID1,1)*TXSCAL - XS + YUSR(JMID1) = CORD(JMID1,2)*TXSCAL - YS + IF(NECON(JMID2,1) .EQ. N1) NECON(JMID2,1)=N2 + IF(NECON(JMID2,2) .EQ. N1) NECON(JMID2,2)=N2 + IF(NECON(JMID4,1) .EQ. N2) NECON(JMID4,1)=N1 + IF(NECON(JMID4,2) .EQ. N2) NECON(JMID4,2)=N1 + endif + GO TO 350 + ENDIF + ENDIF + 250 CONTINUE + 300 END DO + 350 CONTINUE +! CALL PLOTOT + RETURN + END diff --git a/src/src83e/REGSTR.F90 b/src/src83e/REGSTR.F90 new file mode 100644 index 0000000..c7c4238 --- /dev/null +++ b/src/src83e/REGSTR.F90 @@ -0,0 +1,345 @@ +! Last change: IPK 24 Aug 2001 3:08 pm + SUBROUTINE REGISTR(I) + USE BLK1MOD +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' + + CALL SLPOINT(A1,B1,A2,B2,C1,D1,C2,D2,N) +! +! A1 = X CORD OF DESIRED WORLD-1 +! B1 = Y CORD OF DESIRED WORLD-1 +! A2 = X CORD OF DESIRED WORLD-2 +! B2 = X CORD OF DESIRED WORLD-2 +! C1 = X CORD OF INPUT WORLD-1 +! D1 = Y CORD OF INPUT WORLD-1 +! C2 = X CORD OF INPUT WORLD-2 +! D2 = X CORD OF INPUT WORLD-2 + + IF(N .EQ. 1) THEN + +! Compute new locations + + SCALEER= (A2-A1)/(C2-C1) + ASIZ=(BFMINMAX(I,3)-BFMINMAX(I,1))*SCALEER + FLEFT=(C1-BFMINMAX(I,1))/(BFMINMAX(I,3)-BFMINMAX(I,1)) + XNEW1=A1-FLEFT*ASIZ + XNEW2=XNEW1+ASIZ + WRITE(90,*) 'X-SCAL',SCALEER,ASIZ,FLEFT,XNEW1,XNEW2 + SCALEER= (B2-B1)/(D2-D1) + BSIZ=(BFMINMAX(I,4)-BFMINMAX(I,2))*SCALEER + FBEL=(D1-BFMINMAX(I,2))/(BFMINMAX(I,4)-BFMINMAX(I,2)) + YNEW1=B1-FBEL*BSIZ + YNEW2=YNEW1+BSIZ + WRITE(90,*) 'Y-SCAL',SCALEER,BSIZ,FBEL,YNEW1,YNEW2 + +! Confirm that they are acceptable + + CALL DISPREG(BFMINMAX(I,1),BFMINMAX(I,2),BFMINMAX(I,3),BFMINMAX(I,4),XNEW1,YNEW1,XNEW2,YNEW2,NN) + WRITE(90,*) 'AFTER DIS',NN,XNEW1,YNEW1,XNEW2,YNEW2 + +! Store them in the appropriate array + + IF(NN .EQ. 1) THEN + BFMINMAX(I,1)=XNEW1 + BFMINMAX(I,2)=YNEW1 + BFMINMAX(I,3)=XNEW2 + BFMINMAX(I,4)=YNEW2 + ELSE + RETURN + ENDIF + +! Save them if they are wanted + + CALL SAVORG(I,1) + + ENDIF + + RETURN + END SUBROUTINE + +! Display selected origins + + SUBROUTINE DISPREG(A1,B1,A2,B2,C1,D1,C2,D2,NN) + +! This subroutine gets points +! + USE WINTERACTER + + IMPLICIT NONE +! +! Define some parameters to match those in the resource file +! + include 'd.inc' +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: N,IBOX,NN + INTEGER :: IERR + REAL :: A1,B1,A2,B2,C1,D1,C2,D2 + CHARACTER*1 :: IFLAG + + + + call wdialogload(IDD_CONFIRM) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_CONFIRM) + ierr=infoerror(1) + + CALL WDialogPutReal(IDF_REAL1,A1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL2,B1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL5,A2,'(F8.0)') + CALL WDialogPutReal(IDF_REAL6,B2,'(F8.0)') + CALL WDialogPutReal(IDF_REAL3,C1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL4,D1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL7,C2,'(F8.0)') + CALL WDialogPutReal(IDF_REAL8,D2,'(F8.0)') + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + +! Branch depending on type of message. +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + NN=1 + CALL WDialogGetReal(IDF_REAL1,A1) + CALL WDialogGetReal(IDF_REAL2,B1) + CALL WDialogGetReal(IDF_REAL5,A2) + CALL WDialogGetReal(IDF_REAL6,B2) + CALL WDialogGetReal(IDF_REAL3,C1) + CALL WDialogGetReal(IDF_REAL4,D1) + CALL WDialogGetReal(IDF_REAL7,C2) + CALL WDialogGetReal(IDF_REAL8,D2) + RETURN + ELSEIF(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + NN=0 + RETURN + ENDIF +!ipk sep02 + NN=0 + RETURN + ENDDO + RETURN + END + +! Select points + + SUBROUTINE SLPOINT(A1,B1,A2,B2,C1,D1,C2,D2,NN) +! +! This subroutine gets points +! + USE WINTERACTER + + IMPLICIT NONE +! +! +! Define some parameters to match those in the resource file +! + include 'd.inc' + + INTEGER :: NP,NE,NHTP,NMESS,NBRR,IPSW,IRMAIN,ISCRN,icolon,IQSW,IRDISP,ntempin,IGFGSW,IGFGSWB,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL +! + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER :: N,IBOX,NN + INTEGER :: IERR +!IPK MAY02 + REAL :: A1,B1,A2,B2,C1,D1,C2,D2,XX,YY + CHARACTER*1 :: IFLAG + + + call wdialogload(IDD_SLRGNO) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_SLRGNO) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,N) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + +! Branch depending on type of message. +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,N) + GO TO 150 + ENDIF +!ipk sep02 + RETURN + ENDDO + 150 CONTINUE + + NHTP=0 + NBRR=3 + NMESS=43 + CALL HEDR + WRITE(90,*) 'BACK FROM HEDR' + IF(N .EQ. 1) THEN + CALL XYLOC(XX,YY,iflag,ibox) + C1 = XX*TXSCAL - XS + D1 = YY*TXSCAL - YS + WRITE(90,*) 'BACK FROM XYLOC-1',C1,D1,IBOX,IFLAG + ELSE + CALL XYLOC(XX,YY,iflag,ibox) + C2 = XX*TXSCAL - XS + D2 = YY*TXSCAL - YS + WRITE(90,*) 'BACK FROM XYLOC-2',C2,D2,IBOX,IFLAG + ENDIF + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + CALL WRTOUT(0) + RETURN + ENDIF + + call wdialogload(IDD_REGST) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_REGST) + ierr=infoerror(1) + + CALL WDialogPutReal(IDF_REAL1,A1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL2,B1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL3,A2,'(F8.0)') + CALL WDialogPutReal(IDF_REAL4,B2,'(F8.0)') + CALL WDialogPutReal(IDF_REAL5,C1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL6,D1,'(F8.0)') + CALL WDialogPutReal(IDF_REAL7,C2,'(F8.0)') + CALL WDialogPutReal(IDF_REAL8,D2,'(F8.0)') + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + +! Branch depending on type of message. +! + IF (WInfoDialog(ExitButton) .EQ. IDADJUST) THEN + + CALL WDialogGetReal(IDF_REAL1,A1) + CALL WDialogGetReal(IDF_REAL2,B1) + CALL WDialogGetReal(IDF_REAL3,A2) + CALL WDialogGetReal(IDF_REAL4,B2) + CALL WDialogGetReal(IDF_REAL5,C1) + CALL WDialogGetReal(IDF_REAL6,D1) + CALL WDialogGetReal(IDF_REAL7,C2) + CALL WDialogGetReal(IDF_REAL8,D2) + NN=1 + RETURN + ELSEIF (WInfoDialog(ExitButton) .EQ. IDFSWITCH) THEN + + CALL WDialogGetReal(IDF_REAL1,A1) + CALL WDialogGetReal(IDF_REAL2,B1) + CALL WDialogGetReal(IDF_REAL3,A2) + CALL WDialogGetReal(IDF_REAL4,B2) + CALL WDialogGetReal(IDF_REAL5,C1) + CALL WDialogGetReal(IDF_REAL6,D1) + CALL WDialogGetReal(IDF_REAL7,C2) + CALL WDialogGetReal(IDF_REAL8,D2) + IF(N .EQ. 1) THEN + N=2 + ELSE + N=1 + ENDIF + GO TO 150 + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + NN=0 + RETURN + ENDIF +!IPK SEP02 + NN=0 + RETURN + ENDDO + RETURN + END + + + SUBROUTINE SAVORG(NN,III) + +! This subroutine askf to check first then saves ORG file data +! + USE WINTERACTER + + IMPLICIT NONE +! +! Define some parameters to match those in the resource file +! + include 'd.inc' +! +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INCLUDE 'BFILES.I90' + CHARACTER(LEN=256) :: FILTER + + INTEGER :: NN,I,III + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + INTEGER :: INFO(3) + REAL :: XSIZ,YSIZ + IF(III .EQ. 1) THEN + CALL WMessageBox(YesNo,QuestionIcon,CommonOK, 'Do you wish to '// & + 'save locations as ORG or JPGW file?', 'SAVE ORG/JPGW FILE') +! +! If answer 'NO', return +! + IF (WInfoDialog(4) .EQ. 2) RETURN + ENDIF + +! Otherwise process + call IGrFileInfo(BFNAME(NN),INFO,3) + + FILTER ="Registration Files|*.org;*.jpgw|ORG file -- *.org|*.org|JPGW file -- *.jpgw|*.jpgw|" + + CALL WSelectFile(FILTER,SaveDialog+PromptOn+AppendExt,FNAME,'Save ORG/JPGW File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + +! SUB='org' + OPEN(104,FILE=FNAME,STATUS ='UNKNOWN', FORM ='FORMATTED') + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + if(sub .eq. 'jpg') then + XSIZ=(BFMINMAX(NN,3)-BFMINMAX(NN,1))/FLOAT(INFO(2)) + YSIZ=(BFMINMAX(NN,2)-BFMINMAX(NN,4))/FLOAT(INFO(3)) + WRITE(104,*) XSIZ + WRITE(104,*) ' 0.0' + WRITE(104,*) ' 0.0' + WRITE(104,*) YSIZ + WRITE(104,*) BFMINMAX(NN,1) + WRITE(104,*) BFMINMAX(NN,4) + CLOSE(104) + else +! CALL ADDSUB(FNAME,SUB) +! OPEN(104,FILE=FNAME,STATUS ='UNKNOWN', FORM ='FORMATTED') + WRITE(104,'(4G16.8)') (BFMINMAX(NN,I),I=1,4) + CLOSE(104) + endif + ENDIF + + RETURN + END \ No newline at end of file diff --git a/src/src83e/REORD.F90 b/src/src83e/REORD.F90 new file mode 100644 index 0000000..edc863b --- /dev/null +++ b/src/src83e/REORD.F90 @@ -0,0 +1,1049 @@ +!IPK LAST UPDATE SEP 23 2015 ADD TESTING FOR REORDERING + SUBROUTINE ORDALL + + INCLUDE 'BFILES.I90' + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + + ISWALL=1 + nmess=45 + + CALL GETINT(ISWALL) + IF(ISWALL .EQ. 0) ISWALL=1 + ISW=0 + CALL REORD(ISW,ISWALL) + CALL WMessageBox(0,4,1,'REORDERING COMPLETE',' ') + + IRDONE=1 + + RETURN + + END + + + +!IPK LAST UPDATE JULY 11 2005 FIX BUG IN REORDERING +!ipk last update Nov 18 1996 +! Last change: IPK 12 Jan 98 2:06 pm +!ipk last update Jan 6 1997 disallow negative sums + SUBROUTINE ADDORD(ISW) +! +! Enter reordering sequence +! + USE WINTERACTER + USE BLK1MOD + INCLUDE 'BFILES.I90' + +! INCLUDE 'BLK1.COM' +!iPK APR94 + COMMON /RECOD/ IRECD,TSPC +! dimension ilisttmp(100) +! + CHARACTER*1 IFLAG + CHARACTER*14 HEADR + CHARACTER*60 STRELS + CHARACTER*80 LIND +! INTEGER*2 IPAG,NT + DATA MULTPG/0/ + DATA STRELS/' You have tried to reorder before executing "FILL"'/ + DATA XPRT/0./ +! +! Test to make sure fill has been executed. +! + IF(ISW .NE. 1) THEN + DO 70 N=1,NE + IF(IMAT(N) .GT. 0) THEN + DO 60 M=2,NCORN(N),2 +!ipkoct93 + if(imat(n) .gt. 900) go to 60 + IF(NOP(N,M) .EQ. 0) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK, & + 'You have tried to reorder before executing "FILL"'//CHAR(13) & + //'Reordering terminated',& + 'UNABLE TO REORDER') +! CALL SYMBL(0.,7.30,0.20,STRELS,0.,60) + RETURN + ENDIF + 60 CONTINUE + ENDIF + 70 CONTINUE + ENDIF +! +! + IF(ISW .EQ. 0) THEN +! +! Change screens if possible +! + IF(MULTPG .EQ. 1) THEN +! IPAG=1 +! NT=SETACTIVEPAGE(IPAG) +! NT=SETVISUALPAGE(IPAG) + ELSE + CALL CLSCRN + CALL SETD(23) + ENDIF + ISWW=0 + CALL WCursorShape(CurHourGlass ) + ISWALL=0 + CALL REORD(ISWW,ISWALL) + IRDONE=1 +!IPK AUG05 CALL REORD(ISWW) + CALL WCursorShape(CurArrow ) +! +! Restore screen +! +!pk jan98 WRITE(*,*) 'Press "Return" to restore grapical screen' + + CALL SHOWORD +! WRITE(LIND,6002) +! 6002 FORMAT( 'Press "Return" to restore grapical screen') +! call rblue +! call symbl & +! & (1.1,3.0,0.20,LIND,0.0,80) +! ndig=1 +! CALL GTCHARX(IFLAG,NDIG,5.0,7.6) + +!ipk jan98 READ(*,'(A)') IFLAG + IF(MULTPG .EQ. 1) THEN + IPAG=0 +! NT=SETACTIVEPAGE(IPAG) +! NT=SETVISUALPAGE(IPAG) + ELSE + CALL CLSCRN + CALL SETD(2) +! CALL PLOTS(0) +!ipk nov97 add (1) + CALL PLOTOT(1) + do n=1,ne + nn=iem(n) + if(imat(nn) .ne. 0 .AND. IESKP(NN) .EQ. 0) then + + call fillemC(nn,MOD(N/25,15)) + endif +! if(mod(n,200) .eq. 0) then +! READ(*,'(A)') IFLAG +! endif + enddo + ENDIF + ELSEIF(ISW .EQ. 1) THEN + 100 continue +! 100 WRITE(HEADR,5000) NLST +! 5000 FORMAT(' NLIST = ',I5) +! NHTP = 0 +! NMESS = 13 +! NBRR = 0 +! CALL HEDR +! CALL SYMBL(0.,7.50,0.20,HEADR,0.,14) +! XPRT=3.2 +! +! Form element reordering list by clicking on elements with cursor +! + 5001 FORMAT(I10) +! CALL GETINT(NLIST) +! READ(*,5001,ERR=220) NLIST +! +! Find element nearest cursor +! + J=0 + 200 IBOX=1 + NMESS = 12 + NBRR = 9 + CALL HEDR + CALL PLOTORDS + INREORD=1 + CALL PROX(XC,YC,NE,XX,YY,IELEM,IFLAG,IESKP,IBOX) + INREORD=0 + CALL PLOTORDS +! write(90,*) 'reord' +! write(90,'(i10,a10)') ibox,iflag + IF(IRMAIN .EQ. 1) THEN + DO J=1,100 + ilisttmp (j)=0 + ENDDO + RETURN + ENDIF + 210 IF(IFLAG .EQ. 'c' .and. ibox .ne. 7) THEN + CALL FILLEM(IELEM) + XPRT=XPRT+0.5 + IF(XPRT .GT. HSIZE) XPRT=0. + FPN= IELEM + CALL NUMBR(XPRT,7.20,0.20,FPN,0.0,-1) + J=J+1 + ilisttmp (j)=ielem +! ILIST(NLIST,J)=IELEM + GO TO 200 + ELSEIF (IFLAG .EQ. 'U') THEN + ilisttmp (j)=0 + J=J-1 + CALL PLOTOT(1) + CALL HEDR + DO IELEM=1,J + CALL FILLEM(ILISTTMP(IELEM)) + ENDDO + GO TO 200 + ELSEIF(IFLAG .EQ. 'e') THEN +! LLIST(NLIST)=J + nlist=nlst+1 + call getnlist(nlist) + LLIST(NLIST)=J + do i=1,j + ilist(nlist,i)=ilisttmp(i) + enddo + IF(NLIST .GT. NLST) NLST=NLIST + DO J=1,100 + ilisttmp (j)=0 + ENDDO + GO TO 100 + ELSEIF(IFLAG .EQ. 'a' .or. ibox .eq. 7) THEN + nlist=nlst+1 + IF(IRECD .NE.2) call getnlist(nlist) + LLIST(NLIST)=J + do i=1,j + ilist(nlist,i)=ilisttmp(i) + enddo + IF(NLIST .GT. NLST) NLST=NLIST + DO J=1,100 + ilisttmp (j)=0 + ENDDO + GO TO 100 + ELSEIF(IFLAG .EQ. 'q') THEN +! LLIST(NLIST)=J +! IF(NLIST .GT. NLST) NLST=NLIST +! CALL REORD(NLIST) +! CALL WRTOUT(0) + DO J=1,100 + ilisttmp (j)=0 + ENDDO + ENDIF + ELSEIF(ISW .EQ. 2) THEN +! +! Change screens if possible +! + IF(MULTPG .EQ. 1) THEN + IPAG=1 +! NT=SETACTIVEPAGE(IPAG) +! NT=SETVISUALPAGE(IPAG) + ELSE + CALL CLSCRN + CALL SETD(23) + ENDIF + ISWW=NLIST + ISWALL=0 + CALL REORD(ISWW,ISWALL) +!IPK AUG05 CALL REORD(ISWW) +! +! Restore screen +! +!IPK JAN98 WRITE(*,*) 'Press "Return" to restore grapical screen' +!IPK JAN98 READ(*,'(A)') IFLAG + CALL SHOWORD +! WRITE(LIND,6002) +! call symbl & +! & (1.1,3.0,0.20,LIND,0.0,80) +! ndig=1 +! CALL GTCHARX(IFLAG,NDIG,5.0,7.6) + IF(MULTPG .EQ. 1) THEN + IPAG=0 +! NT=SETACTIVEPAGE(IPAG) +! NT=SETVISUALPAGE(IPAG) + ELSE + CALL CLSCRN + CALL SETD(2) +! CALL PLOTS(0) +!ipk nov97 add (1) + CALL PLOTOT(1) + ENDIF + ENDIF + 220 RETURN + END + SUBROUTINE REORD (ISW,ISWALL) +! +! DRIVING ROUTINE TO REORDER ELEMENTS +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! INITIALIZE +! + IF(IECHG .EQ. 0) THEN + NCM=MAXECON + NCMI=MAXECON + NAD=0 + MP=0 + IPASS=1 +! +! GET TABLE OF ELEMENT CONNECTIONS +! + CALL KCON(0) +! +! SETUP NELIM. IDENTIFIES 3 NODE ELEMENTS OR JUNCTIONS WHEN = 1 +! + DO 250 N=1,NE + IF(IMAT(N) .NE. 0) THEN +!ipkoct93 + IF(NCORN(N) .EQ. 3 .OR. (IMAT(N) .GT. 900 .and. & + & ncorn(n) .ne. 8)) THEN + NELIM(N)=1 + ELSE + NELIM(N)=0 + ENDIF + ELSE + NELIM(N)=1 + ENDIF + 250 CONTINUE + IECHG=1 +!IPK MAY03 + ICHG=0 + +! +! PROCESS INITIAL ORDER +! + IF(ISW .EQ. 0) THEN + CALL ORDER(ISWALL) + ISW=ISW+1 + ENDIF + ENDIF + IF(ISW .EQ. 0) ISW=1 +! +! OTHERWISE RESET MLIST +! + 305 DO 310 N=1,NAE + MLIST(N)=0 + 310 END DO +! +! SET STARTING SEQUENCE +! + +!IPK AUG05 + IF(ISWALL .EQ. 0) THEN + + NN=1 + DO 320 N=1,NAE + MLIST(NN)=ILIST(ISW,N) + IF(NN .GT. 1) THEN + IF(MLIST(NN) .EQ. MLIST(NN-1)) THEN + NN=NN-1 + ENDIF +!IPK JUL05 FIX BUG MOVE DOWN NN=NN+1 + ENDIF + NN=NN+1 +! write(90,*) 'Entries forming start of list',n,mlist(n) + IF(MLIST(N) .EQ. 0) GO TO 325 + 320 END DO + ELSE + 322 CONTINUE + IF(MOD(ISW,ISWALL) .EQ. 0) THEN + MLIST(1)=ISW + ELSE + ISW=ISW+1 + GO TO 322 + ENDIF + + ENDIF +! + 325 MP=0 + NAD=0 +! +! RESET NODE TO ELEMENT LIST +! + DO 340 N=1,NP + DO 335 M=1,NCM + IF(NECON(N,M) .EQ. 0) GO TO 338 + 335 CONTINUE + 338 NDELM(N)=M-1 + 340 END DO +! +! RESET ELEMENT CONNECTIONS +! + DO 350 N=1,NE + DO 350 M=1,NCMI + ICON(N,M)=IABS(ICON(N,M)) + 350 CONTINUE +! +! GO TO PROCESS THIS SEQUENCE +! + IF(MLIST(1) .GT. 0) THEN + CALL ORDER(ISWALL) + ISW=ISW+1 + ELSE + GO TO 600 + ENDIF + IF(ISWALL .EQ. 0) THEN + IF(ISW .GT. NLST) GO TO 600 + ELSE + WRITE(90,*) MLIST(1),MTSUMSV(NSEQ),NFWSV(NSEQ),IEM(1),MRSUM + + IF(ISW .GT. NE) GO TO 600 + ENDIF + GO TO 305 +! +! PRINT FINAL ORDER +! + 600 WRITE(90,6040) (IEM(K),K=1,NAE) + 6040 FORMAT(//' SELECTED ELEMENT ORDER'/(10I6)) +! +! RETURN TO MAIN +! + RETURN + END + SUBROUTINE ORDER(ISWALL) +! +! FIND ORDER AND FRONT SUM FOR A GIVEN START POINT +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! SET LIST OF INCORPORATED NODES +! + DO 200 N=1,NP + 200 NINC(N)=0 +! +! SET COUNTER ON ELEMENTS +! + KNT=0 + MTSUM=0 +!ipk feb97 add mtsum1 + mtsum1=0 +!IPK MAY94 LINE ADDED + NFWSAV=0 +! +! PROCESS THROUGH ELEMENTS +! + 300 CONTINUE +! +! SET MLIST FROM INPUT IF NON-ZERO WE MUST FIND KREC +! + KREC=MLIST(KNT+1) +! +! GET NEXT ELEMENT TO ADDED +! + CALL MOVFNT(KREC,ISWALL) + +!ipk mar04 + IF(KREC .lt. 0) THEN + write(90,*) 'krec',knt,mlist(knt) + MTSUM=9999999999999 + MTSUM1=9999999999999 + GO TO 310 + ENDIF +! +! SAVE SELECTED VALUE +! + MLIST(KNT+1)=KREC + KNT=KNT+1 +! +! UPDATE FRONT AND CONNECTION TABLES +! + CALL UPFNT(KREC) +! WRITE(91,9000) KREC,MTSUM,MSUM,MP,NAD +! 9000 FORMAT(' KREC MTSUM MSUM MP NAD'/I6,2I15,2I5) +! +! TEST FOR FULL SET OF ELEMENTS +! + IF (KNT.LT.NAE) GO TO 300 +! +! FOR COMPLETE ORDER CHECK IF IT IS IMPROVEMENT +! +!IPK MAR04 + 310 CONTINUE + CALL CHKOUT(ISWALL) +! +! FINISHED +! + RETURN + END + SUBROUTINE MOVFNT(KREC,ISWALL) +! +! GET ELEMENT THAT INCREASES FRONT WIDTH LEAST +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INTEGER*8 MSAV,MSA + CHARACTER*80 LIND + CHARACTER*1 JUNK +! +! INITIALIZE +! + MSAV=99999999 + NSN=99999 +! +! SKIP IF KREC ALREADY DEFINED +! + IF(KREC .GT. 0) GO TO 310 +! +! SEARCH ADJACENT ELEMENTS +! + NTST=NITST + 260 NFD=0 + if(nad .eq. 0) then +!IPK JAN98 write(*,*) 'nad in trouble type q and press return,enxt(1)',enxt(1) +!IPK JAN98 read(*,*) njunk +!ipk mar04 WRITE(LIND,6002)krec,nsn +!ipk mar04 6002 FORMAT( 'NAD =0 illegal connection. krec,nsn',2i5,'Type q to exit') +!ipk mar04 call symbl & +!ipk mar04 & (1.1,3.0,0.20,LIND,0.0,80) +!ipk mar04 ndig=1 +!ipk mar04 CALL GTCHARX(JUNK,NDIG,5.0,7.6) +!ipk mar04 stop + IF(ISWALL .GT. 0) THEN + KREC=-1 + RETURN + ENDIF + write(90,*) nae + write(90,'(5(i7,i6))') (n,mlist(n),n=1,ne) + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK, & + 'No active adjacent elements found '//CHAR(13) & + //'Possible network error.'//CHAR(13) & + //'or erroneous starting element'//CHAR(13) & + //'Reordering terminated',& + 'ERROR') + krec=-1 + return + endif + DO 300 K=1,NAD + NEL=ENXT(K) + IF(NTST .EQ. 0) GO TO 270 + IF(NELIM(NEL) .EQ. 1) GO TO 300 + 270 CONTINUE + NFD=1 +! +! GET SUMS FOR NEL +! + CALL SUMIT(NEL) +! +! MSA IS THE AVERAGE PER NODE ADDED +! + MSA=MSUM +! MSA=9999999 + IF(NDP .GT. 1) MSA=(MSUM+NDP/2)/NDP +! +! CHECK IF IT IS LESS +! + IF (MSA.GT.MSAV) GO TO 300 + IF (MSA.LT.MSAV) GO TO 280 +! +! IF EQUAL TAKE CASE WITH LEAST NODES ADDED +! + IF (NDP.GE.NSN) GO TO 300 + 280 KREC=NEL + NSN=NDP + MSAV=MSA + 300 END DO + IF(NFD .EQ. 0) THEN + NTST=0 + GO TO 260 + ENDIF + 310 CONTINUE +! +! GET INFORMATION AGAIN FOR SELECTED ELEMENT +! + CALL SUMIT(KREC) +!IPK MAY94 ADD A LINE + IF(NFWS .GT. NFWSAV) NFWSAV=NFWS + IF(MSUM .EQ. 9999999) MSUM=0 + MTSUM=MTSUM+MSUM +!ipk feb97 add pseudo double precision + 320 continue +! if(mtsum .gt. 100000000) then +! mtsum1=mtsum1+1 +! mtsum=mtsum-100000000 +! go to 320 +! endif +! +! UPDATE LIST OF NODES IN FRONT +! + MPN=MP + IF (MP.EQ.0) GO TO 420 + IF (NDP.EQ.0) GO TO 420 +! +! REMOVE THE DROPPED NODES +! +! ict2=ict2+1 +! write(88,*) ict2,'z',krec,ndp,(ndrop(n),n=1,ndp) + DO 400 N=1,NDP +! +! FIND THE NODE TO BE DROPPED IN LIST +! + DO 390 M=1,MP + IF (LIST(M).NE.NDROP(N)) GO TO 390 + LIST(M)=-LIST(M) + GO TO 400 + 390 CONTINUE + 400 END DO +! +! NOW DROP THEM +! + MPN=0 + DO 410 M=1,MP + IF (LIST(M).LT.0) GO TO 410 + MPN=MPN+1 + LIST(MPN)=LIST(M) + 410 END DO +! +! NOW ADD NEWLY GENERATED NODES +! + IF (NNEW.EQ.0) GO TO 435 + 420 DO 430 M=1,NNEW +! +! FIRST SEE IF LNEW IS IN DROP LIST +! + IF(NDP .EQ. 0) GO TO 428 + DO 425 N=1,NDP + IF(LNEW(M) .EQ. NDROP(N)) GO TO 430 + 425 CONTINUE + 428 CONTINUE + MPN=MPN+1 + LIST(MPN)=LNEW(M) + K=LNEW(M) + NINC(K)=1 + 430 END DO +! +! REDUCE COUNT OF ELEMENTS ACQUIRED AT THE NODES OF THE ELEMENT +! + 435 CONTINUE + MP=MPN +! ict1=ict1+1 +! write(85,*) ict1,'x',krec,mp,(list(n),n=1,mp) + DO 440 K=1,8 + N=NOP(KREC,K) + IF (N.EQ.0) GO TO 440 + NDELM(N)=NDELM(N)-1 + 440 END DO + RETURN + END + SUBROUTINE UPFNT(KREC) +! +! DEFINE NEW INFO ON FRONT +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! SET ICON ENTRIES NEGATIVE TO SAY THIS ELEMENT ALREADY ADDED +! + DO 450 M=1,NCMI + K=ICON(KREC,M) + IF (K.EQ.0) GO TO 460 + IF (K.LT.0) GO TO 450 + DO 430 J=1,NCMI + IF (ICON(K,J).NE.KREC) GO TO 430 + ICON(K,J)=-ICON(K,J) + GO TO 450 + 430 CONTINUE + 450 END DO +! +! UPDATE LIST OF ELEMENTS STILL IN FRONT +! + 460 MNAD=0 +! +! FIRST ELIMINATE KREC +! + IF(NAD .EQ. 0) GO TO 510 + DO 500 K=1,NAD + IF (ENXT(K).EQ.KREC) GO TO 500 + MNAD=MNAD+1 + ENXT(MNAD)=ENXT(K) + 500 END DO + 510 CONTINUE + NAD=MNAD +! +! NOW ADD NEW ELEMENTS +! + DO 520 J=1,NCMI + K=ICON(KREC,J) + IF (K.LE.0) GO TO 520 +! +! CHECK OF -K- ALREADY IN LIST +! + DO 515 M=1,NAD + IF(K .EQ. ENXT(M)) GO TO 520 + 515 CONTINUE + MNAD=MNAD+1 + ENXT(MNAD)=K + 520 END DO + NAD=MNAD + RETURN + END + SUBROUTINE SUMIT(NEL) +! +! DEVELOP SUMS FOR MAKING ELIMINATION CHOICE +! + USE BLK1MOD + USE BLK2MOD + INTEGER*8 MSUMP +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! LOCATE NEW NODES +! + NDP=0 + NNEW=0 + DO 280 K=1,8 + N=NOP(NEL,K) + IF (N.EQ.0) GO TO 280 +! +! TEST WHETHER THIS NODE ALREADY INCORPORATED +! + IF (NINC(N).EQ.1) GO TO 260 + NNEW=NNEW+1 + LNEW(NNEW)=N +! +! NOW TEST IF THE NODE IS COMPLETELY FORMED +! + 260 IF (NDELM(N).GT.1) GO TO 280 + NDP=NDP+1 + NDROP(NDP)=N + 280 END DO +! +! IMMEDIATELY ON ADDING NEW FRONT SIZE IS +! + NFW=MP+NNEW +!IPK MAY94 ADD A LINE + NFWS=NFW +! +! NOW TAKE OUT ALL WE CAN +! + MSUM=99999999 +! MSUM=0 + IF(NDP .EQ. 0) RETURN + MSUMP=0 + DO 300 K=1,NDP + MSUMP=MSUMP+NFW**2 + NFW=NFW-1 + 300 END DO + msum=msump + if(msum .gt. 99999999) THEN + write(90,*) ndp,msum,nfw,nel + ENDIF + RETURN + END + SUBROUTINE CHKOUT(ISWALL) +! +! CHECK FINAL TOTAL SAVE ORDER IF BETTER +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + CHARACTER*80 LIND +! + DATA ITIME/0/ + IF(ITIME .EQ. 0) THEN +! call rblue +! call clscrn +! YT=7.5 +! WRITE(90,6010) mtsum1,MTSUM,NFWSAV +! WRITE(LIND,6010) mtsum1,MTSUM,NFWSAV +! WRITE(90,6010) MTSUM,NFWSAV +! WRITE(LIND,6010) MTSUM,NFWSAV +! call symbl & +! & (0.1,YT,0.20,LIND,0.0,80) + NSEQ=0 + MTSUMSV(NSEQ)=MTSUM + NFWSV(NSEQ)=NFWSAV +! elseif(mtsum1 .gt. mrsum1) then +! WRITE(90,6020) mtsum1,MTSUM,NFWSAV +! WRITE(LIND,6020) mtsum1,MTSUM,NFWSAV +! YT=YT-0.3 +! call symbl & +! & (0.1,YT,0.20,LIND,0.0,80) +! RETURN +! elseif(mtsum1 .eq. mrsum1) then +!IPK AUG05 ELSE + ELSEIF(ISWALL .EQ. 0) THEN + NSEQ=NSEQ+1 + MTSUMSV(NSEQ)=MTSUM + NFWSV(NSEQ)=NFWSAV + if(mtsum .ge. mrsum .AND. MRSUM .GT. 0) then +! WRITE(90,6020) mtsum1,MTSUM,NFWSAV +! WRITE(LIND,6020) mtsum1,MTSUM,NFWSAV +! WRITE(90,6020) MTSUM,NFWSAV +! WRITE(LIND,6020) MTSUM,NFWSAV +! YT=YT-0.3 +! call symbl & +! & (0.1,YT,0.20,LIND,0.0,80) + RETURN + else +! WRITE(90,6020) mtsum1,MTSUM,NFWSAV +! WRITE(LIND,6020) mtsum1,MTSUM,NFWSAV +! WRITE(90,6020) MTSUM,NFWSAV +! WRITE(LIND,6020) MTSUM,NFWSAV +! YT=YT-0.3 +! call symbl & +! & (0.1,YT,0.20,LIND,0.0,80) + endif +! ELSE +! WRITE(90,6020) mtsum1,MTSUM,NFWSAV +! WRITE(LIND,6020) mtsum1,MTSUM,NFWSAV +! WRITE(90,6020) MTSUM,NFWSAV +! WRITE(LIND,6020) MTSUM,NFWSAV +! YT=YT-0.3 +! call symbl & +! & (0.1,YT,0.20,LIND,0.0,80) + ELSE +! NSEQ=NSEQ+1 + if(mtsum .ge. mrsum .AND. MRSUM .GT. 0) then + NSEQ=0 + MTSUMSV(NSEQ)=MTSUM + NFWSV(NSEQ)=NFWSAV + RETURN + ELSE + NSEQ=0 + MTSUMSV(NSEQ)=MTSUM + NFWSV(NSEQ)=NFWSAV + endif + ENDIF +! mrsum1=mtsum1 + MRSUM=MTSUM + ITIME=1 +! 6010 FORMAT('ORDERING SUM, ORIGINAL ELEMENT ORDER, MAX FRONT' & +! &,I4,I8.8,I7) +! 6020 FORMAT('ORDERING SUM, LATEST START POINT, MAX FRONT' & +! &,I4,I8.8,I7) + 6010 FORMAT('ORDERING SUM, ORIGINAL ELEMENT ORDER, MAX FRONT' & + &,I12,I7) + 6020 FORMAT('ORDERING SUM, LATEST START POINT, MAX FRONT' & + &,I12,I7) +!ipk feb97 end changes +! +! COPY ORDER +! + DO 300 N=1,NAE + IEM(N)=MLIST(N) + 300 END DO +! +! FILL IEM ARRAY +! + NAEP=NAE+1 + DO 400 N=1,NE + IF(IMAT(N) .EQ. 0) THEN + IEM(NAEP)=N + NAEP=NAEP+1 + ENDIF + 400 END DO + RETURN + END + SUBROUTINE KCON(isw1) +! +! ESTABLISH ELEMENT CONNECTED TO ELEMENT TABLE +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! INITIALIZE +! + DO 200 J=1,NCM + DO 200 N=1,NP + 200 NECON(N,J)=0 + DO 210 J=1,NCMI + DO 210 M=1,NE + 210 ICON(M,J)=0 + DO 230 N=1,NP + 230 NDELM(N)=0 +! +! FORM TABLE OF ELEMENTS CONNECTED TO EACH NODE +! + DO 300 M=1,NE + IF(IMAT(M) .EQ. 0) GO TO 300 + if(isw1 .eq. 1) then + if(imat(m) .eq. 999) go to 300 + endif + DO 280 K=1,8 + N=NOP(M,K) + IF (N .GT. 0) THEN + NDELM(N)=NDELM(N)+1 + J=NDELM(N) + NECON(N,J)=M +!ipkoct93 ELSE +!ipkoct93 GO TO 300 + ENDIF + 280 CONTINUE + 300 END DO +! do n=1,np +! write(87,'(31i6)') n,(necon(n,j),j=1,ncmi) +! enddo +! write(89,*) 'yy' +! DO N=1,NP +! WRITE(89,*) 'NDELM',N,NDELM(N) +! ENDDO +! +! CONVERT TABLE TO ELEMENT TO ELEMENT CONNECTION +! + DO 600 N=1,NP +! +! PLACE PAIRS OF ENTRIES FOR EACH NODE INTO APPROPRIATE ROWS +! + NL=NDELM(N)-1 +! +! SKIP OUT WHEN ONE ELEMENT OR LESS NODE +! + IF (NL.LE.0) GO TO 600 + DO 420 J=1,NL + M=NECON(N,J) +! +! PROCESS SECOND ELEMENT IN A GIVEN ROW +! + DO 370 K=J+1,NL+1 + MR=NECON(N,K) + MS=M +! +! PROCESS EACH DIRECTION OF CONNECTION +! + DO 360 MX=1,2 +! +! SEARCH IN CASE CONNECTION ALREADY FOUND +! + DO 350 L=1,NCMI + IF (ICON(MS,L).NE.0) GO TO 345 + ICON(MS,L)=MR + GO TO 355 + 345 IF (ICON(MS,L).EQ.MR) GO TO 355 + 350 CONTINUE +! +! REVERSE MR-MS FOR SECOND PASS +! + 355 CONTINUE + MS=MR + MR=M + 360 CONTINUE +! +! END LOOP ON SECOND ELEMENT +! + 370 CONTINUE +! +! END LOOP ON FIRST ELEMENT +! + 420 CONTINUE +! +! END LOOP FOR THIS NODE +! + 600 END DO + +! do n=1,ne +! write(86,'(31i6)') n,(icon(n,j),j=1,ncmi) +! enddo + + + +! +! PROCESS TO FIND NUMBER OF ACTIVE ELEMENTS +! + NAE=0 + NTE=NE+1 + DO 700 M=1,NE + IF (IMAT(M) .LT. 1) GO TO 650 + NAE=NAE+1 + MLIST(NAE)=M + GO TO 700 + 650 NTE=NTE-1 + MLIST(NTE)=M + 700 END DO + RETURN + END + +!ipk jan01 + subroutine getnlist(ipos) + use winteracter + + implicit none + + include 'd.inc' + + INTEGER :: IPOS,IERR + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + + call wdialogload(IDD_DIALOG001) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG001) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,IPOS) + +! write(90,*) 'iposin',ipos + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,IPOS) +! write(90,*) 'iposout',ipos + + return + endif + return + enddo + + RETURN + END + +!ipk jan04 + subroutine SHOWORD + use winteracter + + + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + include 'd.inc' + + INTEGER :: IERR + CHARACTER*6 SCOL1(101) + CHARACTER*18 SCOL2(101) + CHARACTER*8 SCOL3(101) + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + + call wdialogload(IDD_ORDEROUT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_ORDEROUT) + ierr=infoerror(1) + DO I=0,NSEQ + WRITE(SCOL1(I+1),'(I4)') I + WRITE(SCOL2(I+1),'(I16)') MTSUMSV(I) + WRITE(SCOL3(I+1),'(I8)') NFWSV(I) + ENDDO + + CALL WGridPutString(IDF_GRID1,1,SCOL1,NSEQ+1) + CALL WGridPutString(IDF_GRID1,2,SCOL2,NSEQ+1) + CALL WGridPutString(IDF_GRID1,3,SCOL3,NSEQ+1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + return + endif + enddo + + RETURN + END + diff --git a/src/src83e/RESETREG.f90 b/src/src83e/RESETREG.f90 new file mode 100644 index 0000000..ec3b3bd --- /dev/null +++ b/src/src83e/RESETREG.f90 @@ -0,0 +1,87 @@ + SUBROUTINE RESETREG + + USE WINTERACTER + + INCLUDE 'TXFRM.COM' + + INCLUDE 'BFILES.I90' + + CHARACTER*1 IFLAG + + + XORIGMIN=BFMINMAX(NBKFL,1) + YORIGMIN=BFMINMAX(NBKFL,2) + XORIGMAX=BFMINMAX(NBKFL,3) + YORIGMAX=BFMINMAX(NBKFL,4) + +! get reference point +! xrefpt +! yrefpt + + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select Fixed Reference point','CHOOSE REFERENCE') + + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + XREFPT = XTEMP*TXSCAL - XS + YREFPT = YTEMP*TXSCAL - YS + +! get start move point +! xlocs +! ylocs + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select Starting point','CHOOSE START') + + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + XLOCS = XTEMP*TXSCAL - XS + YLOCS = YTEMP*TXSCAL - YS + +! get finish move point +! xlocf +! ylocf + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Select Finishing point','CHOOSE FINISH') + + + CALL XYLOC(XTEMP,YTEMP,IFLAG,IBOX) + XLOCF = XTEMP*TXSCAL - XS + YLOCF = YTEMP*TXSCAL - YS + +! establish x moves + + stscal=(xlocf-xrefpt)/(xlocs-xrefpt) + xnewmin=xrefpt-(xrefpt-xorigmin)*stscal + xnewmax=xrefpt+(xorigmax-xrefpt)*stscal + +! establish y moves + + stscal=(ylocf-yrefpt)/(ylocs-yrefpt) + ynewmin=yrefpt-(yrefpt-yorigmin)*stscal + ynewmax=yrefpt+(yorigmax-yrefpt)*stscal + + BFMINMAX(NBKFL,1)=xnewmin + BFMINMAX(NBKFL,2)=ynewmin + BFMINMAX(NBKFL,3)=xnewmax + BFMINMAX(NBKFL,4)=ynewmax + + CALL CLSCRN + CALL PLOTOT(1) + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to use and save'//& + CHAR(13)//'this registration?','CHOOSE REGISTRATION?') +! +! If answer NO revert +! + IF (WInfoDialog(4) .EQ. 2) then + BFMINMAX(NBKFL,1)=XORIGMIN + BFMINMAX(NBKFL,2)=YORIGMIN + BFMINMAX(NBKFL,3)=XORIGMAX + BFMINMAX(NBKFL,4)=YORIGMAX + CALL CLSCRN + CALL PLOTOT(1) + else + ! + ! otherwise SAVE + + CALL SAVORG(NBKFL,2) + END IF +! + + RETURN + END \ No newline at end of file diff --git a/src/src83e/RESETWHGT.f90 b/src/src83e/RESETWHGT.f90 new file mode 100644 index 0000000..dfb5f29 --- /dev/null +++ b/src/src83e/RESETWHGT.f90 @@ -0,0 +1,291 @@ + SUBROUTINE RESETWHGT + USE BLK1MOD + USE BLK2MOD + INCLUDE 'TXFRM.COM' + SAVE + DIST(N,M)=Sqrt((cord(n,1)-cord(m,1))**2+(cord(n,2)-cord(m,2))**2)*txscal +! INCLUDE 'BLK1A.COM' +! DIMENSION K1(50000),levrem(50000) +! ALLOCATABLE NRF(:),AREF(:),LEVREM(:),TRANSEL(:),WLEN(:),WHGT(:),TRCEL(:) + IF(.NOT. ALLOCATED (NRF)) THEN + ALLOCATE (NRF(MAXP),AREF(MAXP),LEVREM(MAXP)) + ENDIF + IF(.NOT. ALLOCATED (TRANSEL)) THEN + ALLOCATE(TRANSEL(MAXP),WLEN(MAXP),WHGT(MAXP)) + ENDIF + NRF=0 + AREF=0 + K1=0 + levrem=0 + WHGT=-9999. + call kcon(1) + CALL PANELWHT(IWTYP,ISWL,R1,R2) + IF(IWTYP .LE. 0) RETURN + IF(ISWL .EQ. 2) GO TO 300 + DO N=1,NE + IF(IMAT(N) .EQ. IWTYP) THEN + DO K=2,6,4 + KK=NOP(N,K) + DO M=1,NE + IF(IMAT(M) .EQ. IWTYP) CYCLE + DO L=2,NCORN(M),2 + IF(NOP(M,L) .EQ. KK) THEN + IF(NCORN(M) .EQ. 8) THEN + IF(L .EQ. 2) THEN + IOP1=NOP(M,5) + IOP2=NOP(M,7) + ELSEIF(L .EQ. 4) THEN + IOP1=NOP(M,7) + IOP2=NOP(M,1) + ELSEIF(L .EQ. 6) THEN + IOP1=NOP(M,1) + IOP2=NOP(M,3) + ELSEIF(L .EQ. 8) THEN + IOP1=NOP(M,3) + IOP2=NOP(M,5) + ENDIF + + ELSE + IF(L .EQ. 2) THEN + IOP1=NOP(M,5) + IOP2=NOP(M,5) + ELSEIF(L .EQ. 4) THEN + IOP1=NOP(M,1) + IOP2=NOP(M,1) + ELSE + IOP1=NOP(M,3) + IOP2=NOP(M,3) + ENDIF + ENDIF + IF(NRF(NOP(N,K-1)) .EQ. 0) THEN + NRF(NOP(N,K-1))=IOP1 + AREF(NOP(N,K-1))=WD(IOP1) + ELSEIF(WD(IOP1) .GT. WD(NOP(N,K-1))) THEN + NRF(NOP(N,K-1))=IOP1 + AREF(NOP(N,K-1))=WD(IOP1) + ENDIF + IF(NRF(NOP(N,K+1)) .EQ. 0) THEN + NRF(NOP(N,K+1))=IOP2 + AREF(NOP(N,K+1))=WD(IOP2) + ELSEIF(WD(IOP2) .GT. WD(NOP(N,K+1))) THEN + NRF(NOP(N,K+1))=IOP2 + AREF(NOP(N,K+1))=WD(IOP2) + ENDIF + ENDIF + ENDDO + ENDDO + ENDDO + ENDIF + ENDDO + DO N=1,NE + IF(IMAT(N) .EQ. IWTYP) THEN + DO K=1,7,2 + IF(AREF(NOP(N,K)) .GE. WD(NOP(N,K))-0.1) THEN + IMAT(N)=IWTYP + nnn=nop(n,k) + write(151,*) 'levee reset',n,k,nnn,aref(nnn),WD(nnn) + do kk=1,7,2 + levrem(nop(n,kk))=1 + enddo + GO TO 150 + ELSEIF(NRF(NOP(N,K)) .EQ. 0) THEN + IMAT(N)=99 + nnn=nop(n,k) + write(151,*) 'Levee element removed',n,k,nnn + GO TO 150 + ELSE + WRITE(151,*) 'Levee active', n,aref(nop(n,k)),iop1 + IMAT(N)=IWTYP+900 + ENDIF + ENDDO + ENDIF + 150 CONTINUE + ENDDO + IF(IWTP .LT. 900) IWTYP=IWTYP+900 + DO N=1,NE + IF(IMAT(N) .EQ. IWTYP) THEN + KCT=1 + NPK1=NOP(N,1) + NPK2=NOP(N,3) + 160 CONTINUE + IF(levrem(NPK1) .eq. 1) then + if(levrem(npk2) .eq. 1) then + IMAT(N)=IWTYP-900 + GO TO 180 + else + IF(KCT .EQ. 1) THEN + MA=NECON(NOP(N,4),1) + MB=NECON(NOP(N,4),2) + ELSE + MA=NECON(NOP(N,8),1) + MB=NECON(NOP(N,8),2) + ENDIF + IF(MA .EQ. N) MA=MB + IF(MA .NE. 0) THEN + IF(NOP(MA,1) .EQ. NPK2) THEN + IF(LEVREM(NOP(MA,3)) .EQ. 1) THEN + IMAT(N)=IWTYP-900 + IMAT(MA)=IWTYP-900 + ENDIF + ELSEIF(NOP(MA,3) .EQ. NPK2) THEN + IF(LEVREM(NOP(MA,1)) .EQ. 1) THEN + IMAT(N)=IWTYP-900 + IMAT(MA)=IWTYP-900 + ENDIF + ENDIF + ENDIF + endif + ENDIF + NPK2=NOP(N,1) + NPK1=NOP(N,3) + IF(KCT .EQ. 1) THEN + KCT=2 + GO TO 160 + ENDIF + ENDIF + 180 CONTINUE + ENDDO + DO N=1,NE + IF(IMAT(N) .EQ. IWTYP) THEN + DO K=1,7,2 + IOP1=NRF(NOP(N,K)) + IF(IOP1 .GT. 0) THEN + NPK=NOP(N,K) + WHGT(NPK)=WD(NPK) + TRANSEL(NPK)=WHGT(NPK)+R1 + n1=nop(n,k) + n2=nop(n,8-k) + wlen(NPK)=dist(n1,n2) + NRF(NPK)=-NRF(NPK) + if(levrem(NPK) .eq. 0) then + WD(NPK)=WD(IOP1) + TRANSEL(NPK)=WHGT(NPK)+R1 + n1=nop(n,k) + n2=nop(n,8-k) + wlen(NPK)=dist(n1,n2) +! wlen(NPK)=8. + endif + ENDIF + ENDDO + 200 CONTINUE +! AMMN=(WHGT(NOP(N,1))+WHGT(NOP(N,3)))/2. +! IF(AMMN .GT. WHGT(NOP(N,1))) THEN +! TRCEL(N)=AMMN - WHGT(NOP(N,1))+0.1 +! ELSE +! TRCEL(N)=AMMN - WHGT(NOP(N,3))+0.1 +! ENDIF +! TRCEL(N)=0.25 +! write(151,*) 'levee element trc set',n,trcel(n),whgt(nop(n,1))& +! ,whgt(nop(n,3)) + ENDIF + ENDDO + DEALLOCATE (NRF,AREF,LEVREM) + GO TO 400 + 300 CONTINUE + DO N=1,NE + IF(IMAT(N) .EQ. IWTYP) THEN + DO K=1,7,2 + NPK=NOP(N,K) + WHGT(NPK)=WD(NPK)+R2 + TRANSEL(NPK)=WHGT(NPK)+R1 + n1=nop(n,k) + n2=nop(n,8-k) + wlen(NPK)=dist(n1,n2) + ENDDO + ENDIF + ENDDO + 400 call OUTWDT + RETURN + END + + SUBROUTINE PANELWHT(N1,ISWL,R1,R2) + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,IERR,ISWL + real :: R1,R2 + character*3 :: sub + + call wdialogload(IDD_SETWRS) + ierr=infoerror(1) + + call wdialogputRadioButton(idf_radio1) + CALL WDialogPutInteger(idf_integer1,n1) + CALL WDialogPutReal(idf_real1,r1) + CALL WDialogPutReal(idf_real2,r2) + + + CALL WDialogSelect(IDD_SETWRS) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + call wdialoggetradiobutton(idf_radio1,ISWL) + CALL WDialogGetInteger(idf_integer1,n1) + CALL WDialogGetReal(idf_real1,r1) + CALL WDialogGetReal(idf_real2,r2) + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + N1=-1 + + ENDIF + RETURN + END + + SUBROUTINE OUTWDT + + USE WINTERACTER + USE BLK1MOD + INCLUDE 'TXFRM.COM' + + CHARACTER(LEN=255) :: FNAME,FILTER + CHARACTER(LEN=4) :: SUB + LOGICAL OPENED + CHARACTER*1 IFLAG,ANS(10) + + IOUTWR=81 + INQUIRE(81, OPENED=OPENED) + if(.not. opened) then + Filter='WDT file -- *.dat|*.dat|' + + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Save Weir Data File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + OPEN(IOUTWR,FILE=FNAME,STATUS='UNKNOWN',ACTION='WRITE') + GO TO 3 + ELSE + GO TO 1 + ENDIF + ELSE + REWIND(IOUTWR) + GO TO 3 + ENDIF + +1 RETURN + +3 DO N=1,NP + IF(WHGT(N) .GT. -9999.) THEN + WRITE(IOUTWR,7778) N,WHGT(N),WLEN(N),TRANSEL(N) +7778 FORMAT('WDT',5X,I8,3F8.2) + ENDIF + ENDDO + CLOSE(IOUTWR) + + RETURN + END \ No newline at end of file diff --git a/src/src83e/RESOURCE.F90 b/src/src83e/RESOURCE.F90 new file mode 100644 index 0000000..7873ca2 --- /dev/null +++ b/src/src83e/RESOURCE.F90 @@ -0,0 +1,32 @@ +! Winteracter module created : 07/Nov/1998 14:27:06 +! + MODULE MENUED + INTEGER, PARAMETER :: IDR_MENU1 = 30001 + INTEGER, PARAMETER :: ID_FILE = 40001 + INTEGER, PARAMETER :: ID_EXIT = 40002 + INTEGER, PARAMETER :: ID_NODE = 40003 + INTEGER, PARAMETER :: ID_ELTS = 40004 + INTEGER, PARAMETER :: ID_ORDR = 40005 + INTEGER, PARAMETER :: ID_CCLN = 40006 + INTEGER, PARAMETER :: ID_CSEC = 40007 + INTEGER, PARAMETER :: ID_ZOOM = 40008 + INTEGER, PARAMETER :: ID_DRAW = 40009 + INTEGER, PARAMETER :: ID_HELP = 40010 + INTEGER, PARAMETER :: ID_STRING1 = 50001 + INTEGER, PARAMETER :: ID_STRING2 = 50002 + INTEGER, PARAMETER :: ID_STRING3 = 50003 + INTEGER, PARAMETER :: ID_STRING4 = 50004 + INTEGER, PARAMETER :: ID_STRING5 = 50005 + INTEGER, PARAMETER :: ID_ITEM11 = 40011 + INTEGER, PARAMETER :: ID_ITEM12 = 40012 + INTEGER, PARAMETER :: ID_ITEM13 = 40013 + INTEGER, PARAMETER :: ID_ITEM14 = 40014 + INTEGER, PARAMETER :: ID_ITEM15 = 40015 + INTEGER, PARAMETER :: ID_ITEM16 = 40016 + INTEGER, PARAMETER :: ID_ITEM17 = 40017 + INTEGER, PARAMETER :: ID_ITEM18 = 40018 + INTEGER, PARAMETER :: ID_ITEM19 = 40019 + INTEGER, PARAMETER :: IDF_STRING1 = 1002 + INTEGER, PARAMETER :: IDF_GROUP1 = 1001 + INTEGER, PARAMETER :: IDF_STRING3 = 1003 + END MODULE MENUED diff --git a/src/src83e/RMAGEN.F90 b/src/src83e/RMAGEN.F90 new file mode 100644 index 0000000..0b55c8a --- /dev/null +++ b/src/src83e/RMAGEN.F90 @@ -0,0 +1,694 @@ +!IPK LAST UPDATE SEP 23 2015 ADD TESTING FOR CHNAGED ELEMENTS/NODES OR REORDERING +! Last change: IPK 13 Jan 98 10:01 am +!cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc + SUBROUTINE RMAGEN(MENUS,N1,N2,N3,N4,N5,N6,N7,N8,N9) +! +! +! +! RMAGEN Version 4.2 +! +! Release date Jan 13 1998 +! +! +! Changes in this version include: +! (1) Revisions to operate in a graphical mode, reducing the amount of +! DOS screen input. +! (2) Addition of options for both the node move operation and refine +! options to allow the user to stop preservation or automatic +! interpolation of bottom elevations from the corner node values. +! This option is a user setting. The default initial setting +! retains the value for the move operation and interpolaton during +! refinement. +! (3) Input of "geo" has been made more flexible. The model +! automatically detects binary files with and without headers. Note +! that this option is only relevant for PC versions. +! (4) The screen now displays compilation limits on startup. +! +! +! RMAGEN Version 4.1(a) +! +! Release date Nov 18 1997 +! +! +! +! Changes in this version include: +! (1) Revised interpolation scheme for computing bottom elevations from +! map file data. +! (2) More consistent backup +! (3) Addition of option to split triangles when refining +! +! RMAGEN Version 4.1 +! +! Release date Oct 19 1996 + +! Changes in this version include: +! (1) New options that allow selective drawing of maps in different +! colours +! (2) An option that allows construction of continuity lines from the +! map screen + +! RMAGEN Version 3.3 + +! Release date April 1 1994 + +! Changes in this version include: +! (1) Incorporation of the ability to record and play scripts. +! (2) Correction to correctly operate in the top half inch of the network + +! RMAGEN Version 3.2 + +! Release date March 1 1994 + +! Changes in this version include: +! (1) Modification to the save options to enter a menu of save choices. +! (2) Addition of the capability to save a binary version of the map file. +! (3) Correction to the "backup file" to make it work consistently. +! (4) Changes to the algorithm of the bottom elevation generation routine +! to improve reliability. +! (5) Removal of an implied limitation of 32000 lines for the map file by +! deleting some INTEGER*2 variable to INTEGER*4. + +! RMAGEN Version 3.1(a) + +! Release date Aug 1 1993 + +! Changes in this version include: +! (1) Correction to colurs that make them more readable. +! (2) Additions to the SELECT options that permit more flexible choice +! of elements. + +! RMAGEN Version 3.1 + +! Release date March 1 1993 + +! Changes in this version include: +! (1) Correction in fill operation to ensure correct fill when there are +! a number of gaps in the nodal sequence. +! (2) Additions to the NODE-DELETE options that permit more flexible +! deletion options such as all mid-side nodes, all exact mid-side +! location nodes or all unused nodes. The fill option has added +! flexibility. + + +! Version 3.0(c) August 1 1992 + +! Changes in this version include: +! (1) Revisions to incorporate REGIS graphics capability +! (2) Block of routines available to use DEC 340 REGIS graphics +! terminal with unix system + + +! Version 3.0(b) May 20 1992 + +! Changes in this version include: +! (1) Renaming of all colours for compatibility with Silicon Graphics +! (2) Modification of nodal delete so that when a mid-side node is +! selected for deletion it is removed and the associated reference +! in the element is set to zero. The element is no longer deleted. +! (3) Cleanup of array subscripts in SUBROUTINE HEDRC + +! Version 3.0(a) April 1992 + +! Changes to a number of routines to correct minor errors +! and nuisances. + +! Version 3.0 January 1992 + +! This version revises the naming of input and output files. +! Output files may be generated in ASCII or BINARY form. +! The binary file is designed to bypass RMA-1. +! This file optionally may contain element reordering numbers +! New capabilities include: +! (1) Automatic filling of zero's in element connection arrays. +! (2) Input of reordering sequences and executing the reordering +! process. + + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'BFILES.I90' + + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + +!ipk oct96 + character*64 fnams + character*25 mesg + CHARACTER*1 ANS,ANSW(0:9),ansx(0:9) + DATA ANSW/'e','n','o','h','s','l','t','z','r','q'/ + data ansx/'s','b','m','p',2*' ','h','z','r','q'/ + + DATA IFIRST / 1 / + + IF(N3 .EQ. 1) GO TO 101 + + ISWTAGN=0 + ISWTINTP=0 + WIDSCL=1.0 + WIDEL=0.0 + IPW1=1 + IMP=N1 + IIN=N2 + IOT=N4 + IOT1=N5 + IGFG=N6 + ITRIAN=N7 +!ipk jul98 + LCROSS=.FALSE. + ICRS=0 + DFACTOR=50. + ZREF=5. + +!iPK JAN98 + IDELV=0 + IRESTT=0 + 1 CONTINUE + IFIRST=1 + IECHG=0 + NELAST=1 + NPLAST=1 + NLST=0 + NENTRY=0 + TXSCAL = 1. + XS=0. + YS=0. + VDX = - 1.0E+10 + VOID = - 1.0E+20 + + IPSW(1)=0 + IPSW(2)=0 + IPSW(3)=0 + IPSW(4)=1 + IPSW(5)=0 + IPSW(6)=0 + IPSW(7)=0 + IPSW(8)=0 + IPSW(9)=0 + IPSW(12)=0 +! IF(N8 .GT. 100000) THEN +! IPSW(2)=1 +! IPSW(4)=0 +! ENDIF + MAXPTS=MAXPL +!ipk jan98 + call file(1) + + + write(90,*) 'rmagen',iot,iot1 + +! Initialize plot + +!! CALL GINIT + +! Startup files + WRITE(MESG,6010) + 6010 FORMAT(' Going to initialisation ') + CALL SYMBL(1.1,6.3,0.15,mesg,0.0,25) + + CALL FILE(2) + + WRITE(MESG,6011) + 6011 FORMAT(' Back from initialisation') + CALL SYMBL(1.1,5.3,0.15,mesg,0.0,25) + + IF(MENUS .EQ. -1) CALL DEMOS + + IF(IIN .EQ. 0) IPSW(1)=1 + +! Initialize plot + +!ipk jan98 CALL GINIT + + IF(IMP .GT. 0) THEN + +! Read map file + WRITE(90,*) 'GOING TO READ MAP' + CALL RDMAP(0,0,0,0) + IF (IFIRST .EQ. 1) THEN + +! Find max and min + + XMIN = 1.E+20 + XMAX = -XMIN + YMIN = 1.E+20 + YMAX = -YMIN + + DO 8 J=1,MAXPTS + IF (CMAP(J,1) .LT. VDX) GOTO 8 + IF (CMAP(J,1) .LT. XMIN) XMIN = CMAP(J,1) + IF (CMAP(J,1) .GT. XMAX) XMAX = CMAP(J,1) + IF (CMAP(J,2) .LT. YMIN) YMIN = CMAP(J,2) + IF (CMAP(J,2) .GT. YMAX) YMAX = CMAP(J,2) + 8 CONTINUE + 9 CONTINUE + ENDIF + ENDIF + +! Read in header lines + + ISET=1 + WRITE(90,*) 'GOING TO HEADIN' + CALL HEADIN(IIN,ISET) + +! Read in existing elements + WRITE(90,*) 'GOING TO RDELEM' + CALL RDELEM(IIN) + +! Read in nodal coordinates + + WRITE(90,*) 'GOING TO RDCORD' + CALL RDCORD(IIN) + + WRITE(90,*) 'RMAGEN-243 NCLM',NCLM + + +!ipk may03 + ichg=1 + +! Close input file + + if(iin .ne. 0) then + CLOSE(IIN) + endif + +! Scale for plotting + + IF (IFIRST .EQ. 1) THEN + IF (IMP .EQ. 0) THEN + XMIN = 1.E+20 + XMAX = -XMIN + YMIN = 1.E+20 + YMAX = -YMIN + ENDIF + + IF(NP .GT. 0) THEN + DO 10 J=1,NP + IF (CORD(J,1) .LT. VDX) GOTO 10 + IF (CORD(J,1) .LT. XMIN) XMIN = CORD(J,1) + IF (CORD(J,1) .GT. XMAX) XMAX = CORD(J,1) + IF (CORD(J,2) .LT. YMIN) YMIN = CORD(J,2) + IF (CORD(J,2) .GT. YMAX) YMAX = CORD(J,2) + 10 CONTINUE + ENDIF + +! Check for background limits + WRITE(90,*) 'NBKFL',NBKFL + IF(NBKFL .GT. 0) THEN + DO I=1,NBKFL + IF(BFMINMAX(I,1) .LT. XMIN) XMIN=BFMINMAX(I,1) + IF(BFMINMAX(I,2) .LT. YMIN) YMIN=BFMINMAX(I,2) + IF(BFMINMAX(I,3) .GT. XMAX) XMAX=BFMINMAX(I,3) + IF(BFMINMAX(I,4) .GT. YMAX) YMAX=BFMINMAX(I,4) + WRITE(90,*) 'XX',XMIN,XMAX,YMIN,YMAX + WRITE(90,*) 'BFMIN',(BFMINMAX(I,K4),K4=1,4) + ENDDO + ENDIF + +!rrr + WRITE(90,*) 'GOING TO PGRID' + CALL PGRID + + AMAP=(XMAX-XMIN)*(YMAX-YMIN) + XSCALE = (XMAX-XMIN)/(hsize-0.5) + YSCALE = (YMAX-YMIN)/6.5 + PSCALE = MAX(XSCALE,YSCALE) + + XAVE = (XMIN + XMAX) /2.0 + YAVE = (YMIN + YMAX) /2.0 + XMIN = XAVE - hsize/2.*PSCALE + YMIN = YAVE - 3.5*PSCALE + XMAX = XAVE + (hsize-0.5)/2.*PSCALE + YMAX = YAVE + 3.25*PSCALE +! YMIN = YMIN - .01*PSCALE +! XMIN = XMIN - .01*PSCALE + +! Reset values if STARTUP.DAT file is used + + IF(IS11 .GT. 0) THEN + READ(IS11,5200) XS,YS,PSCALE + 5200 FORMAT(3F15.0) + XMIN=-XS + YMIN=-YS + ENDIF + + IFIRST = 0 + + ENDIF + +! Plot all data + + CALL PLOTSV(0) +!ipk nov97 add (1) + CALL PLOTOT(1) + GO TO 101 + +! Top of loop ******************************** + + 100 CONTINUE + 101 CONTINUE + if(menus .gt. 9) go to 25 + IF(MENUS .GT. 0) THEN + ANS=ANSW(MENUS-1) + MENUS=0 + GO TO 130 + ENDIF + +! List options + + 25 CONTINUE + +! Draw box around selections + + IF(MENUS .EQ. -3) THEN + CALL PLOTOT(0) + MENUS=-2 + ENDIF + NHTP=1 + NMESS=0 + NBRR=0 + CALL HEDR +! Get answer + + call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + IF(ANS .EQ. 'c') THEN + I=IBOX-1 + if(i .lt. 0) go to 25 + ANS=ANSW(I) + ENDIF + + 130 CONTINUE + +! Add elements + + IF (ANS .EQ. 'e') THEN + CALL ELTS + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + +! Go to help facility + + ELSEIF (ANS .EQ. 'h') THEN + CALL HELPS(1) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + +! Process nodes + + ELSEIF (ANS .EQ. 'n') THEN + CALL ADDNOD +!ipk feb94 call for backup + CALL WRTOUT(0) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + +! Add element reordering sequence + + ELSEIF (ANS .EQ. 'o') THEN + +! Draw box around selections + + 140 CONTINUE + NHTP=3 + NMESS=0 + NBRR=0 + CALL PLOTORDS + + CALL HEDR + +! Get answer + + call xyloc(XPT,YPT,ANS,IBOX) + CALL PLOTORDS + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + IF(ANS .EQ. 'c') THEN + I=IBOX-1 + ELSE + IF(ANS .EQ. 'l') THEN + +! Process current list including baseine order + + I=0 + ELSEIF(ANS .EQ. 'g') THEN + +! Add another order to the list + + I=1 + ELSEIF(ANS .EQ. 'p') THEN + +! Process the latest addition to the list + + I=2 + ELSEIF(ANS .EQ. 'o') THEN + I=3 + ELSEIF(ANS .EQ. 't') THEN + I=4 + ELSEIF(ANS .EQ. 'h') THEN + I=5 + ELSEIF(ANS .EQ. 'z') THEN + I=7 + ELSEIF(ANS .EQ. 'r') THEN + I=8 + ELSEIF(ANS .EQ. 'q') THEN + I=9 + ENDIF + ENDIF + IF(I .LT. 3) THEN + + CALL ADDORD(I) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + GO TO 140 + ELSEIF(I .gt. 2 .and. I .lt. 5) THEN +! +! compact elements and nodes +! + call compact(i) + go to 100 + + ELSEIF(I .EQ. 5) THEN + +! Get help screen + + CALL HELPS(5) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + + ELSEIF(I .EQ. 9) THEN + +! Return to main menu + + GO TO 100 + + ELSE + +! Return to try for character again + + GO TO 140 + ENDIF + GO TO 140 + +! ENDIF +!ipk oct96 add continuity lines + + ELSEIF (ANS .EQ. 'l') THEN + CALL CCLINE(1) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + +!ycw mar97 add cross section + + ELSEIF (ANS .EQ. 't') THEN + CALL CRSECT + IF(IRMAIN .EQ. 1) THEN + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF +!ycw + ELSEIF (ANS .EQ. 'r') THEN +! Save display parameters + + n1=nhtp + n2=nmess + n3=nbrr + CALL RDRW(0) + if(irmain .eq. 1) return + +! Restore display parameters + + nhtp=n1 + nmess=n2 + nbrr=n3 + + ELSEIF (ANS .EQ. 's') THEN + +! Save files + + +! Draw box around selections + + 210 NHTP=11 + NMESS=0 + NBRR=0 + CALL HEDR + +! Get answer + + call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + IF(ANS .EQ. 'c') THEN + if(ibox .le. 0) go to 210 + I=IBOX-1 + ANS=ANSX(I) + ENDIF + +! Save plot file + + IF (ANS .EQ. 'p') THEN + + CALL PLOTSV(1) +!ipk nov97 add(1) + CALL PLOTOT(1) + CALL NDPLSV + + ELSEIF (ANS .EQ. 'b') THEN + +! Save file in binary form + + CALL WRTOUT(2) + + ELSEIF (ANS .EQ. 'm') THEN + +! Save map file + + CALL WRTMAP(0) + + ELSEIF (ANS .EQ. 's') THEN + +! Save file + + CALL WRTOUT(1) + +! Go to help facility + + ELSEIF (ANS .EQ. 'h') THEN + CALL HELPS(8) + IF(IRMAIN .EQ. 1) THEN +!ipk may94 add line + CALL RESCAL + IRMAIN=0 + GO TO 100 + ENDIF + ELSEIF (ANS .EQ. 'q') THEN + GO TO 100 + ENDIF + GO TO 210 + + + ELSEIF (ANS .EQ. 'q') THEN + +! Quit program after checking + + + CALL RQUIT(IYES) + IF(IYES .EQ. 1) THEN + CALL Quit_Pgm + STOP +!!SEP02 CALL CLSCRN +!!SEP02 CALL SETD(23) +!ipk oct96 move to screen output + +!!SEP02 WRITE(FNAMS,*) 'Do you really want to quit? (y) or (n)' +!!SEP02 CALL SYMBL(1.,7.20,0.20,FNAMS,0.,38) +!!SEP02 ndig=1 +!!SEP02 call gtcharx(ans,ndig,6.,7.2) +!ipk oct96 READ(*,'(A)') ANS +!!SEP02 IF(ANS .EQ. 'y' .OR. ANS .EQ. 'Y') THEN +!!SEP02 CALL Quit_Pgm +!!SEP02 STOP +!!SEP02 ELSE +!!SEP02 WRITE(FNAMS,*)'Do you want to restart? (y) or (n)' +!!SEP02 CALL SYMBL(1.,6.20,0.20,FNAMS,0.,34) +!!SEP02 ndig=1 +!!SEP02 call gtcharx(ans,ndig,6.,7.2) +!ipk oct96 READ(*,'(A)') ANS +!!SEP02 IF(ANS .EQ. 'y' .OR. ANS .EQ. 'Y') THEN +!!SEP02 IRESTT=1 +!!SEP02 GO TO 1 +!!SEP02 ENDIF +!!SEP02 CALL SETD(2) + ENDIF + + ENDIF + + GOTO 100 + + END + + + SUBROUTINE RQUIT(IYES) + + USE WINTERACTER + + INCLUDE 'BFILES.I90' + + INCLUDE 'D.INC' + + IF(IRDONE .NE. 0) THEN + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you really wish to quit?'//& + CHAR(13)//' ','Quit option') + ELSE + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'You have not reordered'//Char(13)//'Do you really wish to quit?'//& + CHAR(13)//' ','Quit option') + ENDIF +! +! If answer 'No', return +! + iyes=1 + IF (WInfoDialog(4).EQ.2) iyes=0 + return + end + diff --git a/src/src83e/RMAGENV83d.rc b/src/src83e/RMAGENV83d.rc new file mode 100644 index 0000000..33d9f03 --- /dev/null +++ b/src/src83e/RMAGENV83d.rc @@ -0,0 +1,2432 @@ +/////////////////////////////////////////////////// +// +// THIS FILE SHOULD NOT BE EDITED USING A TEXT +// EDITOR OR 3RD PARTY RESOURCE EDITOR, EXCEPT +// WHEN SPECIFICALLY INSTRUCTED BY I.S.S. +// +/////////////////////////////////////////////////// +// +// Winteracter resource script. +// +// Modified : 13/Feb/2017 12:04:28 +// +/////////////////////////////////////////////////// +// +// Include files +// +#include "winparam.h" + +/////////////////////////////////////////////////// +// +// Parameter Definitions +// +#define IDR_MENU1 30001 +#define ID_FILE 40001 +#define ID_EXIT 40002 +#define ID_NODE 40003 +#define ID_ELTS 40004 +#define ID_ORDRT 40005 +#define ID_CCLNA 40006 +#define ID_CSEC1 40007 +#define ID_ZOOM 40008 +#define ID_DRAW 40009 +#define ID_HELP 40010 +#define ID_STRING1 50001 +#define ID_STRING2 50002 +#define ID_STRING3 50003 +#define ID_STRING4 50004 +#define ID_STRING5 50005 +#define ID_STRING6 50006 +#define ID_STRING7 50007 +#define ID_STRING8 50008 +#define ID_STRING9 50009 +#define ID_STRING10 50010 +#define ID_STRING11 50011 +#define ID_ITEM11 40011 +#define ID_ITEM12 40012 +#define ID_ITEM13 40013 +#define ID_ITEM14 40014 +#define ID_ITEM15 40015 +#define ID_ITEM16 40016 +#define ID_ITEM17 40017 +#define ID_ITEM18 40018 +#define ID_ITEM19 40019 +#define IDF_STRING24 1041 +#define IDD_DIALOG1 101 +#define IDF_LABEL5 1042 +#define IDC_BUTTON2 20001 +#define ID_ITEM20 40021 +#define ID_ITEM73 40022 +#define ID_ITEM23 40023 +#define ID_ITEM24 40024 +#define ID_TOOLBAR1 30101 +#define ID_ZIN 40025 +#define ID_ZOUT 40026 +#define ID_OUT2 40027 +#define ID_OUT4 40028 +#define ID_RSET 40029 +#define ID_PLEFT 40031 +#define ID_PRIGHT 40032 +#define ID_PUP 40033 +#define ID_PDOWN 40034 +#define ID_IDRWT 40035 +#define ID_TYPD 40039 +#define ID_DRAWD 40041 +#define ID_MAPOPD 40042 +#define ID_CONTR 40060 +#define IDF_LABEL1 1001 +#define IDF_LABEL2 1002 +#define IDF_LABEL3 1003 +#define IDF_LABEL4 1004 +#define IDF_STRING1 1013 +#define IDF_STRING2 1014 +#define IDF_STRING3 1015 +#define IDF_STRING4 1016 +#define IDF_STRING5 1017 +#define IDF_STRING6 1018 +#define IDF_STRING7 1019 +#define IDF_STRING8 1020 +#define IDF_STRING9 1021 +#define IDF_STRING10 1022 +#define IDF_STRING11 1023 +#define IDF_STRING12 1024 +#define IDD_DIALOG02 102 +#define IDF_STRING13 1025 +#define IDF_STRING14 1026 +#define IDF_STRING15 1027 +#define IDF_STRING16 1028 +#define IDF_STRING17 1029 +#define IDF_STRING18 1030 +#define IDF_STRING19 1031 +#define IDF_STRING20 1032 +#define IDF_STRING21 1033 +#define IDF_STRING22 1034 +#define IDF_STRING23 1035 +#define IDF_CHECK1 1036 +#define IDF_CHECK2 1037 +#define IDF_CHECK3 1038 +#define IDF_CHECK4 1039 +#define IDF_CHECK5 1040 +#define ID_DCONTR 40056 +#define ID_CONTOPT 40061 +#define ID_ITYPN 40064 +#define ID_ITYPC 40065 +#define ID_ICOPY 40067 +#define IDD_DIALOG04 104 +#define ID_BACGD 40050 +#define ID_ITEM26 40071 +#define IDD_DIALOG05 103 +#define IDF_CMAP8 1005 +#define IDF_CMAP9 1006 +#define IDF_CMAP0 1007 +#define IDF_CMAP1 1008 +#define IDF_CMAP2 1009 +#define IDF_CMAP10 1010 +#define IDF_CMAP11 1011 +#define IDF_CMAP3 1012 +#define IDF_CMAP4 1043 +#define IDF_CMAP5 1044 +#define IDF_CMAP6 1045 +#define IDF_CMAP7 1046 +#define IDD_DIALOG006 105 +#define IDF_RADIO1 1047 +#define IDF_RADIO2 1048 +#define IDF_RADIO3 1049 +#define IDF_RADIO4 1050 +#define IDF_RADIO5 1051 +#define IDF_RADIO6 1052 +#define IDF_RADIO7 1053 +#define IDF_RADIO8 1054 +#define IDF_RADIO9 1055 +#define ID_MMAP 40043 +#define IDD_DIALOG07 106 +#define IDD_DIALOG08 107 +#define ID_Help1 40040 +#define ID_Help2 40044 +#define IDD_DIALOG09 108 +#define IDF_LABEL7 1056 +#define IDD_DIALOG10 109 +#define IDF_INTEGER1 1057 +#define IDF_INTEGER2 1058 +#define ID_LAYFL 40046 +#define IDF_RADIO10 1056 +#define IDD_DIALOG010 110 +#define IDD_DIALOG001 111 +#define ID_BKF 40047 +#define IDD_DIALOG012 113 +#define IDF_CHECK6 1041 +#define IDF_CHECK7 1042 +#define IDF_CHECK8 1043 +#define IDF_CHECK9 1044 +#define IDF_CHECK10 1045 +#define IDF_CHECK11 1059 +#define ID_Clip 40020 +#define ID_UNDOM 40030 +#define ID_BSEL 40036 +#define ID_REGST 40037 +#define IDD_REGST 112 +#define IDF_LABEL6 1005 +#define IDF_REAL1 1060 +#define IDF_REAL2 1061 +#define IDF_REAL3 1062 +#define IDF_REAL4 1063 +#define IDF_LABEL8 1006 +#define IDF_LABEL9 1007 +#define IDF_LABEL10 1008 +#define IDF_LABEL11 1043 +#define IDF_REAL5 1064 +#define IDF_REAL6 1065 +#define IDF_REAL7 1066 +#define IDF_REAL8 1067 +#define IDF_LABEL12 1009 +#define IDADJUST 1068 +#define IDFSWITCH 1069 +#define IDD_SLRGNO 114 +#define IDD_CONFIRM 115 +#define ID_network 40038 +#define ID_NMAP 40045 +#define ID_ITEM56 40048 +#define ID_Nodedata 40049 +#define ID_Eltdata 40051 +#define IDD_nodedata 116 +#define IDF_REAL9 1068 +#define IDF_REAL10 1069 +#define IDD_eltdata 117 +#define IDF_INTEGER3 1059 +#define IDF_INTEGER4 1060 +#define IDF_INTEGER5 1061 +#define IDF_INTEGER6 1062 +#define IDF_INTEGER7 1063 +#define IDF_INTEGER8 1064 +#define IDF_INTEGER9 1070 +#define IDF_INTEGER10 1071 +#define IDD_SELNODE 118 +#define IDNEXT 1072 +#define IDD_SELELT 119 +#define IDD_ELTERR 120 +#define ID_DRAG 40052 +#define ID_DELM 40103 +#define ID_FILL 40102 +#define IDF_Delete 1073 +#define IDFROTATE 1074 +#define IDF_RADIO11 1057 +#define ID_GETELM 40053 +#define ID_mapm 40054 +#define ID_map 40055 +#define IDD_GETINTP 160 +#define ID_SBIN 40057 +#define IDD_headertp 121 +#define ID_TRIAN 40058 +#define ID_SWMAP 40059 +#define ID_SWRM1 40062 +#define IDD_TRIAN 122 +#define IDD_NODERR 123 +#define IDF_STRING25 1106 +#define IDF_STRING26 1107 +#define IDF_STRING27 1108 +#define IDF_STRING28 1109 +#define IDF_STRING29 1110 +#define IDF_STRING30 1111 +#define IDF_STRING31 1112 +#define IDF_STRING32 1113 +#define IDF_STRING33 1114 +#define IDF_STRING34 1115 +#define IDD_SELTFL2 148 +#define ID_LOADRM1 40063 +#define ID_cdata 40066 +#define ID_SELRM1 40068 +#define ID_addmesh 40069 +#define ID_MRGMESH 40070 +#define ID_ITEM22 40072 +#define ID_ALLNODES 40073 +#define ID_UNUSNODES 40074 +#define ID_TRIANG 40075 +#define IDD_TRIANG 124 +#define IDD_QUAD 125 +#define ID_QUAD 40076 +#define ID_JOIN 40104 +#define ID_CSEC 40077 +#define ID_CRSCAL 40078 +#define ID_SAVCRS 40079 +#define ID_crsf 40080 +#define IDD_DIALOG06 126 +#define IDF_RADIO13 1076 +#define IDF_RADIO12 1058 +#define IDD_GETFPN 154 +#define IDD_GETINT 153 +#define ID_CSLOC 40081 +#define IDD_CSLOC 127 +#define ID_UNDO 40082 +#define ID_UNDOS 40083 +#define ID_CREATM 40084 +#define IDD_CREATM 128 +#define IDD_TEMPLATE001 129 +#define IDF_GRID1 1075 +#define ISS1 1077 +#define ISS2 1078 +#define ISS3 1079 +#define IDD_CREATM1 130 +#define ID_CGEN 40085 +#define IDF_STRING35 1042 +#define IDD_ORDEROUT 131 +#define IDD_TEMPLATE002 132 +#define IDF_RADIO14 1080 +#define IDF_RADIO15 1081 +#define IDF_RADIO16 1082 +#define ID_selarea 40086 +#define ID_crsect 40087 +#define IDD_selcrsec 133 +#define IDD_TEMPLATE003 134 +#define ISS4 1083 +#define ISS5 1084 +#define IDD_LIMITS 135 +#define IDF_RADIO17 1059 +#define IDD_lAY 136 +#define IDD_TEMPLATE004 137 +#define ISS6 1085 +#define ISS7 1086 +#define ID_EDLAY 40088 +#define IDF_RADIO18 1062 +#define ID_ORDR 40089 +#define ID_ORDR1 40090 +#define id_chk 2002 +#define id_chck 2001 +#define idchk 2003 +#define ID_SPLITN 40091 +#define IDD_DISPLIT 138 +#define IDD_DIRSPLIT 139 +#define ID_OUTLAY 40093 +#define ID_FORM999 40092 +#define ID_g1d 40094 +#define IDD_SETOPT 140 +#define ID_CCLN 40095 +#define ID_CHKCCLN 40096 +#define ID_GOUTLIN 40097 +#define ID_XOUTLIN 40098 +#define IDD_SETMAXMAP 141 +#define ID_RESETLIM 40099 +#define IDD_MLIMITS 143 +#define IDD_VIEWANG 174 +#define ID_3DVIEW 40100 +#define ID_VIEWANGLE 40101 +#define ID_ROTATE 40106 +#define ID_RESETRG 40105 +#define IDD_CHKOPT 142 +#define ID_ITEM103 40107 +#define ID_SECGRP 40108 +#define IDD_SETSEL 144 +#define ID_SELPR 40109 +#define IDD_CHK1DOPT 145 +#define ID_VROTATE 40110 +#define id_mchck 40111 +#define ID_MOVMESH 40112 +#define IDD_DIALOG047 146 +#define IDD_DIALOG048 147 +#define ID_SELELTYP 40113 +#define IDD_SELELTYP 149 +#define ID_OPENGP 40114 +#define ID_SAVGP 40115 +#define IDF_RADIO19 1063 +#define ID_IGPN 40116 +#define ID_IGPC 40117 +#define ID_DISPTYP 40118 +#define ID_TRANSFORM 40119 +#define IDD_TRANSFORM 151 +#define ID_deletelm 40120 +#define IDD_ELTERR2 152 +#define ID_FORM2D 40121 +#define ID_JOINALL 40122 +#define ID_MOVGRP 40123 +#define ID_CRGRID 40124 +#define IDD_GENBLK 155 +#define ID_SETUPLEV 40125 +#define IDD_SETWRS 156 +#define ID_findnode 40126 +#define ID_findelem 40127 +#define IDD_FORMLINE 157 +#define ID_FILLAGAP 40129 +#define IDD_MATTYP 158 +#define ID_ITEM126 40130 +#define ID_SETTYPLEV 40131 +#define IDD_LEVSETTYP 159 +#define ID_Complex 40132 +#define ID_attach 40133 +#define IDD_CHSTYP 161 +#define ID_SAVSHP 40128 +#define ID_ADDMAP 40134 +#define ID_OUTLINFL 40135 +#define ID_GETSTRESSFIL 40136 +#define IDD_FBED 162 +#define IDD_SETYRDT 163 +#define ID_SMOOTHMAP 40137 +#define IDD_GETINTR 164 +#define ID_RVSDIAG 40138 +#define ID_TESTOUT 40139 +#define ID_LOADELTLD 40140 +#define ID_SHOWELTLD 40141 +#define IDD_CHOOSEMODEL 165 +#define IDD_SETUPELDISP 166 +#define ID_SAVELTLD 40142 +#define ID_RESHOWELTLD 40143 +#define ID_ASSIGNELTLD 40144 +#define ID_FILLTR 40145 +#define IDD_FTRIAN 167 +#define ID_addmeshtr 40146 +#define ID_UNDOGEN 40147 +#define IDD_GETFL 168 +#define ID_DDRAW 40148 + +/////////////////////////////////////////////////// +// +// Dialogs +// +IDD_DIALOG02 DIALOG 0, 0, 402, 255 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT CONTOURS" +BEGIN + CONTROL "Computed max and min",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 20, 120, 8 + CONTROL "Over-riding maximum limit",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 48, 120, 8 + CONTROL "Over-riding minimum limit",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 68, 120, 8 + CONTROL "c-max",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 150, 17, 40, 14 + CONTROL "c-min",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 200, 17, 40, 14 + CONTROL "Max",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 160, 45, 40, 14 + CONTROL "Min",IDF_STRING22,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 160, 65, 40, 14 + CONTROL "Number",IDF_STRING23,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 160, 85, 40, 14 + CONTROL " Accept values",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 250, 8, 100, 10 + CONTROL " Use logarithmic interval",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 250, 28, 100, 10 + CONTROL " Recompute use input limits to set values",IDF_CHECK3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 250, 48, 144, 10 + CONTROL " Use values input below",IDF_CHECK4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 250, 68, 100, 10 + CONTROL " Retain these values",IDF_CHECK5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 250, 88, 100, 10 + CONTROL "v1",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 111, 40, 14 + CONTROL "String",IDF_STRING5,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 80, 111, 40, 14 + CONTROL "String",IDF_STRING6,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 140, 111, 40, 14 + CONTROL "String",IDF_STRING7,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 200, 111, 40, 14 + CONTROL "String",IDF_STRING8,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 260, 111, 40, 14 + CONTROL "v6",IDF_STRING9,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 320, 111, 40, 14 + CONTROL "String",IDF_STRING10,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 20, 133, 40, 14 + CONTROL "String",IDF_STRING11,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 80, 133, 40, 14 + CONTROL "String",IDF_STRING12,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 140, 133, 40, 14 + CONTROL "String",IDF_STRING13,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 200, 133, 40, 14 + CONTROL "String",IDF_STRING14,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 260, 133, 40, 14 + CONTROL "v12",IDF_STRING15,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 320, 133, 40, 14 + CONTROL "String",IDF_STRING16,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 19, 155, 40, 14 + CONTROL "String",IDF_STRING17,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 79, 155, 40, 14 + CONTROL "String",IDF_STRING18,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 139, 155, 40, 14 + CONTROL "String",IDF_STRING19,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 201, 155, 40, 14 + CONTROL "String",IDF_STRING20,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 259, 155, 40, 14 + CONTROL "v18",IDF_STRING21,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 319, 155, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 181, 228, 40, 14 + CONTROL "Number of contours",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 88, 120, 8 + CONTROL "String",IDF_STRING25,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 78, 176, 40, 14 + CONTROL "String",IDF_STRING26,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 138, 176, 40, 14 + CONTROL "String",IDF_STRING27,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 200, 176, 40, 14 + CONTROL "String",IDF_STRING28,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 259, 176, 40, 14 + CONTROL "String",IDF_STRING29,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 320, 176, 40, 14 + CONTROL "v18",IDF_STRING30,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 20, 198, 40, 14 + CONTROL "String",IDF_STRING24,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 20, 176, 40, 14 + CONTROL "String",IDF_STRING31,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 79, 197, 40, 14 + CONTROL "String",IDF_STRING32,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 139, 197, 40, 14 + CONTROL "String",IDF_STRING33,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 201, 197, 40, 14 + CONTROL "String",IDF_STRING34,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 259, 197, 40, 14 + CONTROL "v18",IDF_STRING35,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 319, 197, 40, 14 +END + +IDD_DIALOG02 RCDATA +BEGIN +"[Checks] \n" +" 1036 1 \n" +" 1037 0 \n" +" 1038 0 \n" +" 1039 0 \n" +" 1040 0 \n" +,0 +END + +IDD_DIALOG1 DIALOG 0, 0, 182, 79 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 10, "MS Sans Serif" +CAPTION "TITLE" +BEGIN + CONTROL "",IDF_STRING24,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 0, 24, 181, 20 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 74, 52, 40, 14 + CONTROL "Enter Title for Ouput File",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 32, 4, 136, 14 +END + +IDD_DIALOG04 DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "ERROR" +BEGIN + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 56, 40, 14 + CONTROL "Error in Data -- Press OK and Re-enter Values as Needed",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 15, 20, 130, 16 +END + +IDD_DIALOG04 RCDATA +BEGIN +"[Colours] \n" +" 1 256 256 256 255 000 000 \n" +" 1001 000 000 000 255 000 000 \n" +,0 +END + +IDD_DIALOG05 DIALOG 0, 0, 260, 116 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "MAP DISPLAY OPTIONS" +BEGIN + CONTROL "Map-3",IDF_CMAP3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 200, 12, 40, 14 + CONTROL "Map-4",IDF_CMAP4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 20, 36, 40, 14 + CONTROL "Map-5",IDF_CMAP5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 80, 36, 40, 14 + CONTROL "Map-6",IDF_CMAP6,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 140, 36, 40, 14 + CONTROL "Map-7",IDF_CMAP7,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 200, 36, 40, 14 + CONTROL "Map-8",IDF_CMAP8,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 20, 60, 40, 14 + CONTROL "Map-9",IDF_CMAP9,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 80, 60, 40, 14 + CONTROL "Map-0",IDF_CMAP0,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 20, 12, 40, 14 + CONTROL "Map-1",IDF_CMAP1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 80, 12, 40, 14 + CONTROL "Map-2",IDF_CMAP2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 140, 12, 40, 14 + CONTROL "Map-10",IDF_CMAP10,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 140, 60, 40, 14 + CONTROL "Map-11",IDF_CMAP11,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 200, 60, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 112, 92, 40, 14 +END + +IDD_DIALOG05 RCDATA +BEGIN +"[Checks] \n" +" 1012 0 \n" +" 1043 0 \n" +" 1044 0 \n" +" 1045 0 \n" +" 1046 0 \n" +" 1005 0 \n" +" 1006 0 \n" +" 1007 0 \n" +" 1008 0 \n" +" 1009 0 \n" +" 1010 0 \n" +" 1011 0 \n" +"[Colours] \n" +" 1012 256 256 256 128 255 128 \n" +" 1043 256 256 256 128 255 128 \n" +" 1044 256 256 256 128 255 128 \n" +" 1045 256 256 256 128 255 128 \n" +" 1046 256 256 256 128 255 128 \n" +" 1005 256 256 256 128 255 128 \n" +" 1006 256 256 256 128 255 128 \n" +" 1007 256 256 256 128 255 128 \n" +" 1008 256 256 256 128 255 128 \n" +" 1009 256 256 256 128 255 128 \n" +" 1010 256 256 256 128 255 128 \n" +" 1011 256 256 256 128 255 128 \n" +,0 +END + +IDD_DIALOG006 DIALOG 0, 0, 199, 183 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT DISPLAY OPTIONS" +BEGIN + CONTROL "Map",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 12, 40, 14 + CONTROL "Outline",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 80, 12, 40, 14 + CONTROL "Network",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 140, 12, 40, 14 + CONTROL "Nodes",IDF_RADIO4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 32, 40, 14 + CONTROL "B-elev",IDF_RADIO5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 52, 40, 14 + CONTROL "Elements",IDF_RADIO6,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 80, 32, 40, 14 + CONTROL "Type",IDF_RADIO7,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 80, 52, 40, 14 + CONTROL "Data",IDF_RADIO8,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 140, 32, 40, 14 + CONTROL "Grid",IDF_RADIO9,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 140, 52, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 80, 148, 40, 14 + CONTROL "CC-lines",IDF_RADIO10,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 80, 40, 14 + CONTROL "Con Str",IDF_RADIO11,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 142, 80, 38, 14 +END + +IDD_DIALOG006 RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1049 0 \n" +" 1050 0 \n" +" 1051 0 \n" +" 1052 0 \n" +" 1053 0 \n" +" 1054 0 \n" +" 1055 0 \n" +" 1056 0 \n" +" 1057 0 \n" +,0 +END + +IDD_DIALOG07 DIALOG 0, 0, 213, 170 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SAVE OPTIONS" +BEGIN + CONTROL "Skip checking and then save",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 34, 40, 146, 17 + CONTROL "Terminate save",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 34, 56, 146, 17 + CONTROL "Execute fill then save",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 34, 72, 146, 17 + CONTROL "You have entered save without executing fill",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | SS_LEFT, 34, 16, 146, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 87, 144, 40, 14 + CONTROL "Continue checking",IDF_RADIO4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 34, 88, 146, 17 + CONTROL "Note that if checking is continued without fill, Checks for duplicate elements are ineffective",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | SS_LEFT, 38, 116, 138, 20 +END + +IDD_DIALOG07 RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1049 0 \n" +" 1050 0 \n" +"[Colours] \n" +" 1001 256 256 256 255 255 128 \n" +" 1002 256 256 256 255 255 128 \n" +,0 +END + +IDD_DIALOG08 DIALOG 0, 0, 140, 88 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT CCLINE TYPES" +BEGIN + CONTROL "Save corner nodes only",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 12, 102, 14 + CONTROL "Save corner and mid-sides",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 36, 100, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 50, 64, 40, 14 +END + +IDD_DIALOG08 RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +,0 +END + +IDD_DIALOG09 DIALOG 0, 0, 160, 86 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "RMAGEN INFO" +BEGIN + CONTROL "RMAGEN Version 8.3 Nov 2014",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 14, 8, 130, 12 + CONTROL "Resource Modelling Associates",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_CENTER, 20, 36, 120, 12 + CONTROL "Sydney, NSW Australia",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_CENTER, 20, 48, 118, 12 + CONTROL "Copyright",IDF_LABEL7,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 22, 24, 118, 8 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 64, 40, 14 +END + +IDD_DIALOG10 DIALOG 0, 0, 320, 115 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT PROPERTIES" +BEGIN + CONTROL "Number of figures beyond decimal",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 20, 60, 16 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 20, 40, 16 + CONTROL "Frequency for display",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 44, 60, 16 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 44, 40, 16 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 140, 88, 40, 14 + CONTROL "Draw as colour dots",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 180, 14, 120, 10 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 260, 57, 40, 14 + CONTROL "Radius of dot circle (m)",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 180, 56, 60, 16 + CONTROL "Colour interval (m)",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 181, 36, 60, 12 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 261, 32, 40, 14 +END + +IDD_DIALOG10 RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_DIALOG010 DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT CONTINUITY LINE NUMBER" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 104, 28, 42, 14 + CONTROL " Continuity line number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | SS_LEFT, 20, 28, 76, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 56, 52, 40, 14 +END + +IDD_DIALOG010 RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1001 256 256 256 255 255 255 \n" +,0 +END + +IDD_DIALOG001 DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT REORDERING LIST NUMBER" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 104, 28, 42, 14 + CONTROL "List Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | SS_CENTER, 20, 28, 76, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 56, 52, 40, 14 +END + +IDD_DIALOG001 RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1001 256 256 256 255 255 255 \n" +,0 +END + +IDD_DIALOG012 DIALOG 0, 0, 300, 224 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT ACTIVE BACKGROUND COLOURS AND FILES" +BEGIN + CONTROL "",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 36, 180, 12 + CONTROL "",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 50, 180, 12 + CONTROL "",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 64, 180, 12 + CONTROL "",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 78, 180, 12 + CONTROL "",IDF_STRING5,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 92, 180, 12 + CONTROL "",IDF_STRING6,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 106, 180, 12 + CONTROL "",IDF_STRING7,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 120, 180, 12 + CONTROL "",IDF_STRING8,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 134, 180, 12 + CONTROL "",IDF_STRING9,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 148, 180, 12 + CONTROL "",IDF_STRING10,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 162, 180, 12 + CONTROL "",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 36, 40, 14 + CONTROL "",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 50, 40, 14 + CONTROL "",IDF_CHECK3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 64, 40, 14 + CONTROL "",IDF_CHECK4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 78, 40, 14 + CONTROL "",IDF_CHECK5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 92, 40, 14 + CONTROL "",IDF_CHECK6,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 106, 40, 14 + CONTROL "",IDF_CHECK7,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 120, 40, 14 + CONTROL "",IDF_CHECK8,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 134, 40, 14 + CONTROL "",IDF_CHECK9,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 148, 40, 14 + CONTROL "",IDF_CHECK10,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 240, 162, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 130, 196, 40, 14 + CONTROL "Grey Background on",IDF_CHECK11,"BUTTON",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 106, 12, 86, 14 +END + +IDD_DIALOG012 RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +" 1037 0 \n" +" 1038 0 \n" +" 1039 0 \n" +" 1040 0 \n" +" 1041 0 \n" +" 1042 0 \n" +" 1043 0 \n" +" 1044 0 \n" +" 1045 0 \n" +" 1059 0 \n" +"[Colours] \n" +" 1013 256 256 256 255 255 128 \n" +" 1014 256 256 256 255 255 128 \n" +" 1015 256 256 256 255 255 128 \n" +" 1016 256 256 256 255 255 128 \n" +" 1017 256 256 256 255 255 128 \n" +" 1018 256 256 256 255 255 128 \n" +" 1019 256 256 256 255 255 128 \n" +" 1020 256 256 256 255 255 128 \n" +" 1021 256 256 256 255 255 128 \n" +" 1022 256 256 256 255 255 128 \n" +" 1059 256 256 256 255 255 128 \n" +,0 +END + +IDD_REGST DIALOG 0, 0, 322, 183 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "REGISTER BACKGROUND LOCATION" +BEGIN + CONTROL "1st Value from Image",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 220, 12, 66, 12 + CONTROL "X coordinate",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 32, 40, 8 + CONTROL "Y coordinate",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 48, 40, 8 + CONTROL " 2nd True Location",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 48, 68, 76, 12 + CONTROL "Y coordinate",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 112, 40, 8 + CONTROL "X coordinate",IDF_LABEL6,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 92, 40, 8 + CONTROL " 1st True Location",IDF_LABEL7,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 46, 12, 74, 12 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 80, 32, 60, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 82, 48, 58, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 82, 88, 58, 14 + CONTROL "0.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 82, 108, 58, 14 + CONTROL "X coordinate",IDF_LABEL8,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 36, 40, 8 + CONTROL "Y coordinate",IDF_LABEL9,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 48, 40, 8 + CONTROL "X coordinate",IDF_LABEL10,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 92, 40, 8 + CONTROL "Y coordinate",IDF_LABEL11,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 112, 40, 8 + CONTROL "0.0000",IDF_REAL5,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 241, 35, 56, 14 + CONTROL "0.0000",IDF_REAL6,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 48, 58, 11 + CONTROL "0.0000",IDF_REAL7,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 92, 60, 14 + CONTROL "0.0000",IDF_REAL8,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 112, 58, 14 + CONTROL "2nd Value from Image",IDF_LABEL12,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 220, 70, 67, 9 + CONTROL "Adjust Register",IDADJUST,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 20, 148, 52, 12 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 141, 148, 40, 14 + CONTROL "Switch Point",IDFSWITCH,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 246, 148, 54, 14 +END + +IDD_REGST RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_SLRGNO DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT REGISTER POINT NUMBER" +BEGIN + CONTROL "Choose Point Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 20, 24, 60, 16 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 24, 42, 16 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 58, 56, 40, 14 +END + +IDD_SLRGNO RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_CONFIRM DIALOG 0, 0, 322, 171 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "CONFIRM REGISTER LOCATIONS" +BEGIN + CONTROL "Current upper right",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 220, 12, 66, 12 + CONTROL "X coordinate",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 32, 40, 8 + CONTROL "Y coordinate",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 48, 40, 8 + CONTROL "Proposed lower left",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 48, 68, 76, 12 + CONTROL "Y coordinate",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 112, 40, 8 + CONTROL "X coordinate",IDF_LABEL6,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 92, 40, 8 + CONTROL "Current lower left",IDF_LABEL7,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 46, 12, 74, 12 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 80, 32, 60, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 82, 48, 58, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 82, 88, 58, 14 + CONTROL "0.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 82, 108, 58, 14 + CONTROL "X coordinate",IDF_LABEL8,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 36, 40, 8 + CONTROL "Y coordinate",IDF_LABEL9,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 48, 40, 8 + CONTROL "X coordinate",IDF_LABEL10,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 92, 40, 8 + CONTROL "Y coordinate",IDF_LABEL11,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 180, 112, 40, 8 + CONTROL "0.0000",IDF_REAL5,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 241, 35, 56, 14 + CONTROL "0.0000",IDF_REAL6,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 48, 58, 11 + CONTROL "0.0000",IDF_REAL7,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 92, 60, 14 + CONTROL "0.0000",IDF_REAL8,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 112, 58, 14 + CONTROL "Proposed upper right",IDF_LABEL12,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 220, 70, 66, 9 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 82, 140, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 199, 140, 40, 14 +END + +IDD_CONFIRM RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_nodedata DIALOG 0, 0, 334, 175 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Node Data" +BEGIN + CONTROL "Node Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 34, 20, 66, 8 + CONTROL "X-coordinate",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 34, 36, 66, 8 + CONTROL "Y-coordinate",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 34, 52, 66, 8 + CONTROL "Bed Elevation",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 34, 68, 66, 8 + CONTROL "Bottom Width",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 20, 66, 8 + CONTROL "Side Slope 1",IDF_LABEL6,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 36, 66, 8 + CONTROL "Side Slope 2",IDF_LABEL7,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 52, 66, 8 + CONTROL "Storage Width",IDF_LABEL8,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 68, 66, 8 + CONTROL "Storage Base Elevation",IDF_LABEL9,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 84, 77, 8 + CONTROL "Storage Slope",IDF_LABEL10,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 100, 66, 8 + CONTROL "Bed Slope",IDF_LABEL11,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 170, 116, 66, 8 + CONTROL "Elevation Locked",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 34, 88, 126, 11 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE | ES_READONLY, 110, 19, 50, 12 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 110, 36, 50, 12 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 110, 51, 50, 12 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 110, 67, 50, 12 + CONTROL "0.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 19, 50, 12 + CONTROL "0.0000",IDF_REAL5,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 35, 50, 12 + CONTROL "0.0000",IDF_REAL6,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 50, 50, 12 + CONTROL "0.0000",IDF_REAL7,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 66, 50, 12 + CONTROL "0.0000",IDF_REAL8,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 82, 50, 12 + CONTROL "0.0000",IDF_REAL9,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 97, 50, 12 + CONTROL "0.0000",IDF_REAL10,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 250, 114, 50, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 140, 40, 14 + CONTROL "NEXT",IDNEXT,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 147, 140, 40, 14 + CONTROL "CANCEL",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 236, 140, 40, 14 +END + +IDD_nodedata RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_eltdata DIALOG 0, 0, 352, 156 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Element Data" +BEGIN + CONTROL "Element Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 70, 12, 70, 8 + CONTROL "Element Connections",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 141, 34, 70, 8 + CONTROL "0",IDF_INTEGER2,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 20, 50, 30, 12 + CONTROL "0",IDF_INTEGER3,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 60, 50, 30, 12 + CONTROL "0",IDF_INTEGER4,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 50, 30, 12 + CONTROL "0",IDF_INTEGER5,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 140, 50, 30, 12 + CONTROL "0",IDF_INTEGER6,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 180, 50, 30, 12 + CONTROL "0",IDF_INTEGER7,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 220, 50, 30, 12 + CONTROL "0",IDF_INTEGER8,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 260, 50, 30, 12 + CONTROL "0",IDF_INTEGER9,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 300, 50, 30, 12 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE | ES_READONLY, 180, 10, 40, 14 + CONTROL "Element Type Number",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 70, 72, 70, 8 + CONTROL "0",IDF_INTEGER10,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 180, 68, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 40, 96, 40, 14 + CONTROL "NEXT",IDNEXT,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 116, 96, 40, 14 + CONTROL "CANCEL",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 270, 96, 40, 14 + CONTROL "DELETE",IDF_Delete,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 195, 96, 40, 14 + CONTROL "ROTATE",IDFROTATE,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 156, 124, 40, 14 +END + +IDD_eltdata RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_SELNODE DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Select Node Number" +BEGIN + CONTROL "Node Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 26, 21, 54, 8 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 18, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 46, 40, 14 +END + +IDD_SELNODE RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_SELELT DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Select Element Number" +BEGIN + CONTROL "Element Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 26, 21, 54, 8 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 18, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 46, 40, 14 +END + +IDD_SELELT RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_ELTERR DIALOG 0, 0, 160, 105 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Element Data Error" +BEGIN + CONTROL "ERROR IN ELEMENT CONNECTIONS",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 15, 12, 130, 8 + CONTROL "Remove Element by Deleting Connections",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 12, 28, 136, 8 + CONTROL "Element Number",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 23, 58, 58, 8 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 101, 57, 38, 11 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 78, 40, 14 + CONTROL "or Edit Entries",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 57, 40, 46, 8 +END + +IDD_ELTERR RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1001 256 256 256 255 128 000 \n" +,0 +END + +IDD_GETINTP DIALOG 0, 0, 194, 126 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Set Interpolation" +BEGIN + CONTROL "Number of X interpolation points",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 17, 100, 8 + CONTROL "Number of Y interpolation points",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 20, 37, 100, 8 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 125, 15, 40, 14 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 125, 35, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 72, 100, 40, 14 + CONTROL "X-interpolation interval",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 58, 100, 8 + CONTROL "Y-interpolation interval",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 78, 100, 8 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 125, 55, 40, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 125, 75, 40, 14 +END + +IDD_GETINTP RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_headertp DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT HEADER TYPE" +BEGIN + CONTROL "Little Endian",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 24, 10, 112, 14 + CONTROL "Big Endian",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 24, 26, 112, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 52, 40, 14 +END + +IDD_headertp RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +,0 +END + +IDD_TRIAN DIALOG 0, 0, 260, 100 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "TRIANGULARIZATION OPTIONS" +BEGIN + CONTROL "Data frequency (default=1)",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 22, 100, 10 + CONTROL "Minimum spacing (default = 0.0)",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 40, 110, 10 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 21, 60, 12 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 39, 60, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 110, 67, 40, 14 +END + +IDD_TRIAN RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_NODERR DIALOG 0, 0, 240, 111 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "ERROR IN FILL PROCESS" +BEGIN + CONTROL "MAXIMUM NUMBER OF ELEMENTS CONNECTED",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 36, 8, 168, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 110, 89, 40, 14 + CONTROL "ALLOWABLE LIMIT IS",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 50, 80, 12 + CONTROL "CONNECTIONS DETECTED",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 67, 96, 12 + CONTROL "0",IDF_INTEGER2,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 50, 40, 12 + CONTROL "0",IDF_INTEGER3,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 161, 66, 40, 12 + CONTROL " TO NODE EXCEEDED",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 80, 20, 80, 10 + CONTROL "FILL TERMINATED",IDF_LABEL6,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 87, 30, 65, 11 +END + +IDD_NODERR RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1002 256 256 256 255 255 128 \n" +" 1042 256 256 256 255 255 128 \n" +" 1005 256 256 256 255 255 128 \n" +,0 +END + +IDD_SELTFL2 DIALOG 0, 0, 400, 224 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION " SELECT FILE" +BEGIN + CONTROL "",IDF_STRING25,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 36, 340, 12 + CONTROL "",IDF_STRING26,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 50, 340, 12 + CONTROL "",IDF_STRING27,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 64, 340, 12 + CONTROL "",IDF_STRING28,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 78, 340, 12 + CONTROL "",IDF_STRING29,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 92, 340, 12 + CONTROL "",IDF_STRING30,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 106, 340, 12 + CONTROL "",IDF_STRING31,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 120, 340, 12 + CONTROL "",IDF_STRING32,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 134, 340, 12 + CONTROL "",IDF_STRING33,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 148, 340, 12 + CONTROL "",IDF_STRING34,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 162, 340, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 88, 196, 40, 14 + CONTROL "",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 36, 20, 12 + CONTROL "",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 50, 20, 12 + CONTROL "",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 64, 20, 12 + CONTROL "",IDF_RADIO4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 78, 20, 12 + CONTROL "",IDF_RADIO5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 92, 20, 12 + CONTROL "",IDF_RADIO6,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 106, 20, 12 + CONTROL "",IDF_RADIO7,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 120, 20, 12 + CONTROL "",IDF_RADIO8,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 134, 20, 12 + CONTROL "",IDF_RADIO9,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 148, 20, 12 + CONTROL "",IDF_RADIO10,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_TEXT, 20, 162, 20, 12 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 278, 195, 40, 14 +END + +IDD_SELTFL2 RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1049 0 \n" +" 1050 0 \n" +" 1051 0 \n" +" 1052 0 \n" +" 1053 0 \n" +" 1054 0 \n" +" 1055 0 \n" +" 1056 0 \n" +"[Colours] \n" +" 1106 256 256 256 255 255 128 \n" +" 1107 256 256 256 255 255 128 \n" +" 1108 256 256 256 255 255 128 \n" +" 1109 256 256 256 255 255 128 \n" +" 1110 256 256 256 255 255 128 \n" +" 1111 256 256 256 255 255 128 \n" +" 1112 256 256 256 255 255 128 \n" +" 1113 256 256 256 255 255 128 \n" +" 1114 256 256 256 255 255 128 \n" +" 1115 256 256 256 255 255 128 \n" +,0 +END + +IDD_TRIANG DIALOG 0, 0, 197, 103 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "TRIANGULAR BLOCK" +BEGIN + CONTROL "Elements on side 1",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 18, 62, 8 + CONTROL "Elements on side 2",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 30, 62, 8 + CONTROL "Elements on side 3",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 42, 62, 8 + CONTROL "1",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 16, 40, 12 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 30, 40, 12 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 42, 40, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 80, 64, 40, 14 +END + +IDD_TRIANG RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_QUAD DIALOG 0, 0, 197, 103 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "QUADRILATERAL BLOCK" +BEGIN + CONTROL "Elements on side 1",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 18, 62, 8 + CONTROL "Elements on side 2",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 32, 62, 8 + CONTROL "Elements on side 3",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 46, 62, 8 + CONTROL "1",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 16, 40, 12 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 30, 40, 12 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 44, 40, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 80, 79, 40, 14 + CONTROL "Elements on side 4",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 41, 60, 62, 8 + CONTROL "0",IDF_INTEGER4,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 58, 40, 12 +END + +IDD_QUAD RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_DIALOG06 DIALOG 0, 0, 316, 202 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT DISPLAY OPTIONS" +BEGIN + CONTROL "Map",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 12, 40, 14 + CONTROL "Outline",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 80, 12, 40, 14 + CONTROL "Network",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 200, 12, 40, 14 + CONTROL "Nodes",IDF_RADIO4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 20, 36, 40, 14 + CONTROL "B-elev",IDF_RADIO5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 80, 36, 40, 14 + CONTROL "Layers",IDF_RADIO17,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 140, 36, 40, 14 + CONTROL "No nodal display",IDF_RADIO18,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 198, 36, 80, 14 + CONTROL "Elements",IDF_RADIO6,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 60, 40, 14 + CONTROL "Type",IDF_RADIO7,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 80, 60, 40, 14 + CONTROL "Group",IDF_RADIO19,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 140, 60, 40, 14 + CONTROL "Data",IDF_RADIO8,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 260, 57, 40, 14 + CONTROL "Grid",IDF_RADIO9,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 140, 12, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 200, 137, 40, 14 + CONTROL "CC-lines",IDF_RADIO10,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 260, 12, 40, 14 + CONTROL "Con Str",IDF_RADIO11,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 200, 58, 40, 14 + CONTROL "1-D cross-sec locactions",IDF_RADIO12,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 160, 91, 100, 14 + CONTROL "Cross-sec weighting factors",IDF_RADIO13,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 160, 109, 100, 14 + CONTROL "Display 1-D as input RM1 width",IDF_RADIO14,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 21, 93, 108, 16 + CONTROL "Display 1-D as computed width",IDF_RADIO15,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 21, 109, 108, 16 + CONTROL "Display 1-D as computed area",IDF_RADIO16,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 21, 126, 108, 16 + CONTROL "Nominal Elevation",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 151, 62, 12 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 88, 150, 40, 14 + CONTROL "Width scale factor",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 168, 62, 12 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 88, 167, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 200, 169, 40, 14 +END + +IDD_DIALOG06 RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1049 0 \n" +" 1050 0 \n" +" 1051 0 \n" +" 1059 0 \n" +" 1062 0 \n" +" 1052 0 \n" +" 1053 0 \n" +" 1063 0 \n" +" 1054 0 \n" +" 1055 0 \n" +" 1056 0 \n" +" 1057 0 \n" +" 1058 0 \n" +" 1076 0 \n" +" 1080 0 \n" +" 1081 0 \n" +" 1082 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_GETFPN DIALOG 0, 0, 160, 89 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "ENTER FLOATING POINT" +BEGIN + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 60, 32, 40, 14 + CONTROL "",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | ES_LEFT | ES_CENTER | ES_MULTILINE | ES_UPPERCASE | ES_READONLY, 15, 8, 130, 16 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 59, 40, 14 +END + +IDD_GETFPN RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1013 256 256 256 255 255 255 \n" +"[Formats] \n" +,0 +END + +IDD_GETINT DIALOG 0, 0, 181, 88 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "ENTER INTEGER" +BEGIN + CONTROL "",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | ES_LEFT | ES_CENTER | ES_MULTILINE | ES_UPPERCASE | ES_READONLY, 13, 8, 154, 16 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 70, 36, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 70, 60, 40, 14 +END + +IDD_GETINT RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1013 256 256 256 255 255 255 \n" +,0 +END + +IDD_CSLOC DIALOG 0, 0, 219, 147 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "GET CROSS-SECTION LOCATIONS" +BEGIN + CONTROL "Cross-section Number",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 35, 27, 74, 12 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 142, 24, 44, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 148, 112, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 35, 112, 40, 14 + CONTROL "After selecting Cross-section number, press OK and click location on network display. Press Cancel to terminate.",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_MULTILINE, 36, 52, 148, 36 +END + +IDD_CSLOC RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_CREATM DIALOG 0, 0, 259, 177 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT CONTOUR LINES AND INTERVALS" +BEGIN + CONTROL "",IDF_GRID1,"ISSGRID",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_VSCROLL | WS_HSCROLL | WS_GROUP | WS_TABSTOP | GS_DEFROWLABELS | GS_COLUMNLABELS, 33, 20, 192, 112 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 62, 144, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 159, 144, 40, 14 +END + +IDD_CREATM RCDATA +BEGIN +"[Grids] \n" +" 1075 3 21 129 \n" +,0 +END + +IDD_TEMPLATE001 DIALOG 0, 0, 1000, 16 +STYLE DS_3DLOOK +FONT 8, "MS Sans Serif" +BEGIN + CONTROL "Activate Contour",ISS1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_TEXT, 0, 0, 60, 14 + CONTROL "Contour value",ISS2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 60, 14 + CONTROL "Nodal interval",ISS3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 60, 14 +END + +IDD_TEMPLATE001 RCDATA +BEGIN +"[Checks] \n" +" 1077 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_CREATM1 DIALOG 0, 0, 200, 120 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "CHOOSE OPTIONS" +BEGIN + CONTROL "Use all contour lines",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 40, 17, 120, 14 + CONTROL "Use same interval for all lines",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 40, 37, 120, 14 + CONTROL "Nodal interval along lines",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 61, 78, 8 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 121, 58, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 40, 85, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 121, 84, 40, 14 +END + +IDD_CREATM1 RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +" 1037 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_ORDEROUT DIALOG 0, 0, 276, 248 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "RE-ORDERING RESULTS" +BEGIN + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 118, 216, 40, 14 + CONTROL "",IDF_GRID1,"ISSGRID",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_VSCROLL | WS_HSCROLL | WS_GROUP | WS_TABSTOP | GS_DEFROWLABELS | GS_COLUMNLABELS | GS_ROWLABELS, 33, 24, 211, 148 + CONTROL "Note that sequence number 0 is original order",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 60, 186, 156, 12 +END + +IDD_ORDEROUT RCDATA +BEGIN +"[Grids] \n" +" 1075 3 101 132 \n" +" 0 \n" +"[Colours] \n" +" 1001 256 256 256 255 255 000 \n" +,0 +END + +IDD_TEMPLATE002 DIALOG 0, 0, 1000, 16 +STYLE DS_3DLOOK +FONT 8, "MS Sans Serif" +BEGIN + CONTROL "SEQUENCE NO.",ISS1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_CENTER | ES_MULTILINE, 0, 0, 63, 14 + CONTROL "RE-ORDERING SUM",ISS2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 80, 14 + CONTROL "MAX-FRONT",ISS3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 55, 14 +END + +IDD_selcrsec DIALOG 0, 0, 225, 123 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT CROSS-SECTION NUMBERS" +BEGIN + CONTROL "",IDF_GRID1,"ISSGRID",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | GS_DEFROWLABELS | GS_COLUMNLABELS, 37, 24, 150, 28 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 52, 97, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 149, 97, 40, 14 + CONTROL "Use automatic axis scales",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 68, 60, 88, 12 + CONTROL "Input axis scales",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 68, 73, 88, 12 +END + +IDD_selcrsec RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +"[Grids] \n" +" 1075 5 1 134 \n" +,0 +END + +IDD_TEMPLATE003 DIALOG 0, 0, 1000, 16 +STYLE DS_3DLOOK +FONT 8, "MS Sans Serif" +BEGIN + CONTROL "SEC-1",ISS1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 30, 14 + CONTROL "SEC-2",ISS2,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 30, 14 + CONTROL "SEC-3",ISS3,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 30, 14 + CONTROL "SEC-4",ISS4,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 30, 14 + CONTROL "SEC-5",ISS5,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 30, 14 +END + +IDD_TEMPLATE003 RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_LIMITS DIALOG 0, 0, 209, 141 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SET CROSS-SECTION AXIS LIMITS" +BEGIN + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 126, 20, 40, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 126, 40, 40, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 126, 60, 40, 14 + CONTROL "0.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 126, 80, 40, 14 + CONTROL "X-Axis Minimum",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 23, 80, 8 + CONTROL "Y-Axis Minimum",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 63, 80, 8 + CONTROL "X-Axis Maximum",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 43, 80, 8 + CONTROL "Y-Axis Maximum",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 82, 80, 8 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 40, 108, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 140, 108, 40, 14 +END + +IDD_LIMITS RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_lAY DIALOG 0, 0, 279, 113 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "LAYER DATA" +BEGIN + CONTROL "Layer type LD2",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 50, 12, 58, 14 + CONTROL "Layer type LD3",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 50, 29, 58, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 88, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 180, 88, 40, 14 + CONTROL "",IDF_GRID1,"ISSGRID",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | GS_DEFROWLABELS | GS_COLUMNLABELS, 16, 52, 248, 28 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 200, 20, 40, 14 + CONTROL "Number of layers",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 140, 23, 52, 8 +END + +IDD_lAY RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +"[Ranges] \n" +"[Grids] \n" +" 1075 7 1 137 \n" +,0 +END + +IDD_TEMPLATE004 DIALOG 0, 0, 1000, 16 +STYLE DS_3DLOOK +FONT 8, "MS Sans Serif" +BEGIN + CONTROL "layer 1",ISS1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 + CONTROL "layer 2",ISS2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 + CONTROL "layer 3",ISS3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 + CONTROL "layer 4",ISS4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 + CONTROL "layer 5",ISS5,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 + CONTROL "layer 6",ISS6,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 + CONTROL "layer 7",ISS7,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 0, 0, 35, 14 +END + +IDD_TEMPLATE004 RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_DISPLIT DIALOG 0, 0, 180, 240 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT SPLIT OPTIONS" +BEGIN + CONTROL "Distance Apart of Split Nodes",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 22, 65, 98, 10 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 122, 64, 38, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 70, 201, 40, 14 + CONTROL "Element type number",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 47, 104, 68, 10 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 123, 102, 35, 12 + CONTROL "Insert elements",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 61, 83, 70, 11 + CONTROL "Add end triangles",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 56, 123, 75, 11 + CONTROL "Direction to split nodes for single node split",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 24, 173, 79, 18 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 122, 176, 38, 12 + CONTROL "Continuity Line Number",IDF_LABEL6,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 22, 46, 98, 10 + CONTROL "Form Line by Clicking Nodes",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 22, 8, 110, 12 + CONTROL "Use Existing Continuity Line",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 22, 27, 110, 12 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 123, 47, 35, 12 + CONTROL "End Element type number",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 34, 144, 80, 10 + CONTROL "0",IDF_INTEGER6,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 142, 35, 12 +END + +IDD_DISPLIT RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +" 1037 0 \n" +" 1047 0 \n" +" 1048 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_DIRSPLIT DIALOG 0, 0, 177, 81 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "DIRECTION OF SPLIT" +BEGIN + CONTROL "Direction to split nodes",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 21, 21, 79, 11 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 122, 20, 38, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 68, 48, 40, 14 +END + +IDD_DIRSPLIT RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_SETOPT DIALOG 0, 0, 160, 103 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Set option" +BEGIN + CONTROL "Set nodal value",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 12, 80, 14 + CONTROL "Apply as adjustment",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 24, 80, 14 + CONTROL "Lock value after adjustment",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 32, 48, 95, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 76, 40, 14 +END + +IDD_SETOPT RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1036 0 \n" +,0 +END + +IDD_SETMAXMAP DIALOG 0, 0, 175, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "RESET MAXIMUM MAP FILE SIZE" +BEGIN + CONTROL "Maximum number of map lines",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 20, 24, 60, 16 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 24, 60, 16 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 58, 56, 40, 14 +END + +IDD_SETMAXMAP RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1001 255 000 000 255 255 000 \n" +,0 +END + +IDD_MLIMITS DIALOG 0, 0, 175, 159 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "RESET LIMITS" +BEGIN + CONTROL "Maximum number of nodes",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 20, 22, 60, 24 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 26, 60, 16 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 68, 127, 40, 14 + CONTROL "Maximum Number of Elements",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 22, 53, 60, 24 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 101, 56, 60, 16 + CONTROL "Maximum Number of Map Points",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_CENTER, 20, 88, 60, 24 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 91, 60, 16 +END + +IDD_MLIMITS RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1001 255 000 000 255 255 000 \n" +" 1002 255 000 000 255 255 000 \n" +" 1003 255 000 000 255 255 000 \n" +,0 +END + +IDD_CHKOPT DIALOG 0, 0, 230, 147 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "CHECK OPTIONS" +BEGIN + CONTROL "Check areas",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 40, 18, 150, 11 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 50, 115, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 140, 115, 40, 14 + CONTROL "Check bed elevation/section differences",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 34, 150, 11 + CONTROL "Check normailized depth/section differences",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 50, 150, 11 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 130, 67, 60, 14 + CONTROL "Reference elevation",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 68, 80, 11 + CONTROL "Additional options for 1-D elements",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 40, 86, 150, 11 +END + +IDD_CHKOPT RCDATA +BEGIN +"[Checks] \n" +" 1036 1 \n" +" 1047 0 \n" +" 1048 0 \n" +" 1037 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_SETSEL DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SET SELECTION FRACTION" +BEGIN + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 18, 40, 14 + CONTROL "Selection fraction",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 20, 60, 8 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 48, 40, 14 +END + +IDD_SETSEL RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_CHK1DOPT DIALOG 0, 0, 200, 116 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SET 1-D OPTIONS" +BEGIN + CONTROL "Check width differences",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 16, 120, 11 + CONTROL "Check area differences",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 35, 120, 11 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 40, 84, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 120, 84, 40, 14 + CONTROL "Reference elevation",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 40, 55, 80, 11 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 54, 40, 14 +END + +IDD_CHK1DOPT RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_VIEWANG DIALOG 0, 0, 219, 263 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Set Viewing Angle and Vertical Scale" +BEGIN + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 33, 40, 14 + CONTROL "90.000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 72, 40, 14 + CONTROL "Angle of View Horizontally",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 29, 90, 10 + CONTROL "Angle of View Looking Down",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 69, 95, 11 + CONTROL "To North = 0.0 to West = 90.0",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 40, 100, 11 + CONTROL "Horizontal = 0.0 Vertical = 90.0",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 80, 114, 11 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 90, 230, 40, 14 + CONTROL "Vertical Scale Factor",IDF_LABEL5,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 109, 95, 11 + CONTROL "1.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 115, 40, 14 + CONTROL "Prototype Dimension per Unit Plot Dimension",IDF_LABEL6,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 120, 114, 16 + CONTROL "Vertical Scale Origin for Contour Plot",IDF_LABEL7,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 21, 154, 95, 17 + CONTROL "Units of Contour Plot",IDF_LABEL8,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 21, 176, 85, 15 + CONTROL "1.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 161, 160, 40, 14 + CONTROL "Hold vertical/horizontal aspect ratio constant",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 22, 202, 176, 14 +END + +IDD_VIEWANG RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_DIALOG047 DIALOG 0, 0, 199, 132 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SET MOVE OPTIONS" +BEGIN + CONTROL "X-Shift or X-Origin for scaling",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 18, 100, 8 + CONTROL "Y-Shift or Y-Origin for scaling",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 40, 100, 8 + CONTROL "X-Scale",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 21, 62, 100, 8 + CONTROL "Y-Scale",IDF_LABEL4,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 82, 100, 8 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 140, 15, 40, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 141, 37, 40, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 141, 59, 40, 14 + CONTROL "0.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 141, 81, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 42, 104, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 120, 104, 40, 14 +END + +IDD_DIALOG047 RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_DIALOG048 DIALOG 0, 0, 160, 90 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT METHOD" +BEGIN + CONTROL "Use fixed shift or scaling",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 20, 12, 120, 14 + CONTROL "Use graphical adjustment",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 20, 35, 120, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 22, 60, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 99, 60, 40, 14 +END + +IDD_DIALOG048 RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +,0 +END + +IDD_SELELTYP DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT ELEMENT TYPE" +BEGIN + CONTROL "Element Type",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 26, 21, 54, 8 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 18, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 46, 40, 14 +END + +IDD_SELELTYP RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_TRANSFORM DIALOG 0, 0, 302, 197 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "TRANSFORM COEFFICIENTS" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 152, 17, 40, 14 + CONTROL "SELECT OPTION",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 75, 16, 66, 14 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 94, 40, 40, 14 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 94, 58, 40, 14 + CONTROL "0",IDF_INTEGER4,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 95, 78, 40, 14 + CONTROL "0",IDF_INTEGER5,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 95, 99, 40, 14 + CONTROL "INT COEFFICIENT 1",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 19, 41, 70, 14 + CONTROL "INT COEFFICIENT 2",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 59, 70, 14 + CONTROL "INT COEFFICIENT 3",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 78, 70, 14 + CONTROL "INT COEFFICIENT 4",IDF_STRING5,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 99, 70, 14 + CONTROL "RL COEFFICIENT 1",IDF_STRING6,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 160, 40, 70, 14 + CONTROL "RL COEFFICIENT 2",IDF_STRING7,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 160, 58, 70, 14 + CONTROL "RL COEFFICIENT 3",IDF_STRING8,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 160, 77, 70, 14 + CONTROL "RL COEFFICIENT 4",IDF_STRING9,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 160, 98, 70, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 40, 40, 14 + CONTROL "0.0000",IDF_REAL4,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 58, 40, 14 + CONTROL "0.0000",IDF_REAL5,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 78, 40, 14 + CONTROL "0.0000",IDF_REAL6,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 241, 96, 40, 14 + CONTROL "INT COEFFICIENT 5",IDF_STRING10,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 120, 70, 14 + CONTROL "0",IDF_INTEGER9,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 95, 120, 40, 14 + CONTROL "RL COEFFICIENT 5",IDF_STRING11,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 160, 119, 70, 14 + CONTROL "0.0000",IDF_REAL7,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 241, 117, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 76, 175, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 188, 174, 40, 14 + CONTROL "INT COEFFICIENT 6",IDF_STRING12,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 144, 70, 14 + CONTROL "0",IDF_INTEGER10,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 94, 144, 40, 14 + CONTROL " RL COEFFICIENT 6",IDF_STRING13,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 160, 143, 70, 14 + CONTROL "0.0000",IDF_REAL8,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 240, 141, 40, 14 +END + +IDD_TRANSFORM RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_ELTERR2 DIALOG 0, 0, 220, 105 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Element Data Error" +BEGIN + CONTROL "ERROR IN ELEMENT CONNECTIONS NODE UNDEFINED",IDF_LABEL1,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 20, 12, 181, 8 + CONTROL "Element Number",IDF_LABEL3,"STATIC",WS_CHILD | WS_VISIBLE | SS_LEFT, 56, 35, 58, 8 + CONTROL "0",IDF_INTEGER1,"INTEGEREDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 123, 33, 38, 11 + CONTROL "YES",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 78, 40, 14 + CONTROL "REMOVE ELEMENT?",IDF_LABEL2,"STATIC",WS_CHILD | WS_VISIBLE | WS_GROUP | SS_LEFT, 75, 56, 70, 8 + CONTROL "NO",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 120, 78, 40, 14 +END + +IDD_ELTERR2 RCDATA +BEGIN +"[Ranges] \n" +"[Colours] \n" +" 1001 256 256 256 255 128 000 \n" +" 1002 256 256 256 255 128 000 \n" +,0 +END + +IDD_GENBLK DIALOG 0, 0, 260, 188 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT GENBLK VALUES" +BEGIN + CONTROL "1",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 180, 22, 40, 12 + CONTROL "10.000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 180, 43, 40, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 110, 156, 40, 14 + CONTROL "Number of Elements in Cross-Section",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 22, 120, 12 + CONTROL "Element Length along Channel",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 40, 43, 100, 12 + CONTROL "Right Bank Map Line Number",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 40, 98, 100, 12 + CONTROL "Left Bank Map Line Number",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 40, 65, 102, 12 + CONTROL "1",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 180, 67, 40, 12 + CONTROL "2",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 180, 100, 40, 12 + CONTROL "Reverse Order",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 158, 83, 60, 10 + CONTROL "Reverse Order",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 158, 112, 60, 10 + CONTROL "Connection Option",IDF_STRING5,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 41, 129, 100, 12 + CONTROL "1",IDF_INTEGER5,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 179, 130, 40, 12 +END + +IDD_GENBLK RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +" 1037 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_SETWRS DIALOG 0, 0, 236, 176 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SETUP LEVEE/WEIR DATA" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 96, 40, 14 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 122, 40, 14 + CONTROL "Element Type for Transformation",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 96, 102, 14 + CONTROL " Incr. on Weir Height for Transition",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 122, 118, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 60, 150, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 140, 150, 40, 14 + CONTROL "Option 1 Add increment to form levee height",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 24, 160, 16,WS_EX_STATICEDGE + CONTROL "Option 2 Use Bed Levels for Height,- Reset Bed",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 49, 160, 16,WS_EX_STATICEDGE + CONTROL "Increment to Form Weir Height",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 75, 96, 14 + CONTROL "0.0000",IDF_REAL2,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 160, 75, 40, 14 +END + +IDD_SETWRS RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +"[Ranges] \n" +"[Colours] \n" +" 1047 256 256 256 255 255 255 \n" +" 1048 256 256 256 255 255 255 \n" +"[Formats] \n" +,0 +END + +IDD_FORMLINE DIALOG 0, 0, 201, 267 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "FORM LINE OPTIONS" +BEGIN + CONTROL "Form Simple Line",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 20, 120, 14 + CONTROL "Form Complex Line",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 36, 120, 14 + CONTROL "Nodal Spacing",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 57, 54, 14 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 57, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 40, 223, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 120, 223, 40, 14 + CONTROL " Input Controls From File",IDF_CHECK3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 40, 196, 120, 14 + CONTROL "Element Type Number",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 123, 72, 14 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 122, 123, 40, 14 + CONTROL "Form Only Nodes",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 75, 120, 14 + CONTROL "Add One-D Elements",IDF_RADIO4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 89, 120, 14 + CONTROL "Add Two-D Elements",IDF_RADIO5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 40, 103, 120, 14 + CONTROL "Number of Elements in Section",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_MULTILINE, 44, 170, 72, 19 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 122, 172, 40, 14 + CONTROL "Starting Structure Number",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 39, 145, 79, 14 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 121, 145, 40, 14 +END + +IDD_FORMLINE RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1038 0 \n" +" 1049 0 \n" +" 1050 0 \n" +" 1051 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_MATTYP DIALOG 0, 0, 160, 80 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Input an Element Type" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 108, 16, 40, 14 + CONTROL "Element Type Number",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 24, 16, 74, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 20, 48, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 100, 49, 40, 14 +END + +IDD_MATTYP RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_LEVSETTYP DIALOG 0, 0, 181, 92 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Set Element by Level" +BEGIN + CONTROL "Bed Elevation",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 16, 70, 12 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 16, 40, 14 + CONTROL "Element Type",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 20, 38, 70, 12 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 120, 37, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 20, 64, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 120, 64, 40, 14 +END + +IDD_LEVSETTYP RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_CHSTYP DIALOG 0, 0, 181, 224 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SELECT DATA SET" +BEGIN + CONTROL "",IDF_STRING25,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 36, 80, 12 + CONTROL "",IDF_STRING26,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 50, 80, 12 + CONTROL "",IDF_STRING27,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 64, 80, 12 + CONTROL "",IDF_STRING28,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 78, 80, 12 + CONTROL "",IDF_STRING29,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 92, 80, 12 + CONTROL "",IDF_STRING30,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 106, 80, 12 + CONTROL "",IDF_STRING31,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 120, 80, 12 + CONTROL "",IDF_STRING32,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 134, 80, 12 + CONTROL "",IDF_STRING33,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 148, 80, 12 + CONTROL "",IDF_STRING34,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 40, 162, 80, 12 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 71, 196, 40, 14 + CONTROL "",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 36, 20, 12 + CONTROL "",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 50, 20, 12 + CONTROL "",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 64, 20, 12 + CONTROL "",IDF_RADIO4,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 78, 20, 12 + CONTROL "",IDF_RADIO5,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 92, 20, 12 + CONTROL "",IDF_RADIO6,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 106, 20, 12 + CONTROL "",IDF_RADIO7,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 120, 20, 12 + CONTROL "",IDF_RADIO8,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 134, 20, 12 + CONTROL "",IDF_RADIO9,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 148, 20, 12 + CONTROL "",IDF_RADIO10,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 120, 162, 20, 12 +END + +IDD_CHSTYP RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1049 0 \n" +" 1050 0 \n" +" 1051 0 \n" +" 1052 0 \n" +" 1053 0 \n" +" 1054 0 \n" +" 1055 0 \n" +" 1056 0 \n" +"[Colours] \n" +" 1106 256 256 256 255 255 128 \n" +" 1107 256 256 256 255 255 128 \n" +" 1108 256 256 256 255 255 128 \n" +" 1109 256 256 256 255 255 128 \n" +" 1110 256 256 256 255 255 128 \n" +" 1111 256 256 256 255 255 128 \n" +" 1112 256 256 256 255 255 128 \n" +" 1113 256 256 256 255 255 128 \n" +" 1114 256 256 256 255 255 128 \n" +" 1115 256 256 256 255 255 128 \n" +,0 +END + +IDD_FBED DIALOG 0, 0, 219, 137 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "FAILED TO INTERPOLATE ALL" +BEGIN + CONTROL "INTERPOLATION FAILURE DETECTED",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 46, 20, 126, 14 + CONTROL "Nodes Failed",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 110, 47, 52, 14 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 51, 46, 40, 14 + CONTROL "Use Adjacent Node Value?",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 67, 72, 84, 14 + CONTROL "YES",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 53, 100, 40, 14 + CONTROL "NO",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 131, 100, 40, 14 +END + +IDD_FBED RCDATA +BEGIN +"[Ranges] \n" +,0 +END + +IDD_SETYRDT DIALOG 0, 0, 219, 157 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "SET YEAR AND DATE" +BEGIN + CONTROL "SET YEAR AND DATE",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 46, 20, 126, 14 + CONTROL "Year",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 48, 39, 52, 14 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 132, 37, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 90, 124, 40, 14 + CONTROL "Month",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 48, 57, 52, 14 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 132, 57, 40, 14 + CONTROL "Day",IDF_STRING4,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 48, 75, 52, 14 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 132, 75, 40, 14 + CONTROL "Hour",IDF_STRING5,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 48, 93, 52, 14 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 132, 93, 40, 14 +END + +IDD_SETYRDT RCDATA +BEGIN +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_GETINTR DIALOG 0, 0, 200, 111 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "GET NUMBER OF ELEMENTS TO REVERSE" +BEGIN + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 139, 20, 40, 14 + CONTROL "Number of pairs to reverse",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 19, 20, 94, 14 + CONTROL "Do Not Reverse Equal Elevations",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 20, 48, 155, 14,WS_EX_STATICEDGE + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 40, 80, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 120, 80, 40, 14 +END + +IDD_GETINTR RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +"[Ranges] \n" +,0 +END + +IDD_CHOOSEMODEL DIALOG 0, 0, 179, 137 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "CHOOSE MODEL" +BEGIN + CONTROL "RMA-2",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 45, 25, 90, 18,WS_EX_STATICEDGE + CONTROL "RMA-10",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 45, 50, 90, 14,WS_EX_STATICEDGE + CONTROL "RMA-11",IDF_RADIO3,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 45, 75, 90, 14,WS_EX_STATICEDGE + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 69, 100, 40, 14 +END + +IDD_CHOOSEMODEL RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1049 0 \n" +,0 +END + +IDD_SETUPELDISP DIALOG 0, 0, 249, 233 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Setup Element Load Display" +BEGIN + CONTROL " Display Maximum Flow",IDF_RADIO1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 69, 14, 110, 14 + CONTROL " Display Cumulative Flow",IDF_RADIO2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_AUTORADIOBUTTON | BS_LEFTTEXT | BS_TEXT, 69, 40, 110, 14 + CONTROL " Use Limited Time Period",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 69, 67, 110, 14 + CONTROL "Start Time",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 104, 88, 40, 14 + CONTROL "YEAR JUL DAY HOUR",IDF_STRING2,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT, 54, 110, 140, 14 + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 54, 127, 40, 14 + CONTROL "0",IDF_INTEGER2,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 127, 40, 14 + CONTROL "0.0000",IDF_REAL1,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 145, 127, 40, 14 + CONTROL "End Time",IDF_STRING3,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 104, 149, 40, 14 + CONTROL "0",IDF_INTEGER3,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 54, 171, 40, 14 + CONTROL "0",IDF_INTEGER5,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 100, 171, 40, 14 + CONTROL "0.0000",IDF_REAL3,"REALEDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 145, 171, 40, 14 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 54, 202, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 143, 201, 40, 14 +END + +IDD_SETUPELDISP RCDATA +BEGIN +"[Checks] \n" +" 1047 0 \n" +" 1048 0 \n" +" 1036 0 \n" +"[Ranges] \n" +"[Formats] \n" +,0 +END + +IDD_FTRIAN DIALOG 0, 0, 200, 142 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "Options for TRIANG" +BEGIN + CONTROL "Nominal Element Length",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT, 26, 52, 86, 14 + CONTROL "Add Nodes to Improve Mesh Quality",IDF_CHECK1,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 26, 28, 148, 14,WS_EX_STATICEDGE + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 28, 108, 40, 14 + CONTROL "Cancel",IDCANCEL,"BUTTON",WS_CHILD | WS_VISIBLE | WS_TABSTOP | BS_PUSHBUTTON | BS_TEXT, 132, 108, 40, 14 + CONTROL "Force Conforming Boundary Nodes",IDF_CHECK2,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_AUTOCHECKBOX | BS_LEFTTEXT | BS_TEXT, 26, 80, 148, 14,WS_EX_STATICEDGE + CONTROL "0",IDF_INTEGER1,"INTEGERSPIN",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | WS_TABSTOP | ES_LEFT | ES_RIGHT | ES_MULTILINE, 130, 52, 40, 14 +END + +IDD_FTRIAN RCDATA +BEGIN +"[Checks] \n" +" 1036 0 \n" +" 1037 0 \n" +"[Ranges] \n" +,0 +END + +IDD_GETFL DIALOG 0, 0, 233, 89 +STYLE WS_POPUP | WS_BORDER | WS_DLGFRAME | WS_SYSMENU | DS_3DLOOK | DS_MODALFRAME +FONT 8, "MS Sans Serif" +CAPTION "ENTER FILE DIRECTORY FOR TRIANGLE" +BEGIN + CONTROL "",IDF_STRING1,"EDIT",WS_CHILD | WS_VISIBLE | WS_BORDER | WS_GROUP | ES_LEFT | ES_CENTER | ES_MULTILINE | ES_UPPERCASE, 17, 24, 198, 16 + CONTROL "OK",IDOK,"BUTTON",WS_CHILD | WS_VISIBLE | WS_GROUP | WS_TABSTOP | BS_DEFPUSHBUTTON | BS_TEXT, 96, 59, 40, 14 +END + +IDD_GETFL RCDATA +BEGIN +"[Colours] \n" +" 1013 256 256 256 255 255 255 \n" +,0 +END + +/////////////////////////////////////////////////// +// +// Menus +// +IDR_MENU1 MENU +BEGIN + POPUP "&File" + BEGIN + MENUITEM "&New", ID_ITEM11 + MENUITEM "&Open\aCtrl+O", ID_ITEM12 + MENUITEM "Open Additional Mesh Files", ID_LOADRM1 + MENUITEM "Open Background file", ID_BKF + MENUITEM "Open &Layer Data File", ID_LAYFL + MENUITEM "Open New Map file", ID_NMAP + MENUITEM "Open Additional Map File (Combine)", ID_ADDMAP + MENUITEM "Open Cross-Section file", ID_crsf + MENUITEM "Open &Group File", ID_OPENGP + MENUITEM "Open Outline File", ID_OUTLINFL + MENUITEM "Reset Limits", ID_RESETLIM + MENUITEM "Save a&scii\aCtrl+S", ID_ITEM13 + MENUITEM "&Save binary\aCtrl+B", ID_ITEM14 + MENUITEM "Save as &bin map", ID_ITEM18 + MENUITEM "Save &as ascii", ID_ITEM15 + MENUITEM "Save as &binary", ID_ITEM16 + MENUITEM "Save as binary with header", ID_SBIN + MENUITEM "Save Cross-Section Data", ID_SAVCRS + MENUITEM "Save Layer Data File", ID_OUTLAY + MENUITEM "Save ASCII Group File", ID_SAVGP + MENUITEM "Copy to File", ID_ICOPY + MENUITEM "Copy to Clipboard", ID_Clip + MENUITEM "Copy to Shapefile", ID_SAVSHP + MENUITEM "&Print", ID_ITEM24 + MENUITEM "&Demo", ID_ITEM19 + MENUITEM "E&xit", ID_ITEM17 + END + POPUP "Edit" + BEGIN + MENUITEM "Node Data", ID_Nodedata + MENUITEM "Element Data", ID_Eltdata + MENUITEM "Select Element", ID_GETELM + MENUITEM "Layer data", ID_EDLAY + END + MENUITEM "&Node", ID_NODE + MENUITEM "&Elts", ID_ELTS + POPUP "&Order" + BEGIN + MENUITEM "Reorder menu\aCtrl+R", ID_ORDR + MENUITEM "Reorder All", ID_ORDR1 + END + POPUP "Mesh" + BEGIN + MENUITEM "Select mesh file", ID_SELRM1 + MENUITEM "Input Outline to Add Mesh", ID_addmeshtr + MENUITEM "Add mesh to existing", ID_addmesh + MENUITEM "Merge mesh to existing", ID_MRGMESH + MENUITEM "Generate triangular block", ID_TRIANG + MENUITEM "Generate quadrilateral block", ID_QUAD + MENUITEM "Form a line of 1-D elements", ID_g1d + MENUITEM "Create mesh from map lines", ID_CREATM + MENUITEM "Create Block From 2 Map Lines", ID_CRGRID + MENUITEM "Generate Contour lines", ID_CGEN + MENUITEM "Split a line", ID_SPLITN + MENUITEM "Form type 999 line", ID_FORM999 + MENUITEM "Form 2D elements from 1-D", ID_FORM2D + MENUITEM "Generate outline file", ID_GOUTLIN + MENUITEM "Extract Outline List", ID_XOUTLIN + MENUITEM "Check mesh", id_mchck + MENUITEM "Move mesh", ID_MOVMESH + MENUITEM "Transform mesh", ID_TRANSFORM + MENUITEM "Delete element type", ID_deletelm + MENUITEM "Join all overlapping nodes", ID_JOINALL + MENUITEM "Setup Levee Elements", ID_SETUPLEV + END + POPUP "Map" + BEGIN + MENUITEM "Make map from nodes", ID_MMAP + MENUITEM "Interpolate to make map", ID_map + MENUITEM "Triangulate Map data", ID_TRIAN + MENUITEM "Switch to show MAP data", ID_SWMAP + MENUITEM "Switch to show RM1 data", ID_SWRM1 + MENUITEM "Create map data", ID_cdata + END + POPUP "Cc&line" + BEGIN + MENUITEM "Get Ccline", ID_CCLN + MENUITEM "Update Ccline", ID_CHKCCLN + END + POPUP "Contour" + BEGIN + MENUITEM "Contour Options", ID_CONTOPT + MENUITEM "Draw Contour", ID_DCONTR + END + POPUP "Csec&t" + BEGIN + MENUITEM "Trapezoids", ID_CSEC + MENUITEM "Assign Cross-section locations", ID_CSLOC + MENUITEM "Compute Weighting", ID_CRSCAL + MENUITEM "View Cross-sections", ID_crsect + END + MENUITEM "&Distance", ID_ITEM20 + POPUP "S&elect" + BEGIN + POPUP "Nodes" + BEGIN + MENUITEM "Use Polygon", ID_ITEM22 + MENUITEM "All Nodes", ID_ALLNODES + MENUITEM "Unused Nodes", ID_UNUSNODES + MENUITEM "By Element Type", ID_SELELTYP + MENUITEM "Nodes for Move", ID_MOVGRP + END + MENUITEM "Elem&ents", ID_ITEM23 + MENUITEM "Select Area for extraction", ID_selarea + POPUP "Select Group" + BEGIN + MENUITEM "Select Processed Differences", ID_SECGRP + END + MENUITEM "Select pairs for reversal", ID_SELPR + MENUITEM "Find and Display Element type", ID_DISPTYP + END + POPUP "&Undo" + BEGIN + MENUITEM "Undo Refine or Gblock", ID_UNDO + MENUITEM "Undo Last Selected Element", ID_UNDOS + MENUITEM "Undo Last Auto Mesh Gneration", ID_UNDOGEN + END + POPUP "&View" + BEGIN + MENUITEM "Zoom &In\aCtrl+Z", ID_ZIN + POPUP "Zoom &Out" + BEGIN + MENUITEM "&2 times", ID_OUT2 + MENUITEM "&4 times", ID_OUT4 + END + MENUITEM "Drag", ID_DRAG + MENUITEM "Pan &Left", ID_PLEFT + MENUITEM "Pan &Right", ID_PRIGHT + MENUITEM "Pan &Up", ID_PUP + MENUITEM "Pan &Down", ID_PDOWN + MENUITEM "Re&set", ID_RSET + MENUITEM "View in 3-D", ID_3DVIEW + MENUITEM "Set View Angle", ID_VIEWANGLE + MENUITEM "Rotate 3-D view", ID_VROTATE + MENUITEM "Find Node\aCtrl+F", ID_findnode + MENUITEM "Find Element\aCtrl+E", ID_findelem + END + POPUP "&Rdraw" + BEGIN + MENUITEM "Re-draw", ID_DRAWD + MENUITEM "Draw Options", ID_IDRWT + POPUP "&Background" + BEGIN + MENUITEM "Select", ID_BSEL + MENUITEM "Register", ID_REGST + MENUITEM "Reset Registration", ID_RESETRG + END + POPUP "Type/Group Options" + BEGIN + MENUITEM "Type Number", ID_ITYPN + MENUITEM "Type Colour", ID_ITYPC + MENUITEM "Group Number", ID_IGPN + MENUITEM "Group Colour", ID_IGPC + END + MENUITEM "Map Options", ID_MAPOPD + MENUITEM "Force Direct Draw", ID_DDRAW + END + POPUP "&Help" + BEGIN + MENUITEM "Open &help file", ID_Help1 + MENUITEM "About RMAGEN", ID_Help2 + END + POPUP "Experimental" + BEGIN + MENUITEM "Select Elements to attach", ID_attach + MENUITEM "Fill a Gap Between Elements", ID_FILLAGAP + MENUITEM "Set Type by Level", ID_SETTYPLEV + MENUITEM "Form a complex line of elements", ID_Complex + MENUITEM "Interpolate Map File for Stress File", ID_GETSTRESSFIL + MENUITEM "Smooth Map Contours", ID_SMOOTHMAP + MENUITEM "Smooth Mesh Using Reversal", ID_RVSDIAG + MENUITEM "Remove Elements Outside Outline", ID_TESTOUT + MENUITEM "Input Element Load file", ID_LOADELTLD + MENUITEM "Assign Element Loads to Elements", ID_ASSIGNELTLD + MENUITEM "Show Element Loads", ID_SHOWELTLD + MENUITEM "Re-Show Element Loads", ID_RESHOWELTLD + MENUITEM "Save Element Load File", ID_SAVELTLD + MENUITEM "Form Elements from Map File", ID_FILLTR + END + MENUITEM "E&xit", ID_EXIT +END + +IDR_MENU1 RCDATA +BEGIN +ID_FILE,1,0, +ID_ITEM56,2,0, +ID_ORDRT,5,0, +ID_network,6,0, +ID_mapm,7,0, +ID_CCLNA,8,0, +ID_CONTR,9,0, +ID_CSEC1,10,0, +ID_ITEM26,12,0, +ID_ITEM73,12,1,0, +ID_ITEM103,12,4,0, +ID_UNDOM,13,0, +ID_ZOOM,14,0, +ID_ZOUT,14,2,0, +ID_DRAW,15,0, +ID_BACGD,15,3,0, +ID_TYPD,15,4,0, +ID_HELP,16,0, +ID_ITEM126,17,0, +0 +END + +/////////////////////////////////////////////////// +// +// Accelerators +// +IDR_MENU1 ACCELERATORS +BEGIN + 79 , ID_ITEM12 ,NOINVERT,VIRTKEY,CONTROL + 83 , ID_ITEM13 ,NOINVERT,VIRTKEY,CONTROL + 66 , ID_ITEM14 ,NOINVERT,VIRTKEY,CONTROL + 82 , ID_ORDR ,NOINVERT,VIRTKEY,CONTROL + 90 , ID_ZIN ,NOINVERT,VIRTKEY,CONTROL + 70 , ID_findnode ,NOINVERT,VIRTKEY,CONTROL + 69 , ID_findelem ,NOINVERT,VIRTKEY,CONTROL +END + +/////////////////////////////////////////////////// +// +// Bitmaps +// +ID_TOOLBAR1 BITMAP DISCARDABLE "zoom.BMP" +id_chck BITMAP DISCARDABLE "chck.bmp" +id_chk BITMAP DISCARDABLE "chck.bmp" +idchk BITMAP DISCARDABLE "chck.bmp" + +/////////////////////////////////////////////////// +// +// Icons +// +icon1 ICON DISCARDABLE "winter.ico" +IDC_BUTTON2 ICON DISCARDABLE "button.ico" +IDOK ICON DISCARDABLE "ok.ico" +IDCANCEL ICON DISCARDABLE "cancel.ico" + +/////////////////////////////////////////////////// +// +// Strings +// +STRINGTABLE DISCARDABLE +BEGIN + ID_STRING1 "Map file -- *.map |*.map|Bin Map file -- *.mpb|*.mpb|Bin Map file (no head) -- *.mbb|*.mbb|RM1 file (as map) -- *.rm1|*.rm1|ESRI ASC file -- *.asc|*.asc|SURFER GRD file -- *.grd|*.grd|SHAPE FILE -- *.shp|*.shp|" + ID_STRING2 "Network files |*.rm1,*.geo,*.gfg,*.rst,*.bin|Rm1 file -- *.rm1|*.rm1|Geo file -- *.geo|*.geo|Gfg file -- *.gfg|*.gfg|Rst file -- *.rst|*.rst|Bin file -- *.bin|*.bin|" + ID_STRING3 "Rm1 file -- *.rm1|*.rm1|" + ID_STRING4 "Geo file -- * .geo|*.geo|" + ID_STRING5 "Bin Map file -- *.mpb|*.mpb|" + ID_STRING6 "jpeg file -- *.jpg|*.jpg|png file -- *.png|*.png|pcx file -- *.pcx|*.pcx|bmp file -- *.bmp|*.bmp|cgm file -- *.cgm|*.cgm|pic file -- *.pic|*.pic|emf file -- *.emf|*.emf|wmf file -- *.wmf|*.wmf|dxf file -- *.dxf|*.dxf|" + ID_STRING7 "Map file -- *.map |*.map|" + ID_STRING8 "Cln file -- *.cln |*.cln|" + ID_STRING9 "Layer file -- *.lay |*.lay|" + ID_STRING10 "jpeg file -- *.jpg|*.jpg|wmf file -- *.wmf|*.wmf|bmp file -- *.bmp|*.bmp|pcx file -- *.pcx|*.pcx|png file -- *.png|*.png|cgm file -- *.cgm|*.cgm|pic file -- *.pic|*.pic|" + ID_STRING11 "org file -- *.org|*.org|" + ID_DELM "Delete all Mid-side nodes" + ID_FILL "Fill Mid-side nodes" + ID_RSET "Reset to basic view" + ID_DRAG "Pan Screen" + ID_ZIN "Zoom In" + ID_OUT2 "Zoom Out" + ID_JOIN "Merge Two Nodes" + ID_IDRWT "Show Network Display Options" + id_chck "Check Network" + ID_ROTATE "Rotate 3-D View" +END + +/////////////////////////////////////////////////// +// +// Toolbar Data +// +ID_TOOLBAR1 RCDATA +BEGIN + 16, 16, + ID_ZIN, + ID_OUT2, + ID_DRAG, + ID_RSET, + ID_DELM, + ID_FILL, + ID_JOIN, + ID_IDRWT, + id_chck, + ID_ROTATE, +0,0 +END + + +/////////////////////////////////////////////////// +// +// Winteracter Visual Tool Settings +// +//*WI* BASEMENU 30001 +//*WI* BASEITEM 40001 +//*WI* BASEDIALOG 101 +//*WI* BASEFIELD 1001 +//*WI* BASETOOLBAR 30101 +//*WI* BASEBUTTON 40101 +//*WI* BASEIMAGE 2001 +//*WI* F90MODULE 0 +//*WI* FORTSAVE 1 +//*WI* FILENAME D.INC +//*WI* FMODNAME +//*WI* LASTTYPE 1 +//*WI* LASTRES 1 diff --git a/src/src83e/RMAGENV83d.res b/src/src83e/RMAGENV83d.res new file mode 100644 index 0000000..f1e506c Binary files /dev/null and b/src/src83e/RMAGENV83d.res differ diff --git a/src/src83e/RVSDIAG.F90 b/src/src83e/RVSDIAG.F90 new file mode 100644 index 0000000..9fe8d99 --- /dev/null +++ b/src/src83e/RVSDIAG.F90 @@ -0,0 +1,121 @@ + SUBROUTINE RVSDIAG +! routine to test for and reverse diagonals + USE BLK1MOD + USE BLK2MOD + INCLUDE 'BFILES.I90' + + REAL IGrDistanceLine + dist(n1,n2)=sqrt((xusr(n1)-xusr(n2))**2+(yusr(n1)-yusr(n2))**2) +! save current file + + IFILOUT=IACTVFIL+50 + CALL WRTFIL(IFILOUT) + +! fill midsides + CALL FILM(1) +! get elements connected to nodes table + MIDSIDE=0 + IERR=1 + CALL NDNECON(IERR) + +! gets nodes nodes opposite +! loop on midsides + KCOUNT=0 + DO N=1,NP + IF(NECON(N,2) .EQ. 0) CYCLE + NEL1=NECON(N,1) + NEL2=NECON(N,2) + WRITE(160,*) 'ELTS',NEL1,NEL2 +! test for two triangles + IF(NCORN(NEL1) .EQ. 8 .OR. NCORN(NEL1) .LT. 6) CYCLE + IF(NCORN(NEL2) .EQ. 8 .OR. NCORN(NEL2) .LT. 6) CYCLE +! get the adjacent nodes N1 and N2 + DO K=2,6,2 + IF(N .EQ. NOP(NEL1,K)) THEN +! get the adjacent nodes N1 and N2 + N1=NOP(NEL1,K-1) + N2=K+1 + IF(N2 .GT. 6) N2=1 + N2=NOP(NEL1,N2) +! get first of two nodes facing each other N3 + N3=K+3 + IF(N3 .GT. 6) N3=N3-6 + N3=NOP(NEL1,N3) + ENDIF + ENDDO +! get second of two nodes facing each other N4 + DO K=2,6,2 + IF(N .EQ. NOP(NEL2,K)) THEN + N4=K+3 + IF(N4 .GT. 6) N4=N4-6 + N4=NOP(NEL2,N4) + ENDIF + ENDDO + IF(WD(N1) .EQ. WD(N3) .AND. WD(N2) .EQ. WD(N3)) GO TO 500 + IF(WD(N1) .EQ. WD(N4) .AND. WD(N2) .EQ. WD(N4)) GO TO 500 + IF(WD(N1) .EQ. WD(N3) .AND. WD(N1) .EQ. WD(N4)) GO TO 500 + IF(WD(N2) .EQ. WD(N3) .AND. WD(N2) .EQ. WD(N4)) GO TO 500 + X1=XUSR(N1) + X2=XUSR(N2) + X3=XUSR(N3) + X4=XUSR(N4) + Y1=YUSR(N1) + Y2=YUSR(N2) + Y3=YUSR(N3) + Y4=YUSR(N4) + CALL IGRINTERSECTLINE(X1,Y1,X2,Y2,X3,Y3,X4,Y4,XINTER,YINTER,ISTAT) + IF(ISTAT .NE. 5) GO TO 500 + METHOD=1 + D1=IGrDistanceLine(X1,Y1,X2,Y2,XINTER,YINTER,METHOD) +! D2=IGrDistanceLine(X1,Y1,X2,Y2,X4,Y4,METHOD) + D1=SQRT((X1-XINTER)**2+(Y1-YINTER)**2) + D2=SQRT((X2-XINTER)**2+(Y2-YINTER)**2) + D3=SQRT((X1-X2)**2+(Y1-Y2)**2) + IF(D1 .LT. 0.05*D3) GO TO 500 + IF(D2 .LT. 0.05*D3) GO TO 500 + IF(WD(N3) .EQ. WD(N1)) THEN + IF(ABS(WD(N4)-WD(N3)) .LT. ABS(WD(N2)-WD(N3))) THEN + KCOUNT=KCOUNT+1 + WRITE(160,*) 'QV1',KCOUNT,NEL1,NEL2,N1,N2,N3,N4 + CALL DUMPBIN(KCOUNT,1) + CALL REVERS(NEL1,NEL2) + GO TO 500 + ELSE + GO TO 500 + ENDIF + ELSEIF(WD(N3) .EQ. WD(N2)) THEN + IF(ABS(WD(N4)-WD(N3)) .LT. ABS(WD(N3)-WD(N2))) THEN + KCOUNT=KCOUNT+1 + WRITE(160,*) 'QV2',KCOUNT,NEL1,NEL2,N1,N2,N3,N4 + CALL DUMPBIN(KCOUNT,1) + CALL REVERS(NEL1,NEL2) + GO TO 500 + ELSE + GO TO 500 + ENDIF + ENDIF +! test if they are equal height + IF(WD(N3) .EQ. WD(N4) .or. ABS(WD(N3) -WD(N4)) .LT. ABS(WD(N1)-WD(N2))) THEN +! if so reverse connections + if(dist(n1,n2)*1.5 .lt. dist(n3,n4)) go to 500 + KCOUNT=KCOUNT+1 + WRITE(160,*) 'RV1',KCOUNT,NEL1,NEL2,N1,N2,N3,N4 + CALL REVERS(NEL1,NEL2) + CALL DUMPBIN(KCOUNT,1) + + ELSE +! test if N4 closer or equal to N3 than N1 or N2 + IF(ABS(WD(N4) - WD(N3)) .LT. ABS(WD(N1) - WD(N3)) .OR. ABS(WD(N4) - WD(N3)) .LT. ABS(WD(N2) - WD(N3))) THEN +! if so reverse connections + if(dist(n1,n2)*1.5 .lt. dist(n3,n4)) go to 500 + KCOUNT=KCOUNT+1 + WRITE(160,*) 'RV2',KCOUNT,NEL1,NEL2,N1,N2,N3,N4 + CALL REVERS(NEL1,NEL2) + CALL DUMPBIN(KCOUNT,1) + ENDIF + ENDIF +500 CONTINUE +! end loop + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/src83e/SAVELTLD.F90 b/src/src83e/SAVELTLD.F90 new file mode 100644 index 0000000..60e8176 --- /dev/null +++ b/src/src83e/SAVELTLD.F90 @@ -0,0 +1,110 @@ + SUBROUTINE SAVEEQ + USE WINTERACTER + + USE BLKELTLD + + include 'D.inc' + character*255 fnamein,filter + CHARACTER *24 DATAOUT + + filter='Element Input files|*.elt|' + CALL WSelectFile(filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAMEIN,'Element Load File Name') + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + OPEN(202,FILE=FNAMEIN,STATUS='UNKNOWN') + ELSE + RETURN + ENDIF + IF(IRMATYP .EQ. 11) WRITE(202,6000) +6000 FORMAT('TI') + IF(IRMATYP .EQ. 2 .OR. IRMATYP .EQ. 10) WRITE(202,6001) +6001 FORMAT('TE') + DO I=1,NQHYD + HRYEAR=365*24. + IYR=IYDATE(I) + IF(MOD(IYDATE(I),4) .EQ. 0) HRYEAR=HRYEAR+24. + IF(IRMATYP .EQ. 2 .OR. IRMATYP .EQ. 10) THEN + WRITE(202,6002) NCLINE(I),NEST(I),IYDATE(I),XYCEL(I,1),XYCEL(I,2) +!6002 FORMAT('QEI',5X,3I8) +6002 FORMAT('QEI',5X,3I8,2F16.2) + NST=NHYE(I) + DO N=1,NST + IF(TAE(N,I) .GE. HRYEAR) THEN + TAOUT=TAE(N,I)-HRYEAR + IYR=IYR+1 + ELSE + IF(N .GT. 1) THEN + IF(TAE(N,I) .LT.TAE(N-1,I)) IYR=IYR+1 + ENDIF + TAOUT=TAE(N,I) + ENDIF + CALL ENCODDAT(DATAOUT,TAE(N,I),IYR) + IF(IRMATYP .EQ. 2) THEN + WRITE(202,6003) DATAOUT,HAE(N,I) +6003 FORMAT(A24,F8.3) + ELSE + WRITE(202,6004) DATAOUT,ILAYRE(N,I),HAE(N,I),(HDE(N,I,K),K=1,3) +6004 FORMAT(A24,I8,F8.3,3F8.2) + ENDIF + ENDDO + + ELSEIF(IRMATYP .EQ. 11) THEN + WRITE(202,6002) NCLINE(I),NEST(I),IYDATE(I),XYCEL(I,1),XYCEL(I,2) + NST=NHYE(I) + DO N=1,NST + IF(TAE(N,I) .GE. HRYEAR) THEN + TAOUT=TAE(N,I)-HRYEAR + IYR=IYR+1 + ELSE + IF(N .GT. 1 .AND. TAE(N,I) .LT.TAE(N-1,I)) IYR=IYR+1 + TAOUT=TAE(N,I) + ENDIF + CALL ENCODDAT(DATAOUT,TAE(N,I),IYR) + WRITE(202,6006) DATAOUT,HAE(N,I),(HDE(N,I,K),K=1,3) +6006 FORMAT(A24,4F8.3) + ENDDO + ENDIF + ENDDO + WRITE(202,6010) +6010 FORMAT('ENDDATA') + CLOSE (202) + RETURN + END + + SUBROUTINE ENCODDAT(DATAOUT,DAYJUL,IYR) + CHARACTER*24 DATAOUT + REAL DAYJUL,TIME + INTEGER IMTS(12,2),IDAY,IMO,IYR,RMIN + DATA IMTS/0,31,59,90,120,151,181,212,243,273,304,334,0,31,60,91,121,152,182,213,244,274,305,335/ + LP=1 + IF(MOD(IYR,4) .EQ. 0) LP=2 + DO K=1,12 + + IF(DAYJUL/24. .LT. IMTS(K,LP)) THEN + IMO=K-1 + IDAY=DAYJUL/24.-IMTS(IMO,LP)+1 + IDT=DAYJUL/24. + HR=DAYJUL-FLOAT(IDT)*24. + IHR=HR + RMIN=(HR-FLOAT(IHR))*60.+.5 + GO TO 100 + ENDIF + ENDDO + IMO=12 + IDAY=DAYJUL/24.-(334+LP-1)+1 + IDT=DAYJUL/24. + HR=DAYJUL-FLOAT(IDT)*24. + IHR=HR + RMIN=(HR-FLOAT(IHR))*60.+.5 + + 100 IF(IHR .LT. 10) THEN + WRITE(DATAOUT(1:24),6000) IDAY,IMO,IYR,IHR,RMIN +6000 FORMAT('QM',7X,I2.2,'/',I2.2,'/',I4,I2,':',I2.2) + ELSE + WRITE(DATAOUT(1:24),6001) IDAY,IMO,IYR,IHR,RMIN +6001 FORMAT('QM',6X,I2.2,'/',I2.2,'/',I4,I3,':',I2.2) + ENDIF + RETURN + END + + \ No newline at end of file diff --git a/src/src83e/SAVESHP.F90 b/src/src83e/SAVESHP.F90 new file mode 100644 index 0000000..e8b7fd7 --- /dev/null +++ b/src/src83e/SAVESHP.F90 @@ -0,0 +1,175 @@ + SUBROUTINE SAVESHP +! +! ROUTINE TO SAVE NETWORK AS A SHAPEFILE +! + + USE WINTERACTER + USE BLK1MOD + + REAL*8 XK(12),YK(12),DEP(12) +! SAVE INFO TO A SCRATCH + VOID = -1.E10 + + Call WMessageBox(3,2,1,'Do you wish to save as a complex polygon'//Char(13)//& + 'shapefile containing all the network data'//'Press YES to accept',& + 'CHOOSE SHAPEFILE TYPE -1- !!') + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then + IOPTSV=1 + IOPTSVNOD=0 + IOPTSVEL=0 + ELSE + IOPTSV=2 + Call WMessageBox(3,2,1,'Do you wish to save as a polygon'//Char(13)//& + 'shapefile containing network outline'//'Press YES to accept',& + 'CHOOSE SHAPEFILE TYPE -2- !!') + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then + IOPTSVEL=1 + ELSE + IOPTSVEL=0 + ENDIF + Call WMessageBox(3,2,1,'Do you wish to save as a point'//Char(13)//& + 'shapefile containing bed levels'//'Press YES to accept',& + 'CHOOSE SHAPEFILE TYPE -3- !!') + IF(WinfoDialog(ExitButtonCommon) .eq. CommonOK) then + IOPTSVNOD=1 + ELSE + IOPTSVNOD=0 + ENDIF + ENDIF + IF(IOPTSVEL .EQ. 1 .OR. IOPTSV .EQ. 1) THEN + OPEN(113,FORM='BINARY',STATUS='SCRATCH') + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + NC=0 + IF(NCORN(N) .GT. 5) THEN + DO KK=1,NCORN(N)+1 + K=MOD(KK,NCORN(N)) + IF(K .EQ. 0) K=NCORN(N) + NODE=NOP(N,K) + IF(NODE .GT. 0) THEN + NC=NC+1 + XK(NC)=XUSR(NODE) + YK(NC)=YUSR(NODE) + DEP(NC)=WD(NODE) + ENDIF + ENDDO + IMATT=IMAT(N) + WRITE(113) N,IMATT,NC,(XK(K),YK(K),DEP(K),K=1,NC) + !ELSEIF(NCORN(N) .EQ. 5) THEN + ! DO K=1,5 + ! NODE=NOP(N,K) + ! IF(NODE .GT. 0) THEN + ! NC=NC+1 + ! XK(NC)=XUSR(NODE) + ! YK(NC)=YUSR(NODE) + ! DEP(NC)=WD(NODE) + ! ENDIF + ! ENDDO + ! DO K=3,1,-1 + ! NODE=NOP(N,K) + ! IF(NODE .GT. 0) THEN + ! NC=NC+1 + ! XK(NC)=XUSR(NODE) + ! YK(NC)=YUSR(NODE) + ! DEP(NC)=WD(NODE) + ! ENDIF + ! ENDDO + ! IMATT=IMAT(N) + ! WRITE(113) N,IMATT,NC,(XK(K),YK(K),DEP(K),K=1,NC) + ELSEIF(NCORN(N) .LT. 6 .AND. (IMAT(N) .LT. 900 .OR. IMAT(N) .GT. 903)) THEN + NODE1=NOP(N,1) + DO K=1,3 + NODE=NOP(N,K) + IF(NODE .GT. 0) THEN + NC=NC+1 + XK(NC)=XUSR(NODE) + YK(NC)=YUSR(NODE) + DEP(NC)=WD(NODE) + ENDIF + ENDDO + IF(WIDTH(NODE) .GT. 0.) THEN + eldir=atan2(YUSR(NOP(N,3))-YUSR(NOP(N,1)),XUSR(NOP(N,3))-XUSR(NOP(N,1))) + elnorm=eldir-1.5708 + NC=NC+1 + xK(NC)=XK(NC-1)+cos(elnorm)*WIDTH(NODE)/2. + yK(NC)=YK(NC-1)+sin(elnorm)*WIDTH(NODE)/2. + NMID=0 + IF(NOP(N,2) .GT. 0) THEN + NMID=1 + NC=NC+1 + xK(NC)=XK(2)+cos(elnorm)*(WIDTH(NODE)+WIDTH(NODE1))/4. + yK(NC)=YK(2)+sin(elnorm)*(WIDTH(NODE)+WIDTH(NODE1))/4. + ENDIF + NC=NC+1 + xK(NC)=XK(1)+cos(elnorm)*WIDTH(NODE1)/2. + yK(NC)=YK(1)+sin(elnorm)*WIDTH(NODE1)/2. + NC=NC+1 + xK(NC)=XK(1)-cos(elnorm)*WIDTH(NODE1)/2. + yK(NC)=YK(1)-sin(elnorm)*WIDTH(NODE1)/2. + IF(NMID .GT. 0) THEN + NC=NC+1 + xK(NC)=XK(2)-cos(elnorm)*(WIDTH(NODE)+WIDTH(NODE1))/4. + yK(NC)=YK(2)-sin(elnorm)*(WIDTH(NODE)+WIDTH(NODE1))/4. + NC=NC+1 + xK(NC)=XK(3)-cos(elnorm)*WIDTH(NODE)/2. + yK(NC)=YK(3)-sin(elnorm)*WIDTH(NODE)/2. + NC=NC+1 + XK(NC)=XK(3) + YK(NC)=YK(3) + ELSE + NC=NC+1 + xK(NC)=XK(2)-cos(elnorm)*WIDTH(NODE)/2. + yK(NC)=YK(2)-sin(elnorm)*WIDTH(NODE)/2. + NC=NC+1 + XK(NC)=XK(2) + YK(NC)=YK(2) + ENDIF + ELSE + DO K=2,1,-1 + NODE=NOP(N,K) + IF(NODE .GT. 0) THEN + NC=NC+1 + XK(NC)=XUSR(NODE) + YK(NC)=YUSR(NODE) + DEP(NC)=WD(NODE) + ENDIF + ENDDO + ENDIF + IMATT=IMAT(N) + WRITE(113) N,IMATT,NC,(XK(K),YK(K),DEP(K),K=1,NC) + ENDIF + ENDIF + ENDDO + REWIND 113 + +! CALL FORMSHP TO WRITE OUT SHAPEFILE + IF(IOPTSV .EQ. 1) THEN + ISTYP=25 +! ISTYP=25 is saving element list + IVECACT=4 + ELSE +! ISTYP=5 is saving element list with polygons? + ISTYP=5 + IVECACT=5 + ENDIF + CALL FORMSHP2(istyp,ivecact) + CLOSE(113) + ENDIF + + IF(IOPTSVNOD .EQ. 1) THEN + OPEN(113,FORM='BINARY',STATUS='SCRATCH') + DO NODE=1,NP + IF(XUSR(NODE) .GT. VOID) THEN + WRITE(113) NODE,XUSR(NODE),YUSR(NODE),WD(NODE) + ENDIF + ENDDO + REWIND 113 +! ISTYP=1 is saving of nodal values + ISTYP=1 + IVECACT=6 + CALL FORMSHP2(istyp,ivecact) + CLOSE (113) + ENDIF + + RETURN + END \ No newline at end of file diff --git a/src/src83e/SELT.F90 b/src/src83e/SELT.F90 new file mode 100644 index 0000000..19824a7 --- /dev/null +++ b/src/src83e/SELT.F90 @@ -0,0 +1,958 @@ +! last update feb 10 2002 add lock/unlock +! Last change: IPK 2 Mar 1999 12:05 pm + SUBROUTINE SELNODE(ISW) + + USE WINTERACTER + USE BLKMAP + USE BLK1MOD + USE BLK2MOD + + include 'd.inc' + + dimension xot(100),yot(100) +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! + dimension nodlist(maxp),RLAY(9) +! DIMENSION ICN(MAXP) + character*1 iflag + CHARACTER*1 ANS,ANSW(10) + CHARACTER*63 STRELS + DATA ANSW/'m','a','f','s','k','u','t','w','h','q'/ + DATA STRELS/' You have tried set to set elevation with no mapfile"'/ + + +! +! save nhtp etc + + nhtps=nhtp + nbrs=nbrr + nmessv=nmess + if(isw .eq. 0 .or. isw .eq. 4) then + + CALL GETPOLY(XOT,YOT,NPTS) + +! look for points inside polygon + + ndlist=0 + do j=1,np + if(inskp(j) .eq. 0) then + inswt=0 + call cpoly(xot,yot,npts,cord(j,1),cord(j,2),inswt) + if(inswt .eq. 1) then + call rred + fpn=j + x = cord(j,1) + y = cord(j,2) - .11 + call numbr(x,y,ht,fpn,0.0,-1) + ndlist=ndlist+1 + nodlist(ndlist)=j + endif + endif + enddo + call rblue + elseif(isw .eq. 1) then +! +! Add all nodes to list +! + NDLIST=0 + DO J=1,NP + IF(INEW(J) .EQ. 1) THEN + NDLIST=NDLIST+1 + NODLIST(NDLIST)=J + ENDIF + END DO + + elseif(isw .eq. 2) then + +! Get inactive nodes + + DO I=1,NP + ICN(I) = 0 + ENDDO + DO J = 1, NE + IF( IMAT(J) .NE. 0 ) THEN + DO K = 1, 8 + IF( NOP(J,K) .GT. 0) THEN + ICN(NOP(J,K))=999 + ENDIF + ENDDO + ENDIF + END DO +! +! Add nodes to list +! + NDLIST=0 + DO J=1,NP + IF(ICN(J) .EQ. 0 .AND. INEW(J) .EQ. 1) THEN + NDLIST=NDLIST+1 + NODLIST(NDLIST)=J + ENDIF + END DO + + elseif(isw .eq. 3) then + NS=1 + call wdialogload(IDD_SELELTYP) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,NS) + + CALL WDialogSelect(IDD_SELELTYP) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,ModaL) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,NS) + go to 80 + ENDIF + enddo + 80 CONTINUE + DO I=1,NP + ICN(I) = 0 + ENDDO + NDLIST=0 + DO K=1,NE + IF(IMAT(K) .EQ. NS) THEN + DO L=1,8 + NST=NOP(K,L) + IF(NST .GT. 0) THEN + IF(ICN(NST) .EQ. 0) THEN + NDLIST=NDLIST+1 + NODLIST(NDLIST)=NST + ICN(NST)=1 + ENDIF + ENDIF + ENDDO + ENDIF + ENDDO + + endif +! NEW MOVE OPERATION + + IF(ISW .EQ. 4) THEN + CALL MVGRP(NDLIST,NODLIST) + nhtp=nhtps + nbrr=nbrs + nmess=nmessv + call hedr + RETURN + ENDIF + nbrr=0 + nhtp=14 + call hedr + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + if(ibox .eq. 1 .or. iflag .eq. 'd') then + do n=1,ndlist + j=nodlist(n) + call deletn(j) + enddo + elseif(ibox .eq. 2 .or. iflag .eq. 'e') then + do n=1,ndlist + j=nodlist(n) + wd(j)=-9999. + enddo + elseif(ibox .eq. 3 .or. iflag .eq. 't') then +! +! Establish size for range +! +! IF(IMP .EQ. 0) THEN +! CALL SYMBL(0.,7.25,0.20,STRELS,0.,63) +! nhtp=nhtps +! nbrr=nbrs +! nmess=nmessv +! call hedr +! RETURN +! endif + + 100 CONTINUE + NHTP = 16 + NMESS = 0 + NBRR = 0 + CALL HEDR +! +! Get answer +! + 110 call xyloc(XPT,YPT,ANS,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(ANS .EQ. 'c') THEN + if(ibox .eq. 0) go to 110 + ANS=ANSW(IBOX) + ENDIF + IF(ANS .EQ. 'm') THEN +! +! This option allows changes to bottom elevations +! + CALL ADDPTH2(NODLIST,NDLIST) + GO TO 220 + + ELSEIF (ANS .EQ. 'a') THEN +! +! All nodes +! + ISWT = -1 + ELSEIF(ANS .EQ. 'f') THEN +! +! Fill nodes +! + ISWT = 0 +! ELSEIF(ANS .EQ. 's') THEN +! +! Single node at a time +! +! ISWT = 1 + +!ipk feb02 add lock/unlock and remove cdata + +! ELSEIF(ANS .EQ. 'w') THEN +! +! This option allows changes to nodal widths +! +! CALL ADDWID +! IF(IRMAIN .EQ. 1) RETURN +! GO TO 100 +! +! Call to help screen +! + ELSEIF(ANS .EQ. 'h') THEN + CALL HELPS(4) + IF(IRMAIN .EQ. 1) RETURN + GO TO 100 +! + ELSEIF(ANS .EQ. 'q') THEN +! +! Writeout and return +! + CALL WRTOUT(0) + RETURN + ENDIF + + IF(IMP .EQ. 0) THEN + CALL SYMBL(0.,7.25,0.20,STRELS,0.,63) + go to 100 + endif +! +! Establish size for range +! +!!!!!!!!!!!!!!!!!!!!!!!!! + + IF(ISWTAGN .EQ. 0) THEN + +! IF(IRECD .EQ. 2) THEN +! iswtintp=0 +! iswtagn=0 +! go to 210 +! ENDIF + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to interpolate '//& + CHAR(13)//'from the triangulated map file?' ,& + 'Select Interpolation method?') +! If answer 'Yes' set interpolate switch to 1 +! + IF (WInfoDialog(4) .EQ. 2) then + iswtintp=0 + ELSE + iswtintp=1 + ENDIF + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Ask this question again?'//& + CHAR(13)//' ' ,& + 'Ask again?') +! If answer 'Yes' set again switch to 0 +! + IF (WInfoDialog(4) .EQ. 2) then + iswtagn=1 + ELSE + iswtagn=0 + ENDIF + ENDIF + + 210 CONTINUE + +!!!!!!!!!!!!!!!!!!!!!!!!!!!! + + IF(ISWTINTP .EQ. 0) THEN + + call setrng(xnears,nmap) + iswt=0 + do n=1,ndlist + m=nodlist(n) +!ipk feb02 +!ipk jan08 chnage subscript + if(lock(m) .eq. 0) CALL SETELV(XNEARS,NMAP,M,ISWT) + enddo + ELSE + if(nelts .eq. 0) then + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'No triangulated exists'//& + CHAR(13)//'Do you wish to triangulate now?' ,& + 'NO TRIANGULATION AVAILABLE?') +! If answer 'Yes' set triangulate now +! + IF (WInfoDialog(4) .EQ. 2) then + return + ELSE + call triang + ENDIF + + endif + do n=1,ndlist + m=nodlist(n) + if(lock(m) .eq. 0) CALL TRIANINT(NMAP,M,ISWT,ITIME) + enddo + ENDIF + 220 CONTINUE + + elseif(ibox .eq. 4 .or. iflag .eq. 'l') then + +! Define layers + + call openlay + + NHTP=0 + NBRR=0 + NMESS=45 + CALL HEDR + NMESS=4 + xprt=3.2 +! +! call getint(nlay) + + call GETLAYDAT(NLAY,ipos,RLAY) + ILAYTP=IPOS + + do n=1,ndlist + j=nodlist(n) + lay(j)=nlay + DO I=1,NLAY + WTLAY(J,I)=RLAY(I) + ENDDO + enddo + REWIND 102 + DO J=1,NP + IF(LAY(J) .GT. -9998) THEN + if(ILAYTP .eq. 1) then + write(102,6000) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + 6000 format('LD2 ',2i8,9F8.2) + else + write(102,6001) J,LAY(J),(WTLAY(J,I),I=1,LAY(J)) + 6001 format('LD3 ',2i8,9F8.2) + endif + ENDIF + ENDDO + nlayd=1 +!ipk feb02 add lcok/unlock + elseif(ibox .eq. 5 .or. iflag .eq. 'k') then + do n=1,ndlist + j=nodlist(n) + lock(j)=1 + enddo + elseif(ibox .eq. 6 .or. iflag .eq. 'u') then + do n=1,ndlist + j=nodlist(n) + lock(j)=0 + enddo + elseif(ibox .eq. 7 .or. iflag .eq. 'f') then + do n=1,np + list(n)=0 + enddo + do n=1,ndlist + list(nodlist(n))=1 + enddo + call deln2(np,0) + endif + +! CALL PLOTOT(1) + + nhtp=nhtps + nbrr=nbrs + nmess=nmessv + call hedr + RETURN + END + + SUBROUTINE SELELT(ISW) + + USE BLK1MOD + save fracd + dimension xot(100),yot(100) + +! INCLUDE 'BLK1.COM' +! + dimension nodlist(maxp) + character*1 iflag + + data itime/0/ + + if(itime .eq. 0) then + mat=0 + itime=1 + endif + + IF(ISW .EQ. 2) GO TO 200 + + CALL GETPOLY(XOT,YOT,NPTS) + + +! +! save nhtp etc + + nhtps=nhtp + nbrs=nbrr + nmessv=nmess + +! look for points inside polygon + + ndlist=0 + nefl=0 + do n=1,ne + ieswt=0 + if(ieskp(n) .eq. 0) then + ieswt=1 + do m=1,ncorn(n) + j=nop(n,m) + if(j .gt. 0) then + inswt=0 + call cpoly(xot,yot,npts,cord(j,1),cord(j,2),inswt) + if(inswt .eq. 1) then +! call rred +! fpn=j +! x = cord(j,1) +! y = cord(j,2) - .11 +! call numbr(x,y,ht,fpn,0.0,-1) + ndlist=ndlist+1 + nodlist(ndlist)=j + else + ieswt=0 + endif + endif + enddo + endif + if(ieswt .eq. 1) then + nefl=nefl+1 + neflag(nefl)=n +! call rcyan +! fpn = n +! x = xc(n) +! y = yc(n) + .01 +! call numbr(x,y,0.20,fpn,0.0,-1) + call fillem(n) + endif + enddo + call rblue + + GO TO 300 +200 CONTINUE +! +! save nhtp etc + + nhtps=nhtp + nbrs=nbrr + nmessv=nmess + NEFL=0 + CALL GETFRAC(FRACD) + call plotot(0) + DO N=1,NE + IF(EDIF(N) .GT. (1.-FRACD)*EDIF(0)) THEN + nefl=nefl+1 + neflag(nefl)=n + call fillem(n) + ENDIF + ENDDO +300 CONTINUE + if(isw .eq. 0 .OR. ISW .EQ. 2) then + nbrr=0 + nhtp=15 + call hedr + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + if(ibox .eq. 1 .or. iflag .eq. 'd') then + do n=1,nefl + j=neflag(n) + call deltel(j) + enddo + nefl=0 + elseif(ibox .eq. 2 .or. iflag .eq. 'e') then + call refb + elseif(ibox .eq. 3 .or. iflag .eq. 't') then + nhtp=0 + nbrr=4 + NMESS=45 + call hedr + nmess=2 + call getint(mat) + ipsw(7)=1 + ipsw(5)=0 + do n=1,nefl + j=neflag(n) + imat(j) = mat + enddo + nefl=0 + elseif(ibox .eq. 4 .or. iflag .eq. 'm') then +! +! simplify layout +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL SMFY + +!ipk dec11 + elseif(ibox .eq. 5 .or. iflag .eq. 'g') then +! +! form group +! + CALL FORMGP + + endif + + + + CALL PLOTOT(1) + + nhtp=nhtps + nbrr=nbrs + nmess=nmessv + call clrbox + call hedr + else + call extract(NODLIST,NDLIST) + +! display extracted file + + + CALL PLOTOT(1) + + nhtp=nhtps + nbrr=nbrs + nmess=nmessv + call clrbox + call hedr + endif + + + RETURN + END + + SUBROUTINE CPOLY(XOT,YOT,NPTS,X,Y,INSWT) + DIMENSION XOT(*),YOT(*) + REAL*8 X,Y + DATA PI/3.14159/ + SUMA=0 + DO N=1,NPTS-1 + ANG1=ATAN2(YOT(N+1)-Y,XOT(N+1)-X) + ANG2=ATAN2(YOT(N)-Y,XOT(N)-X) + DIFA=ANG2-ANG1 + IF(ABS(DIFA) .GT. PI) THEN + IF(DIFA .LT. -PI) DIFA=DIFA+2.*PI + IF(DIFA .GT. PI) DIFA=DIFA-2.*PI + ENDIF + SUMA=SUMA+DIFA + ENDDO + IF(ABS(SUMA) .GT. PI) THEN + INSWT=1 + ELSE + INSWT=0 + ENDIF + RETURN + END + + SUBROUTINE GETPOLY(XOT,YOT,NPTS) + + USE BLK1MOD + dimension xot(*),yot(*) +! INCLUDE 'BLK1.COM' +! + CHARACTER*23 SELN3 + CHARACTER*32 SELN + CHARACTER*24 SELN2 + CHARACTER*1 IFLAG + data SELN/' Click at points to form polygon'/ + data SELN2/' Click next point '/ + data SELN3/' Click last point again'/ + + 80 CALL CLRBOX + nhtp=0 + nbrr=5 + nmess=0 + call hedr + CALL SYMBL(0.,7.70,0.20,SELN,0.,32) +! + 100 continue +! +! Get cursor location +! + CALL XYLOC(xscrn,yscrn,iflag,ibox) + IF(IRMAIN .EQ. 1) RETURN +! + if (iflag .eq. 'q') return +! + if(iflag .eq. 'c') then + xot(1)=xscrn + yot(1)=yscrn + npts=1 +! +! This option is creating an inset locations +! + 120 continue + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + IF(IRMAIN .EQ. 1) RETURN + if(ibox .eq. 6 .or. iflag .eq. 'b') then + npts=npts-1 + go to 120 + endif + if(iflag .eq. 'c') then +! +! Look for a screen size +! + 122 continue + xsiz=abs(xscrn1-xscrn) + ysiz=abs(yscrn1-yscrn) +!ipk jun96 test for zero sizes + if(xsiz .lt. 0.001 .or. ysiz .lt. 0.001) then + CALL CLRBOX + call hedr + CALL SYMBL(0.,7.70,0.20,seln3,0.,23) + go to 120 + endif + npts=npts+1 + xot(npts)=xscrn1 + yot(npts)=yscrn1 + call DASHLN(xot,yot,npts,1) + CALL CLRBOX + call hedr + + CALL SYMBL(0.,7.70,0.20,seln2,0.,24) + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + IF(IRMAIN .EQ. 1) RETURN + + if(ibox .eq. 6 .or. iflag .eq. 'b') then + npts=npts-1 + go to 120 + elseif(ibox .eq. 7 .or. iflag .eq. 'n') then + npts=npts+1 + xot(npts)=xot(1) + yot(npts)=yot(1) + call DASHLN(xot,yot,npts,1) + go to 280 + else + go to 122 + endif + endif + ENDIF + 280 continue + RETURN + END + + subroutine extract(NODLIST,NDLIST) + + USE WINTERACTER + USE BLK1MOD + INCLUDE 'BFILES.I90' +! include 'blk1.com' + + + include 'd.inc' + + DIMENSION NODLIST(*) + CHARACTER(LEN=256) :: FILTER + CHARACTER(LEN=255) :: FNAME,FNAMRM + +! select filename for new file + + FILTER ="Rm1 file -- *.rm1|*.rm1|" + CALL WSelectFile(Filter,SaveDialog+PromptOn+AppendExt+DirChange,FNAME,'Filename for extracted file') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + GO TO 200 + ELSE + GO TO 500 + ENDIF + 200 CONTINUE + CALL IlowerCase(FNAME) + + ITOTFIL=ITOTFIL+1 + FNAMEOUT(ITOTFIL)=FNAME + +! save current file + + IFILOUT=IACTVFIL+50 + CALL WRTFIL(IFILOUT) + +! create network structure + + CALL ZERORELM(NODLIST,NDLIST) + + IACTVFIL=ITOTFIL + + + +! save new structure + + IOT = 20 + FNAMRM=FNAME + igfgsw=0 + close(iot) + OPEN(IOT,FILE=FNAME,STATUS='UNKNOWN') +! +! Check if file cords format to be short or long +! +! + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to save'//& + CHAR(13)//'coordinates in long format?' ,& + 'Coordinate save format') +! +! If answer 'No', use short format +! + IF (WInfoDialog(4) .EQ. 2) then + ntempin=0 + else + ntempin=2 + END IF +! + call wrtout(1) + CLOSE (IOT) + OPEN(IOT,FILE=FNAMRM,STATUS='UNKNOWN') + + 500 continue + return + end + + SUBROUTINE ZERORELM(NODLIST,NDLIST) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + dimension nodlist(*) + + DO N=1,NP + +! search nodlist + + do k=1,ndlist + if(n .eq. nodlist(K)) go to 300 + enddo + call deletn(n) + 300 continue + ENDDO + +! reset NP + + do k=np,1,-1 + if(inew(k) .gt. 0) then + np=k + go to 350 + endif + enddo + 350 continue + +! reset NE + + do k=ne,1,-1 + if(imat(k) .gt. 0) then + ne=k + go to 400 + endif + enddo + 400 continue + + RETURN + END + + SUBROUTINE GETFRAC(FRACD) +! +! Generate continuity lines +! + + USE WINTERACTER + save + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: I1,I2,I3,ITIME,IPOS + + REAL :: FRACD + + data itime/0/ + + IF(ITIME .EQ. 0) THEN + FRACD=0.1 + itime=1 + ENDIF + + call wdialogload(IDD_SETSEL) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_SETSEL) + ierr=infoerror(1) + + CALL WDialogPutReal(IDF_REAL1,FRACD) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialoggetReal(IDF_REAL1,FRACD) + GO TO 100 + + ENDIF + + enddo + + 100 CONTINUE + return + end + + SUBROUTINE FINDTYP + + USE WINTERACTER + USE BLKMAP + USE BLK1MOD + USE BLK2MOD + character*1 iflag + + include 'd.inc' + + DATA NS/1/ + + + call wdialogload(IDD_SELELTYP) + ierr=infoerror(1) + + CALL WDialogPutInteger(IDF_INTEGER1,NS) + + CALL WDialogSelect(IDD_SELELTYP) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,ModaL) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetInteger(IDF_INTEGER1,NS) + go to 80 + ENDIF + enddo +80 CONTINUE + ICLL=4 + call clscrn + call plotot(0) + nefl=0 + DO N=1,NE + IF(IMAT(N) .EQ. NS) THEN + CALL FILLEMC(N,ICLL) + nefl=nefl+1 + neflag(nefl)=n + + ENDIF + ENDDO + nbrr=0 + nhtp=15 + call hedr + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + if(ibox .eq. 1 .or. iflag .eq. 'd') then + do n=1,nefl + j=neflag(n) + call deltel(j) + enddo + nefl=0 + elseif(ibox .eq. 2 .or. iflag .eq. 'e') then + call refb + elseif(ibox .eq. 3 .or. iflag .eq. 't') then + nhtp=0 + nbrr=4 + NMESS=45 + call hedr + nmess=2 + call getint(mat) + ipsw(7)=1 + ipsw(5)=0 + do n=1,nefl + j=neflag(n) + imat(j) = mat + enddo + nefl=0 + elseif(ibox .eq. 4 .or. iflag .eq. 'm') then +! +! simplify layout +! + IECHG=0 +!IPK MAY03 + ICHG=0 + CALL SMFY + +!ipk dec11 + elseif(ibox .eq. 5 .or. iflag .eq. 'g') then +! +! form group +! + CALL FORMGP + + elseif(ibox .eq. 6) then + do n=1,nefl + j=neflag(n) + do jj=1,8 + if(nop(j,jj) .ne. 0) then + wd(nop(j,jj))=-9999. + endif + enddo + enddo + endif + + RETURN + END + + SUBROUTINE MVGRP(NDLIST,NODLIST) + + USE WINTERACTER + USE BLK1MOD + INCLUDE 'TXFRM.COM' + dimension nodlist(maxp),RLAY(9) + character*1 iflag +! GET AMOUNT OF SHIFT IN PAGE UNITS + 200 continue + NHTP = 16 + NMESS = 47 + NBRR = 0 + CALL HEDR + CALL xyloc(xscrn1,yscrn1,iflag,ibox) + CALL XYLOC(XSCRN2,YSCRN2,IFLAG,IBOX) + XSHIFT=XSCRN2-XSCRN1 + YSHIFT=YSCRN2-YSCRN1 +! APPLY SHIFT TO NODES IN THE LIST + DO N=1,NDLIST + CORD(NODLIST(N),1)=CORD(NODLIST(N),1)+XSHIFT + CORD(NODLIST(N),2)=CORD(NODLIST(N),2)+YSHIFT + ENDDO + CALL PLOTOT(0) + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to save'//& + CHAR(13)//'new coordinate location?' ,& + 'COORDINATE MOVE') + IF (WInfoDialog(4) .EQ. 2) then +! revert to old + DO N=1,NDLIST + CORD(NODLIST(N),1)=(XUSR(NODLIST(N))+XS)/TXSCAL + CORD(NODLIST(N),2)=(YUSR(NODLIST(N))+YS)/TXSCAL + ENDDO + CALL PLOTOT(0) + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to '//& + CHAR(13)//'try again?' ,& + 'COORDINATE MOVE') + IF (WInfoDialog(4) .EQ. 2) then + return + else + go to 200 + endif + else +! accept + END IF + RETURN + END \ No newline at end of file diff --git a/src/src83e/SHOWEQ.F90 b/src/src83e/SHOWEQ.F90 new file mode 100644 index 0000000..735dc5c --- /dev/null +++ b/src/src83e/SHOWEQ.F90 @@ -0,0 +1,237 @@ + SUBROUTINE SHOWEQ(ISWT) + use winteracter + USE BLKELTLD + save + include 'D.inc' + INCLUDE 'TXFRM.COM' +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + REAL HMAX(200),HRSTART,HREND + INTEGER IYSTART, IYEND, IDYSTART,IDYEND,ick1 + data ick1/0/,ITIME/0/ + IF(ISWT .EQ. 1) GO TO 140 + IF(ITIME .EQ. 0) THEN + IYSTART=IYDATE(1) + IYEND=IYDATE(1) + IDYSTART=TAE(1,1)/24. + HRSTART=TAE(1,1)-IDYSTART*24 + IDYSTART=IDYSTART+1 + IDYEND=IDYSTART + HREND=HRSTART + ITIME=1 + ENDIF + call wdialogload(IDD_SETUPELDISP) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_IDD_SETUPELDISP) + ierr=infoerror(1) + call wdialogputRadioButton(idf_radio1) + call wdialogputCheckBox(idf_check1,ick1) + CALL WDialogPutInteger(idf_integer1,IYSTART) + CALL WDialogPutInteger(idf_integer2,IDYSTART) + CALL WDialogPutInteger(idf_integer3,IYEND) + CALL WDialogPutInteger(idf_integer5,IDYEND) + CALL WDialogPutReal(idf_real1,HRSTART) + CALL WDialogPutReal(idf_real3,HREND) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + call wdialogGetRadioButton(idf_radio1,iopt) + call wdialogGetCheckBox(idf_check1,ick1) + CALL WDialogGetInteger(idf_integer1,IYSTART) + CALL WDialogGetInteger(idf_integer2,IDYSTART) + CALL WDialogGetInteger(idf_integer3,IYEND) + CALL WDialogGetInteger(idf_integer5,IDYEND) + CALL WDialogGetReal(idf_real1,HRSTART) + CALL WDialogGetReal(idf_real3,HREND) + GO TO 80 + + elseif(WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + RETURN + ENDIF + ENDDO +80 CONTINUE + TTMIN=1.E20 + TTMAX=-1.E20 + if(ick1 .eq. 0) then + DO I=1,NQHYD + IF(IRMATYP .EQ. 11) THEN + IF(NEST(I) .EQ. 3) CYCLE + ENDIF + NST=NHYE(I) + if(iopt .eq. 1) then + HMAX(I)=-1.E20 + DO K=1,NST + HMAX(I)=MAX(HAE(K,I),HMAX(I)) + ENDDO + TTMIN=MIN(HMAX(I),TTMIN) + TTMAX=MAX(HMAX(I),TTMAX) + else + HMAX(I)=0.0 + DO K=2,NST + IF(TAE(K,I)-TAE(K-1,I) .LT. 0.) THEN + IF(MOD(IYDATE(I),4) .EQ. 0) THEN + TCOR=366*24. + ELSE + TCOR=365*24. + ENDIF + ELSE + TCOR=0. + ENDIF + HMAX(I)=HMAX(I)+(HAE(K-1,I)+HAE(K,I))/2.*(TAE(K,I)+TCOR-TAE(K-1,I))*3.600E-3 + ENDDO + TTMIN=MIN(HMAX(I),TTMIN) + TTMAX=MAX(HMAX(I),TTMAX) + endif + ENDDO + else + DO I=1,NQHYD + IF(IRMATYP .EQ. 11) THEN + IF(NEST(I) .EQ. 3) CYCLE + ENDIF + TASTART=(IDYSTART-1)*24.+HRSTART + TAEND=(IDYEND-1)*24.+HREND + IF(IYSTART-IYDATE(I) .GT. 0) THEN + TASTART=TASTART+365*24.*(IYSTART-IYDATE(I)) + IF(MOD(IYDATE(I),4) .EQ. 0) TASTART=TASTART+24. + ENDIF + IF(IYEND-IYDATE(I) .GT. 0) THEN + TAEND=TAEND+365*24.*(IYEND-IYDATE(I)) + IF(MOD(IYDATE(I),4) .EQ. 0) TAEND=TAEND+24. + ENDIF + NST=NHYE(I) + if(iopt .eq. 1) then + HMAX(I)=-1.E20 + TCOR=0. + DO K=2,NST + IF(TAE(K,I)-TAE(K-1,I) .LT. 0.) THEN + TCOR=TCOR+365*24. + ENDIF + TTEMP=TAE(K,I)+TCOR + IF(TTEMP .LT. TASTART) CYCLE + IF(TTEMP .GT. TAEND) GO TO 120 + HMAX(I)=MAX(HAE(K,I),HMAX(I)) + ENDDO +120 CONTINUE + TTMIN=MIN(HMAX(I),TTMIN) + TTMAX=MAX(HMAX(I),TTMAX) + else + HMAX(I)=0.0 + TCOR=0. + DO K=2,NST + IF(TAE(K,I)-TAE(K-1,I) .LT. 0.) THEN + IF(MOD(IYDATE(I),4) .EQ. 0) THEN + TCOR=TCOR+366*24. + ELSE + TCOR=TCOR+365*24. + ENDIF +! TCOR=TCOR+365*24. + TDIF=TAE(K,I)-TAE(K-1,I)+TCOR + ELSE + TDIF=TAE(K,I)-TAE(K-1,I) + ENDIF + TTEMP=TAE(K,I)+TCOR + IF(TTEMP .LT. TASTART) CYCLE + IF(TTEMP .GT. TAEND) GO TO 130 + HMAX(I)=HMAX(I)+(HAE(K-1,I)+HAE(K,I))/2.*TDIF*3.600E-3 + ENDDO +130 CONTINUE + TTMIN=MIN(HMAX(I),TTMIN) + TTMAX=MAX(HMAX(I),TTMAX) + endif + ENDDO + endif + ISZ=1 + RAD=10. + CALL CSET(TTMIN,TTMAX,isz) +140 CONTINUE + DO I=1,NQHYD + IF(IRMATYP .EQ. 11) THEN + IF(NEST(I) .EQ. 3) CYCLE + ENDIF + DO J=1,NUMV + IF(HMAX(I) .LE. CONTUR(J)) THEN + ncoln=mod(J,13)+4 + JJ=NCLINE(I) +! CALL GETXCL(JJ,XCJ,YCJ) + call change_color(ncoln) +! CALL FILLEMC(NCLINE(I),NCOLN) + + raddisp=0.05 +! if(raddisp .lt. 0.01) raddisp=0.01 +! call circle(xcj,ycj,raddisp) + XCT=(XYCEL(I,1)+XS)/TXSCAL + YCT=(XYCEL(I,2)+YS)/TXSCAL + call circle(xct,yct,raddisp) + GO TO 200 + ENDIF + ENDDO +200 CONTINUE + ENDDO + CALL RBLACK + DO I=1,NQHYD + IF(IRMATYP .EQ. 11) THEN + IF(NEST(I) .EQ. 3) CYCLE + ENDIF + JJ=NCLINE(I) +! CALL GETXCL(JJ,XCJ,YCJ) +! CALL NUMBR(XCJ,YCJ,0.15,HMAX(I),0.0,1) + XCT=(XYCEL(I,1)+XS)/TXSCAL + YCT=(XYCEL(I,2)+YS)/TXSCAL + CALL NUMBR(XCT,YCT,0.15,HMAX(I),0.0,1) + enddo + RETURN + + END + + SUBROUTINE GETXCL(J,XCJ,YCJ) + + USE BLK1MOD + + XXC=0. + YYC=0. + IF(IMAT(J) .EQ. 0) GO TO 50 + NCN = NCORN(J) + IF(NCN .EQ. 9) THEN + NCNR=8 + ELSE + NCNR=NCN + ENDIF + NCNT=0 + DO 25 K=1,NCNR + N = NOP(J,K) +! + IF (N .EQ. 0 .OR. XUSR(N) .LT. VDX) GOTO 25 +! ! + IF (NCN .NE. 5 .OR. K .LT. 5) THEN + IF (MOD(K,2) .EQ. 1) THEN + XXC = XXC + XUSR(N) + YYC = YYC + YUSR(N) + NCNT=NCNT+1 + ENDIF + ENDIF + 25 CONTINUE + + IF(NCN .LT. 9) THEN + XCJ = XXC/NCNT + YCJ = YYC/NCNT + ELSE + XCJ= XUSR(NOP(J,9)) + YCJ= YUSR(NOP(J,9)) + ENDIF + 50 CONTINUE + RETURN + END + \ No newline at end of file diff --git a/src/src83e/SHOWEQ.FOR b/src/src83e/SHOWEQ.FOR new file mode 100644 index 0000000..8d7972b --- /dev/null +++ b/src/src83e/SHOWEQ.FOR @@ -0,0 +1,8 @@ + SUBROUTINE SHOWEQ + USE BLKELTLD + DO I=1,NQHYD + IELEM=NCLINE(I) + CALL FILLEM(IELEM) + ENDDO + RETURN + END diff --git a/src/src83e/SMFY.F90 b/src/src83e/SMFY.F90 new file mode 100644 index 0000000..ac1810f --- /dev/null +++ b/src/src83e/SMFY.F90 @@ -0,0 +1,70 @@ + SUBROUTINE SMFY + + USE BLKMAP + USE BLK1MOD + USE BLK2MOD + DATA SPAC/0.0/ +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + +! First delete selected elements and create list of nodes + + do n=1,np + list(n)=0 + ninc(n)=0 + enddo + + do n=1,nefl + j=neflag(n) + do k=1,8,2 + if(nop(j,k) .gt. 0) list(nop(j,k))=1 + enddo + call deltel(j) + enddo + +! All corner nodes connected to elements now have LIST=1 + +! Remove nodes that are still connected from list +! But keep list of nodes that are dropped +! Now form list of nodes to be refined + do n=1,ne + if(imat(n) .gt. 0) then + do k=1,8,2 + if(nop(n,k) .gt. 0) then + if(list(nop(n,k)) .eq. 1) then + ninc(nop(n,k))=1 + endif + list(nop(n,k))=0 + endif + enddo + endif + enddo + + +! Get simplification options + + CALL TRIANOPT(NINTV,SPAC) + +! Sort points into ascending x order + + CALL SORTDB(XUSR,NKEY,NP) + +! Drop points based on spacing + + IF(NINTV .GT. 1 .OR. SPAC .GT. 0.) THEN + CALL DROPPTS(NP,NINTV,SPAC) + ENDIF + +! Add back in the edge nodes + + DO N=1,NP + IF(NINC(N) .EQ. 1) LIST(N)=1 + ENDDO + +! Form new triangles + + call deln2(np,2) + +! + RETURN + END \ No newline at end of file diff --git a/src/src83e/SPLIT.F90 b/src/src83e/SPLIT.F90 new file mode 100644 index 0000000..ed7c10c --- /dev/null +++ b/src/src83e/SPLIT.F90 @@ -0,0 +1,345 @@ +!IPK NEW ROUTINE SEP 9 2006 + SUBROUTINE SPLITN +! +! Generate continuity lines +! + + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD + include 'd.inc' + +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INCLUDE 'TXFRM.COM' + CHARACTER*1 IFLAG + DIMENSION DIRL(350),IPROCES(MAXE) +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR + + DATA SPAC/10./,ieltyp/1/,ielsw/1/,iensw/0/ + +! DIST(N1,N2)=SQRT((CORD(N1,1)-CORD(N2,1))**2 & +! & +(CORD(N1,2)-CORD(N2,2))**2) + PROJ(N1,N2,DR)= (CORD(N2,1)-CORD(N1,1))*COS(DR)+(CORD(N2,2)-CORD(N1,2))*SIN(DR) +! + icln=1 + dirsplIt=0. + ieltyp=1 + ientyp=1 + SPAC=10. + call wdialogload(IDD_DISPLIT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DISPLIT) + ierr=infoerror(1) + + call wdialogputradiobutton(idf_radio1) + CALL WDialogPutinteger(IDF_INTEGER3,icln) + CALL WDialogPutReal(IDF_REAL1,SPAC) + CALL WDialogPutinteger(IDF_INTEGER2,IELTYP) + call wdialogputcheckbox(IDF_check1,ielsw) + call wdialogputcheckbox(IDF_check2,iensw) + CALL WDialogPutinteger(IDF_INTEGER6,IENTYP) + CALL WDialogPutReal(IDF_REAL2,DIRSPLIT) + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,iswr) + CALL WDialogGetinteger(IDF_INTEGER3,icln) + CALL WDialogGetREAL(IDF_REAL1,SPAC) + CALL WDialogGetinteger(IDF_INTEGER2,IELTYP) + call wdialogGetcheckbox(IDF_check1,ielsw) + call wdialogGetcheckbox(IDF_check2,iensw) + CALL WDialogGetinteger(IDF_INTEGER6,IENTYP) + CALL WDialogGetREAL(IDF_REAL2,DIRSPLIT) + GO TO 100 + ENDIF + + enddo + +100 CONTINUE + + if(iswr .eq. 1) then + CALL CCLINE(2) + else + DO KK=1,350 + if(iccln(icln,KK) .eq. 0) then + ntract=kk-1 + go to 102 + endif + itrac(kk)=ICCLN(icln,KK) + enddo +102 continue + endif + DO N=1,NTRACT + + N1=ITRAC(N) + IF(N .GT. 1) THEN + N0=ITRAC(N-1) + ENDIF + IF(N .LT. NTRACT) THEN + N2=ITRAC(N+1) + ENDIF + +! Get direction + + IF(N .EQ. 1) THEN + IF(NTRACT .GT. 1) THEN + DIRX=XUSR(N2)-XUSR(N1) + DIRY=YUSR(N2)-YUSR(N1) + DIRL(N)=ATAN2(DIRX,-DIRY) + ELSE + DIRL(N)=DIRSPLIT + ENDIF + ELSEIF(N .EQ. NTRACT) THEN + DIRX=XUSR(N1)-XUSR(N0) + DIRY=YUSR(N1)-YUSR(N0) + DIRL(N)=ATAN2(DIRX,-DIRY) + ELSE + DIRX=XUSR(N2)-XUSR(N0) + DIRY=YUSR(N2)-YUSR(N0) + DIRL(N)=ATAN2(DIRX,-DIRY) + ENDIF + ENDDO +! Move nodes apart adding new numbers + + DO N=1,NTRACT + N1=ITRAC(N) + CALL GETNOD(J) + JTRAC(N)=J + XUSR(J)=XUSR(N1)-SPAC/2.*COS(DIRL(N)) + YUSR(J)=YUSR(N1)-SPAC/2.*SIN(DIRL(N)) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + INEW(J)=1 + INSKP(J) = 0 + + XUSR(N1)=XUSR(N1)+SPAC/2.*COS(DIRL(N)) + YUSR(N1)=YUSR(N1)+SPAC/2.*SIN(DIRL(N)) + CORD(N1,1)=(XUSR(N1)+XS)/TXSCAL + CORD(N1,2)=(YUSR(N1)+YS)/TXSCAL + WD(J)=WD(N1) + WIDTH(J)=WIDTH(N1) + SS1(J)=SS1(N1) + SS2(J)=SS2(N1) + WIDS(J)=WIDS(N1) + WIDBS(J)=WIDBS(N1) + SSO(J)=SSO(N1) + ENDDO + + +! Form list of elements connected to nodes + IERR=0 + CALL NDNECON(IERR) + +! find each element + + IPROCES=0 + + IF(NTRACT .GT. 1) THEN + DO N=1,NTRACT-1 + DO K=1,NDELM(ITRAC(N)) + J=NECON(ITRAC(N),K) +! IF(IPROCES(J) .EQ. 0) THEN + IJ=0 + II=0 + DO L=1,NCORN(J),2 + IF(NOP(J,L) .EQ. ITRAC(N) .or. NOP(J,L) .EQ. JTRAC(N)) II=L + IF(NOP(J,L) .EQ. ITRAC(N+1)) IJ=L + ENDDO + IF(IJ .NE. 0) THEN + IF(IJ .LT. II .OR. (II .EQ. 1 .and. ij .ne. 3) ) THEN + IF(II .EQ. NCORN(J)-1 .AND. IJ .EQ. 1) GO TO 200 +! MATCH FOUND + NOP(J,II)= JTRAC(N) + NOP(J,IJ)= JTRAC(N+1) + IPROCES(J)=1 + GO TO 300 + ENDIF + 200 CONTINUE + IPROCES(J)=1 + ENDIF + 300 CONTINUE +! ENDIF + ENDDO + ENDDO + + ENDIF + + DO N=1,NTRACT + DO K=1,NDELM(ITRAC(N)) + J=NECON(ITRAC(N),K) + IF(IPROCES(J) .EQ. 0) THEN + II=0 + DO L=1,NCORN(J),2 + IF(NOP(J,L) .EQ. ITRAC(N)) II=L + ENDDO + IF(II .NE. 0) THEN + A0P=-9999. + A0M=9999. + B0P=-9999. + B0M=9999. + DO L=1,NCORN(J),2 + IF(II .NE. NOP(J,L)) THEN + ITEST=NOP(J,L) + ENDIF + A1=PROJ(ITEST,ITRAC(N),DIRL(N)) + IF(A1 .GT. A0P) A0P=A1 + IF(A1 .LT. A0M) A0M=A1 + B1=PROJ(ITEST,JTRAC(N),DIRL(N)) + IF(B1 .GT. B0P) B0P=B1 + IF(B1 .LT. B0M) B0M=B1 + ENDDO + IF(ABS(A0M) .GT. ABS(A0P)) THEN + A0P=A0M + B0P=B0M + ENDIF + IF(ABS(A0P) .GT. ABS(B0P)) THEN + NOP(J,II)= JTRAC(N) + ENDIF + IPROCES(J)=1 + ENDIF + ENDIF + ENDDO + ENDDO + IERR=0 + CALL NDNECON(IERR) + + IF(IELSW .EQ. 0) GO TO 400 +! form new elements + + DO N=1,NTRACT-1 + CALL GETELM(J) + NOP(J,1)=JTRAC(N) + NOP(J,3)=JTRAC(N+1) + NOP(J,5)=ITRAC(N+1) + NOP(J,7)=ITRAC(N) + NOP(J,2)=0 + NOP(J,4)=0 + NOP(J,6)=0 + NOP(J,8)=0 + IMAT(J)=IELTYP + NCORN(J) = 8 + IESKP(J) = 0 + NE = MAX(J,NE) + ENDDO + + 400 CONTINUE + + if(iensw .gt. 0) then + + + +! start at first node + IF(NDELM(ITRAC(1)) .GT. 1) THEN + DO K=1,NDELM(ITRAC(1)) + J=NECON(ITRAC(1),K) + DO KZ=1,NCORN(J),2 + IF(NOP(J,KZ) .EQ. ITRAC(1)) THEN + K1=KZ + GO TO 500 + ENDIF + ENDDO + 500 KK=K1-2 + IF(KK .LT. 0) KK=NCORN(J)-1 + KUP=NOP(J,KK) + DO KZ=1,NDELM(KUP) + JJ=NECON(KUP,KZ) + DO KY=1,NCORN(JJ),2 + IF(NOP(JJ,KY) .EQ. KUP) THEN + K2=KY + GO TO 550 + ENDIF + ENDDO + 550 KL=K2-2 + IF(KL .LT. 0) KL=NCORN(JJ)-1 + IF(NOP(JJ,KL) .EQ. JTRAC(1)) THEN + GO TO 600 + ENDIF + ENDDO + ENDDO + +! FOUND A MATCH + + 600 CONTINUE + CALL GETELM(JK) + NOP(JK,1)=ITRAC(1) + NOP(JK,3)=KUP + NOP(JK,5)=JTRAC(1) + NOP(JK,2)=0 + NOP(JK,4)=0 + NOP(JK,6)=0 + IMAT(JK)=IENTYP + NCORN(JK) = 6 + IESKP(JK) = 0 + NE = MAX(JK,NE) + ENDIF + + IF(NDELM(ITRAC(NTRACT)) .GT. 1) THEN + DO K=1,NDELM(ITRAC(NTRACT)) + J=NECON(ITRAC(NTRACT),K) + DO KZ=1,NCORN(J),2 + IF(NOP(J,KZ) .EQ. ITRAC(NTRACT)) THEN + K1=KZ + GO TO 650 + ENDIF + ENDDO + 650 KK=K1+2 + IF(KK .GT. NCORN(J)) KK=1 + KUP=NOP(J,KK) + DO KK=1,NDELM(KUP) + JJ=NECON(KUP,KK) + DO KY=1,NCORN(JJ),2 + IF(NOP(JJ,KY) .EQ. KUP) THEN + K2=KY + GO TO 700 + ENDIF + ENDDO + 700 KL=K2+2 + IF(KL .GT. NCORN(JJ)) KL=1 + IF(NOP(JJ,KL) .EQ. JTRAC(NTRACT)) THEN + GO TO 750 + ENDIF + ENDDO + ENDDO + GO TO 800 + +! FOUND A MATCH + + 750 CONTINUE + CALL GETELM(JK) + + NOP(JK,1)=JTRAC(NTRACT) + NOP(JK,3)=KUP + NOP(JK,5)=ITRAC(NTRACT) + NOP(JK,2)=0 + NOP(JK,4)=0 + NOP(JK,6)=0 + IMAT(JK)=IENTYP + NCORN(JK) = 6 + IESKP(JK) = 0 + NE = MAX(JK,NE) + ENDIF + + endif + + 800 CONTINUE + call clscrn + CALL PLOTOT(1) + NHTP=1 + NMESS=0 + NBRR=0 + CALL HEDR + RETURN + END \ No newline at end of file diff --git a/src/src83e/SWMAP.F90 b/src/src83e/SWMAP.F90 new file mode 100644 index 0000000..e57ddef --- /dev/null +++ b/src/src83e/SWMAP.F90 @@ -0,0 +1,91 @@ + SUBROUTINE SWMAP + + USE BLKMAP + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + + LOGICAL OPENTS + CHARACTER*1 iflag + + ISWAP=IBAK + IBAK=15 + +! Write out RM1 file + + INQUIRE(IBAK, OPENED=OPENTS) + IF(.NOT. OPENTS) THEN + OPEN(IBAK,STATUS='SCRATCH',FORM='UNFORMATTED') + ENDIF + REWIND IBAK + CALL WRTOUT(0) + REWIND IBAK + IBAK=ISWAP + +! Now put map data into RM1 position + + NE=NELTS + DO J=1,NE + DO K=1,8 + NOP(J,K)=0. + ENDDO + IF(NOPEL(J,1) .GT. 0) THEN + NOP(J,1)=NOPEL(J,1) + NOP(J,3)=NOPEL(J,2) + NOP(J,5)=NOPEL(J,3) + NCORN(J)=6 + IMAT(J)=1 + IESKP(J) = 0 + ELSE + NCORN(J)=0 + IMAT(J)=0 + IESKP(J) = 1 + ENDIF + ENDDO + NP=MAXPTS + DO J=1,NP + XUSR(J)=XMAP(J) + YUSR(J)=YMAP(J) + CORD(J,1) = XUSR(J) + CORD(J,2) = YUSR(J) + WD(J)=VAL(J) + INSKP(J)=0 + IF (CORD(J,1) .GT. VDX) THEN + INEW(J) = 1 + ENDIF + ENDDO + NLST=0 + NENTRY=0 + NLAYD=0 + NCLM=0 + CALL RESCAL + CALL HEDR + RETURN + END + + SUBROUTINE SWRM1 + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + NOPEL(N,1)=NOP(N,1) + NOPEL(N,2)=NOP(N,3) + NOPEL(N,3)=NOP(N,5) + ELSE + NOPEL(N,1)=0 + NOPEL(N,2)=0 + NOPEL(N,3)=0 + ENDIF + ENDDO + CALL RDRST(1,15) + CALL RDRST(2,15) + CALL RDRST(3,15) + REWIND 15 + CALL RESCAL + CALL HEDR + RETURN + END diff --git a/src/src83e/SYMBL.F90 b/src/src83e/SYMBL.F90 new file mode 100644 index 0000000..7ef3282 --- /dev/null +++ b/src/src83e/SYMBL.F90 @@ -0,0 +1,1441 @@ +!IPK LAST UPDATE SEP 23 2015 REVISE TESTING FOR RIVER SECTIONS + subroutine tekgin(x,y,iflag) + save +!iPK APR94 + COMMON /RECOD/ IRECD,TSPC + character*1 iflag,iiflag,iflags + data rsclx,rscly/100.0,100./ + data itime/0/ + if(itime .eq. 0) then + itime=1 + iky=0 + endif +!iPK APR94 + IF(IRECD .EQ. 2) THEN + if(iky .eq. 0) then + READ(91,'(2F7.2,A1)') X,Y,IFLAG + iflags=iflag + xs=x + ys=y + else + iflag=iflags + x=xs + y=ys + endif +! write(*,'(2f7.2,a1,i4)') x,y,iflag,iky + call flush_screen + CALL INTRVL(TA,0) + 90 CALL INTRVL(TA,1) + IF(TA .LT. TSPC) GO TO 90 + if(tspc .eq. 0.) then + call gim_an_event(ix,iy,iiflag) + if(iiflag .eq. '~') then + iflag='P' + iky=1 + return + endif + endif + iky=0 + ENDIF +100 continue +! write(*,'(2i15,a1,i3)') ix,iy,iflag,iky + if(irecd .eq. 2) return + call flush_screen + CALL gim_an_event(ix, iy, iiflag) +! write(*,'(2i5,a1)') ix,iy,iiflag + IF (iiflag.eq.'~') then +! call hedr +! CALL plotot +! call hedr + iflag='P' + iky=1 +! go to 100 + return + endif + iky=0 +! if(irecd .eq. 2) return + x= float(ix)/rsclx +! y= 8.0-float(iy)/rscly + y= float(iy)/rscly + iflag=iiflag +! write(90,666) x,y,iflag,ix,iy,iiflag,iky +! 666 format('tekgin',2f8.2,a1,2i5,a1,i2) + if(iflag .eq. 'u') then + go to 100 + endif + +!ipk apr94 + if(irecd .eq. 1) then + write(91,'(2f7.2,a1)') x,y,iflag + endif + + return + end + + subroutine draw(x,y) + save + common /pltc/ipsav,iflg,xll,yll + + data rsclx,rscly/100.,100./ + ix=x*rsclx + iy=y*rscly + CALL gim_a_line(ix, iy) + +! save data on file if requested + + if(ipsav .gt. 0) then + +! don't write out point unless > .005" from previous point + + if (abs(xll-x) .ge. .005 .or. abs(yll-y) .ge. .005 ) then + write(ipsav,99) 'pa',x,y + xll = x + yll = y + iflg = 0 + else + iflg = 1 + endif + endif +99 format (a2,2f8.3) + return + end + + + subroutine move(x,y) + save + common /pltc/ipsav,iflg,xll,yll + + data rsclx,rscly/100.,100./ + ix=x*rsclx + iy=y*rscly + CALL move_da_pointer(ix, iy) + +! save data on file if requested + + if(ipsav .gt. 0) then + +! don't write out point unless > .005" from previous point + + write(ipsav,99) 'ma',x,y + xll = x + yll = y + iflg = 0 + endif +99 format (a2,2f8.3) + return + end + +!************************************************************* +! +! SYMBOL SUBROUTINE +! +! ROUTINE TO OUTPUT !HARACTER STRINGS. +! +!***************************************************************** + SUBROUTINE SYMBL (X,Y,HEIGHT,STRING,ANGLE,NCHAR) + save + COMMON /PLTC/IPSAV,IFLG,XLL,YLL + CHARACTER*(*) STRING + CHARACTER*32 FMT1 + CHARACTER*2 PS + CHARACTER*2 IHT + DATA PS/'PS'/,HT/0.8/ + integer*4 nchar + IHT(1:1)=CHAR(27) + IHT(2:2)=':' + + HT=height*5. + +! if(height .gt. 0.7) then +! ht=height +! else +! ipk mar01 +! ht=0.6 +! endif +! +! Centered symbols +! + ICHR = -1 + IF (NCHAR .LT. 0) THEN + ICHR = ICHAR(STRING(1:1)) + IF (ICHR .EQ. 0) STRING(1:1) = CHAR(35) + IF (ICHR .EQ. 1) STRING(1:1) = CHAR(33) + IF (ICHR .EQ. 2) STRING(1:1) = CHAR(39) + IF (ICHR .EQ. 3) STRING(1:1) = CHAR(41) +!cc WRITE(2,'(A)') 'SS "CENTERED.SYM"' + ENDIF +! + ZANGLE = ANGLE + LSTR = LENSTR(STRING) + LSTR = MIN(LSTR,IABS(NCHAR)) +! +! ixx = x*scrnx +! iyy = (7.50-y-0.2)*scrny + +! +! + CALL QUAD(X,Y,ITS) + IF(ITS .EQ. 22) THEN + yy=y +! CALL move( x, yy) + CALL LABL(X,YY,LSTR,HT,STRING) + ANGL = ZANGLE/3.14159 + XLAS = X + COS(ANGL)*(HEIGHT*LSTR) + YLAS = Y + SIN(ANGL)*(HEIGHT*LSTR) +! + IF(IPSAV .GT. 0) THEN + HTG=HT*0.75 + WRITE(FMT1,198) NCHAR + 198 FORMAT(18h(A2,4F8.3,1X,1H",A,i2,5h,1H")) + WRITE(ipsav,FMT1) PS,X,Y,HTG,ANGLE,STRING + ENDIF + + ENDIF +! + RETURN + END + SUBROUTINE QUAD(X,Y,IST) +!- +!...... Subroutine to establish location of X and Y relative to bounds +!- + COMMON /PAGE/ XL,XH,YL,YH +!- +!...... Test side of X +!- + IST=22 + IF(X .LT. XL) IST=12 + IF(X .GT. XH) IST=32 +!- +!...... Test side of Y +!- + IF(Y .LT. YL) IST=IST-1 + IF(Y .GT. YH) IST=IST+1 +!- +!...... Final pattern for IST is +!- +! 13 23 33 +! ------ +! 12 | 22 | 32 +! ------ +! 11 21 31 +! + RETURN + END + + SUBROUTINE TRIM(XO,YO,XI,YI,XB,YB,IST,ISTN) + +!...... Subroutine to compute coordinates for XB and YB on the boundary + + COMMON /PAGE/ XL,XH,YL,YH + IF(IST .LT. 20) THEN + +!...... XO is to the left + + IF(ISTN .LT. 20) THEN + +!...... XI is also left skip out +! by setting IST negative + + IST=-IST + RETURN + ELSE + XB = XL + YB = YO+(YI-YO)/(XI-XO)*(XL-XO) + +!...... Check location of YB. If its within limits we are done +! or have found a totally crossing line + + IF(YB .LT. YL) THEN + +!...... Below + + IF (YI .EQ. YB) THEN + XB = 999. + ELSE + XB = XB+(XI-XB)/(YI-YB)*(YL-YB) + ENDIF + YB = YL + IF(XB .GT. XH .OR. XB .LT. XL) THEN + +!...... Signify that final point is still out by negative IST + + IST=-IST + ELSEIF(ISTN .NE. 22) THEN + +!...... Part of a crossing line set ISTN negative + + ISTN=-ISTN + ENDIF + ELSEIF(YB .GT. YH) THEN + +!...... Above + + IF (YI .EQ. YB) THEN + XB = 999. + ELSE + XB = XB+(XI-XB)/(YI-YB)*(YH-YB) + ENDIF + YB = YH + IF(XB .GT. XH .OR. XB .LT. XL) THEN + IST=-IST + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ENDIF + ELSEIF(IST .GT. 30) THEN + +!...... XO is to the right + + IF(ISTN .GT. 30) THEN + +!...... XI is also right skip out + IST=-IST + ELSE + XB = XH + YB = YO+(YI-YO)/(XI-XO)*(XH-XO) + +!...... Check location of YB. If its within limits we are done + + IF(YB .LT. YL) THEN + +!...... Below + + IF (YI .EQ. YB) THEN + XB = 999. + ELSE + XB = XB+(XI-XB)/(YI-YB)*(YL-YB) + ENDIF + YB = YL + IF(XB .GT. XH .OR. XB .LT. XL) THEN + IST=-IST + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ELSEIF(YB .GT. YH) THEN + +!...... Above + + IF (YI .EQ. YB) THEN + XB = 999. + ELSE + XB = XB+(XI-XB)/(YI-YB)*(YH-YB) + ENDIF + YB = YH + IF(XB .GT. XH .OR. XB .LT. XL) THEN + IST=-IST + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ENDIF + ELSE + +!...... XO is in the middle section + +!...... Check location of YB. If its within limits we are done + + IF(YO .LT. YL) THEN + +!...... Below + + IF(MOD(ISTN,10) .EQ. 1) THEN + +!...... still out + + IST=-IST + ELSE + YB = YL + IF (YI .EQ. YO) THEN + XB = 999. + ELSE + XB = XO+(XI-XO)/(YI-YO)*(YL-YO) + ENDIF + IF(XB .GT. XH .OR. XB .LT. XL) THEN + IST=-IST + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ENDIF + ELSEIF(YO .GT. YH) THEN + +!...... Above + + IF(MOD(ISTN,10) .EQ. 3) THEN + +!...... still out + + IST=-IST + ELSE + YB = YH + IF (YI .EQ. YO) THEN + XB = 999. + ELSE + XB = XO+(XI-XO)/(YI-YO)*(YH-YO) + ENDIF + IF(XB .GT. XH .OR. XB .LT. XL) THEN + IST=-IST + ELSEIF(ISTN .NE. 22) THEN + ISTN=-ISTN + ENDIF + ENDIF + ENDIF + ENDIF + RETURN + END + + SUBROUTINE NUMBR(X,Y,HITE,RNUM,THETA,NDEC) +! This routine has been extensively rewritten AUG 94 + SAVE + COMMON /PLTC/IPSAV,IFLG,XLL,YLL + integer*4 ndec + CHARACTER*36 FMT,FMT1,NARRAY + CHARACTER*1 QOT + + +! WHERE: X,Y DEFINE THE COORDINATES OF THE LOWER-LEFT CORNER OF THE +! FIRST DIGIT TO BE PLOTTED +! HITE CHARACTER HEIGHT (INCHES) +! RNUM THE REAL NUMBER TO BE PLOTTED +! THETA THE ANGLE (IN DEGREES) THE CHARACTER STRING MAKES WITH THE +! X-AXIS +! NDEC THE OF DECIMAL PLACES TO WHICH THE IS PLOTTED + + + DATA QOT/'"'/ + CALL CVF(RNUM,NDEC,NARRAY,NUMC) + CALL SYMBL(X,Y,HITE,NARRAY,THETA,NUMC) + IF(IPSAV .GT. 0) THEN + XLAS=X+NUMC*HITE*0.75 + YLAS=Y + ZANGLE = THETA + HTG=HITE*0.75 + WRITE(IPSAV,199) 'PS',X,Y,HTG,ZANGLE,(NARRAY(I:I),I=1,NUMC),QOT +199 FORMAT (A2,2F8.3,2F8.3,1X,1H",11A1) + ENDIF + RETURN + + END + + + + subroutine polyfl(x,y,npts,icol) +! polygon fill routine npts close it , colour code is icol + save + dimension x(*),y(*) + dimension itran(0:16) + data itran/0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16/ + IF(icol .EQ. -11) then + icll=8 + else + icll=itran(icol) + endif + if (npts .lt. 4) return + CALL nwpen(icll) + CALL fill_a_polygon(x,y,npts) + call Rblue + return + end +! --------------------------------------------------------------------------- + + subroutine nwpen(icl) + + CALL change_color(icl) + return + end + + subroutine RGrey + icl=15 +! 240 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + + subroutine RBlack + icl=14 +! 223 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + subroutine Rwhite + icl=0 +! 224 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + subroutine Rwhiteb + icl=1 +! 224 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + subroutine RRed + icl=12 +! 16 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + subroutine RBlue + icl=3 +! 175 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + subroutine Rcyan + icl=5 +! 112 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + subroutine RGreen + icl=7 +! 96 + call nwpen(icl) + return + end +! ----------------------------------------------------------------------------- + + + + +! Routine to obtain keyboard entry in ascii code + + SUBROUTINE KEYBRD(K) + character*1 cha + call gim_a_charac(K,cha,x,y) + RETURN + END + + + subroutine clscrn + CALL clear_screen + return + end + + + SUBROUTINE PLOTT(XX,YY,II) + SAVE + COMMON /PLTC/IPSAV,IFLG,XLL,YLL + + COMMON /PAGE/ XL,XH,YL,YH + COMMON /PLXZ/ XLAS,YLAS,NPLT,NCHRS,XORG,YORG + + +! Save data on file if requested + + IF(IPSAV .GT. 0 .AND. II .LT. 0) THEN + WRITE(IPSAV,99) 'tr',XX,YY + WRITE(IPSAV,99) 'pi',0.0,0.0 + WRITE(IPSAV,99) 'ma',0.0,0.0 + xold=xx + yold=yy + ENDIF + 99 FORMAT (a2,2F8.3) + + IF(II .EQ. 3) THEN + CALL QUAD(XX,YY,ITS) + XOLD=XX + YOLD=YY + IF(ITS .EQ. 22) call move(xx,yy) + ENDIF + IF(II .EQ. 2) THEN + IF(ITS .EQ. 22) THEN +! was in + CALL QUAD(XX,YY,ITS) + IF(ITS .EQ. 22) THEN +! still in + CALL DRAW(XX,YY) + XOLD=XX + YOLD=YY + ELSE +! now out + ITSN=22 + CALL TRIM(XX,YY,XOLD,YOLD,XB,YB,ITS,ITSN) + CALL DRAW(XB, YB) + XOLD=XX + YOLD=YY + ITS=IABS(ITS) + ENDIF + ELSE +! was out + CALL QUAD(XX,YY,ITSN) + IF(ITSN .EQ. 22) THEN +! now in + CALL TRIM(XOLD,YOLD,XX,YY,XB,YB,ITS,ITSN) + CALL MOVE(XB, YB) + CALL DRAW(XX, YY) + XOLD=XX + YOLD=YY + ITS=22 + ELSE +! still out but could have been in for a time so test + CALL TRIM(XOLD,YOLD,XX,YY,XB,YB,ITS,ITSN) + IF(ITS .LT. 0) THEN +! yes + XOLD=XX + YOLD=YY + ITS=IABS(ITSN) + ELSEIF(ITSN .LT. 0) THEN + CALL MOVE(XB,YB) + ITSN=-ITSN + ITS=22 + XOLD=XB + YOLD=YB + CALL TRIM(XX,YY,XOLD,YOLD,XB,YB,ITSN,ITS) + CALL DRAW(XB, YB) + XOLD=XX + YOLD=YY + ITS=IABS(ITSN) + ENDIF + ENDIF + ENDIF + ENDIF + XLAS=XOLD + YLAS=YOLD + RETURN + END + + + subroutine quit_pgm + call setd(24) + close (90) + CALL get_rid_window + stop + end + +! ----------------------------------------------------------------------------- + + subroutine clrbox + CALL clear_box + return + end + + SUBROUTINE INTRVL(TA,IS) + +!...... Timing routine + +! TA is interval time in seconds + +!IPK APR94 + COMMON /RECOD/ IRECD,TSPC + + INTEGER*4 ITA,ITN + + IF(IS .EQ. 0) THEN +! CALL TIMER(ITA) + CALL GETTIM(IHR,IMIN,ISEC,IHUN) + TB=3600.*IHR+60.*IMIN+ISEC+ FLOAT(IHUN)/100. + RETURN + ELSE + CALL GETTIM(IHR,IMIN,ISEC,IHUN) + TA=3600.*IHR+60.*IMIN+ISEC+ FLOAT(IHUN)/100. +! CALL TIMER(ITN) + ENDIF +! ITIC=ITN-ITA +! IF(ITIC .LT. 0) THEN +! ITA=ITN +! ITIC=0 +! ENDIF +! TA=FLOAT(ITIC)/100. + TA=TA-TB + IF(TSPC .EQ. 0.) THEN + TA=TA-0.5 + ENDIF + RETURN + END + + SUBROUTINE DASHLN(XLIN,YLIN,NLINP,ICD) + +! Routine to draw a line with dashes + + DIMENSION XLIN(*),YLIN(*) + +! Work through points + + DO 200 K=1,NLINP + IF(K .EQ. 1) THEN + CALL PLOTT(XLIN(K),YLIN(K),3) + ELSEIF(ICD .EQ. 0) THEN + CALL PLOTT(XLIN(K),YLIN(K),2) + ELSE + +! Draw dashed line + + DASHNT=0.2/2.**ICD + SC1=(XLIN(K)-XLIN(K-1))**2 + SC2=(YLIN(K)-YLIN(K-1))**2 + SLEN=SQRT(SC1+SC2) + NDASH=IFIX(SLEN/DASHNT)+1 + XINC=(XLIN(K)-XLIN(K-1))/SLEN*DASHNT + YINC=(YLIN(K)-YLIN(K-1))/SLEN*DASHNT + XP=XLIN(K-1) + YP=YLIN(K-1) + DO 180 ND=1,NDASH + IF(ND .LT. NDASH) THEN + XP=XP+XINC + YP=YP+YINC + ELSE + XP=XLIN(K) + YP=YLIN(K) + ENDIF + IF(MOD(ND,2) .EQ. 1) THEN + CALL PLOTT(XP,YP,2) + ELSE + CALL PLOTT(XP,YP,3) + ENDIF + 180 CONTINUE + ENDIF + 200 CONTINUE + RETURN + END + + subroutine chint(iflag) + character*1 iflag + iflag='c' + return + end + SUBROUTINE GETINTAA(INUM) + + COMMON /RECOD/ IRECD,TSPC + + character*50 cha + CHARACTER*11 DATA + + CHARACTER*30 MES + DATA MES/'Error reading integer, Reenter'/ + + if(irecd .eq. 2) then + read(91,'(i7)') inum + CALL INTRVL(TA,0) + 70 CALL INTRVL(TA,1) + IF(TA .LT. TSPC) GO TO 70 + return + endif + + 80 CONTINUE + DO 90 I=1,11 + DATA(I:I)=' ' + 90 CONTINUE + + I = 1 + 10 CONTINUE + I = I+1 + + call gim_a_charac(key,cha,x,y) + +! write(90,*) 'key',key + + IF (KEY .EQ. 8) THEN + I = I-2 + GO TO 10 + ENDIF + IF(KEY .EQ. 13) GO TO 200 + DATA(I:I)=CHAR(KEY) + CALL GTEXT(4,I+20,DATA(I:I)) + 100 CONTINUE + GO TO 10 + 200 CONTINUE + + READ(DATA,5000,ERR=300) INUM + 5000 FORMAT(1X,I10) + + if(irecd .eq. 1) then + write(91,'(i7)') inum + endif + + RETURN + + 300 CONTINUE + CALL SYMBL(3.0,7.6,0.2,MES,0.0,30) + GO TO 80 + END + + + SUBROUTINE GETFPNA(FPN) + +!IPK APR94 + COMMON /RECOD/ IRECD,TSPC + + CHARACTER*11 DATA + character*50 cha + + CHARACTER*30 MES + DATA MES/'Error reading number, Reenter.'/ + + if(irecd .eq. 2) then + read(91,'(f7.2)') fpn + CALL INTRVL(TA,0) + 70 CALL INTRVL(TA,1) + IF(TA .LT. TSPC) GO TO 70 + return + endif + + 80 CONTINUE + DO 90 I=1,11 + DATA(I:I)=' ' + 90 CONTINUE + + I = 1 + 10 CONTINUE + I = I+1 + + call gim_a_charac(key,cha,x,y) + +! write(90,*) 'key',key + IF (KEY .EQ. 8) THEN + I = I-2 + GO TO 10 + ENDIF + IF(KEY .EQ. 13) GO TO 200 + DATA(I:I)=CHAR(KEY) + CALL GTEXT(4,I+20,DATA(I:I)) + 100 CONTINUE + GO TO 10 + 200 CONTINUE + + READ(DATA,5000,ERR=300) FPN + 5000 FORMAT(1X,F10.0) + + if(irecd .eq. 1) then + write(91,'(f7.2)') fpn + endif + + RETURN + + 300 CONTINUE + CALL SYMBL(3.0,7.6,0.2,MES,0.0,30) + GO TO 80 + END + + SUBROUTINE FLUSHWN + CALL FLUSH_SCREEN + RETURN + END + + subroutine gtext(j,i,cha) + character*1 cha + y=8.0-0.1*j + x=i*0.15 + call symbl(x,y,0.15,cha,0.0,1) + return + end + + subroutine fillem(ielem) + + USE BLK1MOD + INCLUDE 'TXFRM.COM' + dimension xvs(9),yvs(9) +! include 'BLK1.COM' + + ncn=ncorn(ielem) + if(ncn .gt. 5) go to 200 + N1=NOP(IELEM,1) + N2=NOP(IELEM,3) + + IF(IPW1 .EQ. 1) THEN + wd11=width(n1)/txscal + wd2=width(n2)/txscal + ELSE + BT1= & + CRSDAT(NRIVCR1(N1),1,1)*WTRIVCR1(N1)+ & + CRSDAT(NRIVCR2(N1),1,1)*WTRIVCR2(N1) + BT2= & + CRSDAT(NRIVCR1(N2),1,1)*WTRIVCR1(N2)+ & + CRSDAT(NRIVCR2(N2),1,1)*WTRIVCR2(N2) + H1=WIDEL-BT1 + H2=WIDEL-BT2 + CALL INTERPWLV(N1,H1,AR1,WR1,DWR1) + CALL INTERPWLV(N2,H2,AR2,WR2,DWR2) + WIDTH(N1)=WR1 + WIDTH(N2)=WR2 + IF(IPW1 .EQ. 2) THEN + WD11=WR1*WIDSCL/TXSCAL + WD2=WR2*WIDSCL/TXSCAL + ELSE + WD11=AR1*WIDSCL/TXSCAL + WD2=AR2*WIDSCL/TXSCAL + ENDIF + + ENDIF + + + IF(WD11 .GT. 0. .AND. WD2 .GT. 0.) THEN + X1= CORD(N1,1) + X2= CORD(N2,1) + Y1= CORD(N1,2) + Y2= CORD(N2,2) + ELDIR=ATAN2(Y2-Y1,X2-X1) + ELNORM=ELDIR-1.5708 + XVS(1)=X1+COS(ELNORM)*WD11/2. + XVS(4)=X1-COS(ELNORM)*WD11/2. + XVS(2)=X2+COS(ELNORM)*WD2/2. + XVS(3)=X2-COS(ELNORM)*WD2/2. + YVS(1)=Y1+SIN(ELNORM)*WD11/2. + YVS(4)=Y1-SIN(ELNORM)*WD11/2. + YVS(2)=Y2+SIN(ELNORM)*WD2/2. + YVS(3)=Y2-SIN(ELNORM)*WD2/2. + NPTS=4 + call polyfl(xvs,yvs,npts,14) + ENDIF + RETURN + + 200 xvs(1)=cord(nop(ielem,1),1) + yvs(1)=cord(nop(ielem,1),2) + + npts=1 + do 100 n=1,ncn + + if(n .ge. 9) go to 100 + if(nop(ielem,n) .eq. 0) go to 100 + npts=npts+1 + xvs(npts)=cord(nop(ielem,n),1) + yvs(npts)=cord(nop(ielem,n),2) + 100 continue + + call polyfl(xvs,yvs,npts,14) + return + end + + SUBROUTINE CLRSTP(y1,y2) + + REAL HSIZE + COMMON /SSIZE/ HSIZE + + dimension x(4),y(4) + x(1)=0. + x(2)=HSIZE + x(3)=HSIZE + x(4)=0. + y(1)=y1 + y(2)=y1 + y(3)=y2 + y(4)=y2 + call Rwhite + CALL fill_a_polygon(x,y,4) + call RBlue + return + end + + SUBROUTINE FILLEMC(IELEM,ICCT) + + USE BLK1MOD + INCLUDE 'BFILES.I90' + INCLUDE 'TXFRM.COM' + +! INCLUDE 'BLK1.COM' + DIMENSION X(4),Y(4) + DO 300 N=1,NCORN(IELEM),2 + M=NOP(IELEM,N) + IF(M .EQ. 0) THEN + GO TO 310 + ELSE + X((N+1)/2)=CORD(M,1) + Y((N+1)/2)=CORD(M,2) + if(i3dview .eq. 1) then + Y((N+1)/2)=Y((N+1)/2)+(WD(M)-VRTORIG)*COS(VANG/57.29578)/VRTSCAL + endif + NPOL=(N+1)/2 + ENDIF + 300 CONTINUE + 310 CONTINUE + IF(NCORN(IELEM) .GT. 5) THEN + CALL NWPEN(ICCT) + CALL fill_a_polygon(x,y,npol) + ELSE + N1=NOP(IELEM,1) + N2=NOP(IELEM,3) + IF(IPW1 .EQ. 1) THEN + wd11=width(n1)/txscal + wd2=width(n2)/txscal + ELSE + IF(NRIVCR1(N1) .EQ. 0 .AND. NRIVCR2(N1) .EQ. 0) RETURN + IF(NRIVCR1(N2) .EQ. 0 .AND. NRIVCR2(N2) .EQ. 0) RETURN + BT1= & + CRSDAT(NRIVCR1(N1),1,1)*WTRIVCR1(N1)+ & + CRSDAT(NRIVCR2(N1),1,1)*WTRIVCR2(N1) + BT2= & + CRSDAT(NRIVCR1(N2),1,1)*WTRIVCR1(N2)+ & + CRSDAT(NRIVCR2(N2),1,1)*WTRIVCR2(N2) + H1=WIDEL-BT1 + H2=WIDEL-BT2 + CALL INTERPWLV(N1,H1,AR1,WR1,DWR1) + CALL INTERPWLV(N2,H2,AR2,WR2,DWR2) + WIDTH(N1)=WR1 + WIDTH(N2)=WR2 + IF(IPW1 .EQ. 2) THEN + WD11=WR1*WIDSCL/TXSCAL + WD2=WR2*WIDSCL/TXSCAL + ELSE + WD11=AR1*WIDSCL/TXSCAL + WD2=AR2*WIDSCL/TXSCAL + ENDIF + + ENDIF + IF(WD11 .GT. 0. .AND. WD2 .GT. 0.) THEN + X1= CORD(N1,1) + X2= CORD(N2,1) + Y1= CORD(N1,2) + Y2= CORD(N2,2) + ELDIR=ATAN2(Y2-Y1,X2-X1) + ELNORM=ELDIR-1.5708 + X(1)=X1+COS(ELNORM)*WD11/2. + X(4)=X1-COS(ELNORM)*WD11/2. + X(2)=X2+COS(ELNORM)*WD2/2. + X(3)=X2-COS(ELNORM)*WD2/2. + Y(1)=Y1+SIN(ELNORM)*WD11/2. + Y(4)=Y1-SIN(ELNORM)*WD11/2. + Y(2)=Y2+SIN(ELNORM)*WD2/2. + Y(3)=Y2-SIN(ELNORM)*WD2/2. + NPOL=4 + CALL NWPEN(ICCT) + CALL fill_a_polygon(x,y,npol) + ENDIF + ENDIF + CALL RBlue + RETURN + END + + SUBROUTINE POLYG(AX,AY,NPT,N) + SAVE + DIMENSION AX(10),AY(10),BX(15),BY(15) + +! Duplicate numbers around AX to form long list +! + DO 200 I=1,NPT + AX(I+NPT)=AX(I) + AY(I+NPT)=AY(I) + 200 CONTINUE + +! Find a starting point that is on the page + + DO 250 I=1,NPT + CALL QUAD(AX(I),AY(I),ITS) + IF(ITS .EQ. 22) THEN + +! We have a starting point + + II=I + GO TO 350 + ENDIF + +! Keep looking + + 250 CONTINUE + +! No point on page then skip out + + RETURN + +! Loop to check each point and trim as required + + 350 CONTINUE + JJ=1 + BX(1)=AX(II) + BY(1)=AY(II) + XOLD=AX(II) + YOLD=AY(II) + DO 500 J=2,NPT+1 + II=II+1 + IF(ITS .EQ. 22) THEN + CALL QUAD(AX(II),AY(II),ITS) + IF(ITS .EQ. 22) THEN + +! still in copy over from A to B + + JJ=JJ+1 + BX(JJ)=AX(II) + BY(JJ)=AY(II) + XOLD=AX(II) + YOLD=AY(II) + ELSE + +! now out copy over boundary + + ITSN=22 + CALL TRIM(AX(II),AY(II),XOLD,YOLD,XB,YB,ITS,ITSN) + JJ=JJ+1 + BX(JJ)=XB + BY(JJ)=YB + XOLD=AX(II) + YOLD=AY(II) + ITS=IABS(ITS) + ENDIF + ELSE + +! WAS OUT + + CALL QUAD(AX(II),AY(II),ITSN) + IF(ITSN .EQ. 22) THEN + +! now in copy over point of return + + CALL TRIM(XOLD,YOLD,AX(II),AY(II),XB,YB,ITS,ITSN) + JJ=JJ+1 + BX(JJ)=XB + BY(JJ)=YB + +! Copy destination point + + JJ=JJ+1 + BX(JJ)=AX(II) + BY(JJ)=AY(II) + XOLD=AX(II) + YOLD=AY(II) + ITS=22 + ELSE + +! still out but could have been in for a time so test + + CALL TRIM(XOLD,YOLD,AX(II),AY(II),XB,YB,ITS,ITSN) + IF(ITS .LT. 0) THEN + +! no + + XOLD=AX(II) + YOLD=AY(II) + ITS=IABS(ITSN) + ELSEIF(ITSN .LT. 0) THEN + +! Temporarily in. Copy point of return + + JJ=JJ+1 + BX(JJ)=XB + BY(JJ)=YB + ITSN=-ITSN + ITS=22 + XOLD=XB + YOLD=YB + CALL TRIM(AX(II),AY(II),XOLD,YOLD,XB,YB,ITSN,ITS) + +! Now copy over point of exit + + JJ=JJ+1 + BX(JJ)=XB + BY(JJ)=YB + XOLD=AX(II) + YOLD=AY(II) + ITS=IABS(ITSN) + ENDIF + ENDIF + ENDIF + 500 CONTINUE + +! Record final number of points + + NPTS=JJ +!ipk sep 94 icl=mod(n,16)+1 + icl=mod(n-1,14) + call polyfl(bx,by,npts,icl) + RETURN + END + + SUBROUTINE DBDASHLN(XLIN,YLIN,NLINP,ICD) + +! Routine to draw a line with dashes + + REAL*8 XLIN(*),YLIN(*) + +! Work through points + + DO 200 K=1,NLINP + IF(K .EQ. 1) THEN + XCT=XLIN(K) + YCT=YLIN(K) + CALL PLOTT(XCT,YCT,3) + ELSEIF(ICD .EQ. 0) THEN + XCT=XLIN(K) + YCT=YLIN(K) + CALL PLOTT(XCT,YCT,2) + ELSE + +! Draw dashed line + + DASHNT=0.2/2.**ICD + SC1=(XLIN(K)-XLIN(K-1))**2 + SC2=(YLIN(K)-YLIN(K-1))**2 + SLEN=SQRT(SC1+SC2) + if(slen .lt. 0.1) then + XP=XLIN(K-1) + YP=YLIN(K-1) + CALL PLOTT(XP,YP,3) + XP=XLIN(K) + YP=YLIN(K) + CALL PLOTT(XP,YP,2) + cycle + endif + NDASH=IFIX(SLEN/DASHNT)+1 + XINC=(XLIN(K)-XLIN(K-1))/SLEN*DASHNT + YINC=(YLIN(K)-YLIN(K-1))/SLEN*DASHNT + XP=XLIN(K-1) + YP=YLIN(K-1) + DO 180 ND=1,NDASH + IF(ND .LT. NDASH) THEN + XP=XP+XINC + YP=YP+YINC + ELSE + XP=XLIN(K) + YP=YLIN(K) + ENDIF + IF(MOD(ND,2) .EQ. 1) THEN + CALL PLOTT(XP,YP,2) + ELSE + CALL PLOTT(XP,YP,3) + ENDIF + 180 CONTINUE + ENDIF + 200 CONTINUE + RETURN + END + + SUBROUTINE GETINT(ISW) + USE WINTERACTER +! +! + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + COMMON /RECOD/ IRECD,TSPC + + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + CHARACTER*47 MESOUT,MESS(46) + + DATA MESS /'Enter node to search for',' Enter material type',& + 'Enter element to search for ',& + 'Enter number of layers ',& + 'Enter width ',& + 'Click mouse at end of line ',& + 'Enter number of nodes in line ',& + 'Click at corners of block ',& + 'Enter number of elements in x-dir ',& + 'Enter number of elements in y-dir ',& + 'Click to move boundaries or (q)uit to terminate',& + 'Click on elements','Enter starting list number ',& + 'Enter bed elevation','Click on node ',& + 'Click location of new node','Click at node to move ',& + 'Click at node to delete ',& + 'Type 1 to use all nodes else type 0 ',& + 'Enter element to select','Click location of node',& + 'Enter SS1','Enter SS2','Enter STRWID','Enter STORAGE ELEVATION',& + 'Click mouse on node','click mouse on next node',& + 'ERROR - Midside node selected - Select node again',& + 'Plotting a selected cross section',& + 'Click two locations to form a cross section',& + 'Click to adjust the cross section',& + 'Compute cross section parameters',& + 'Click a node for the cross section',& + 'Click two locations to form the width','Click to adjust the line','Click two locations to form left slope',& + 'Click two locations to form right slope','Click a location'& + ,'Enter storage elevation','Enter storage slope',& + 'Click at two locations to determine distance'& + ,'Enter continuity line number. Use 0 to end','Click at location to define register point'& + ,'Enter 1-D cross-section bed slope','Enter element frequency for search'& + ,'Enter no. of elements to reverse '/ + + + if(irecd .eq. 2) then + read(91,'(i7)') isw + CALL INTRVL(TA,0) + 70 CALL INTRVL(TA,1) + IF(TA .LT. TSPC) GO TO 70 + return + endif + + + if(isw .eq. 0) isw=1 + call wdialogload(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogPutString(IDF_STRING1,MESS(NMESS)) + CALL WDialogPutInteger(IDF_INTEGER1,ISW) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetInteger(IDF_INTEGER1,ISW) + RETURN + ELSE + RETURN + ENDIF + ENDDO + + RETURN + END + + SUBROUTINE GETFPN(FPN) + USE WINTERACTER +! +! + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + COMMON /RECOD/ IRECD,TSPC + + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout + CHARACTER*47 MESOUT,MESS(46) + + DATA MESS /'Enter node to search for',' Enter material type',& + 'Enter element to search for ',& + 'Enter number of layers ',& + 'Enter width ',& + 'Click mouse at end of line ',& + 'Enter number of nodes in line ',& + 'Click at corners of block ',& + 'Enter number of elements in x-dir ',& + 'Enter number of elements in y-dir ',& + 'Click to move boundaries or (q)uit to terminate',& + 'Click on elements','Enter starting list number ',& + 'Enter bed elevation','Click on node ',& + 'Click location of new node','Click at node to move ',& + 'Click at node to delete ',& + 'Type 1 to use all nodes else type 0 ',& + 'Enter element to select','Click location of node',& + 'Enter SS1','Enter SS2','Enter STRWID','Enter STORAGE ELEVATION',& + 'Click mouse on node','click mouse on next node',& + 'ERROR - Midside node selected - Select node again',& + 'Plotting a selected cross section',& + 'Click two locations to form a cross section',& + 'Click to adjust the cross section',& + 'Compute cross section parameters',& + 'Click a node for the cross section',& + 'Click two locations to form the width','Click to adjust the line','Click two locations to form left slope',& + 'Click two locations to form right slope','Click a location'& + ,'Enter storage elevation','Enter storage slope',& + 'Click at two locations to determine distance'& + ,'Enter continuity line number. Use 0 to end','Click at location to define register point'& + ,'Enter 1-D cross-section bed slope','Enter time interval for display of steps'& + ,'Enter tolerance for overlapping points'/ + if(irecd .eq. 2) then + read(91,'(f7.2)') fpn + CALL INTRVL(TA,0) + 70 CALL INTRVL(TA,1) + IF(TA .LT. TSPC) GO TO 70 + return + endif + + call wdialogload(IDD_GETFPN) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETFPN) + ierr=infoerror(1) + + CALL WDialogPutString(IDF_STRING1,MESS(NMESS)) + CALL WDialogPutReal(IDF_REAL1,FPN) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetReal(IDF_REAL1,FPN) + RETURN + ELSE + RETURN + ENDIF + ENDDO + + RETURN + END + + subroutine drawcr(x,y,siz) + +! routine to draw x mark + + siz1=0.707/2.*siz + x1=x-siz1 + y1=y-siz1 + call plott(x1,y1,3) + x1=x+siz1 + y1=y+siz1 + call plott(x1,y1,2) + x1=x-siz1 + y1=y+siz1 + call plott(x1,y1,3) + x1=x+siz1 + y1=y-siz1 + call plott(x1,y1,2) + return + end + + SUBROUTINE GETREV(ISW,ILMIT) + USE WINTERACTER +! +! + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + INTEGER ISW,ILMIT + + + + call wdialogload(IDD_GETINTR) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETINTR) + ierr=infoerror(1) + + CALL WDialogPutCheckBox(IDF_check1,ILMIT) + CALL WDialogPutInteger(IDF_INTEGER1,ISW) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetCheckBox(IDF_check1,ILMIT) + CALL WDialogGetInteger(IDF_INTEGER1,ISW) + RETURN + ELSE + ISW=-1 + RETURN + ENDIF + ENDDO + + RETURN + END + \ No newline at end of file diff --git a/src/src83e/TXFRM.COM b/src/src83e/TXFRM.COM new file mode 100644 index 0000000..b564d03 --- /dev/null +++ b/src/src83e/TXFRM.COM @@ -0,0 +1,4 @@ + REAL*8 XS,YS,TXSCAL + INTEGER IRGB,IDDSW + COMMON /TXFRM/ XS, YS, TXSCAL,IRGB,IDDSW + diff --git a/src/src83e/UTIL.F90 b/src/src83e/UTIL.F90 new file mode 100644 index 0000000..bae20fb --- /dev/null +++ b/src/src83e/UTIL.F90 @@ -0,0 +1,1269 @@ +!IPK LAST UPDATE SEP 23 2015 ADD TESTING FOR CHNAGED ELEMENTS/NODES +!ipk last update Jan25 2001 fix when deleting center-mid expand ipsw +! last change ipk 12 July 1999 +! Last change: IPK 13 Jan 98 10:01 am +!ipk last update Nov 18 1997 +!ipk last updated Oct 23 1996 +!ipk last updated June 23 1996 +!ipk last updated Oct 25 1995 + SUBROUTINE GETELM(NEM) +! +! Routine to find first free element number +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + DO 200 J=NELAST,NE + IF(IMAT(J) .EQ. 0) THEN + NEM=J + NELAST=J + RETURN + ENDIF + 200 END DO + NE=NE+1 + NELAST=NE + NEM=NE + RETURN + END + +! + SUBROUTINE GETNOD(NPT) +! +! Routine to find first free node number +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + IF(NP .GT. 0) THEN + DO 200 J=NPLAST,NP + IF(INEW(J) .EQ. 0) THEN + NPT=J + NPLAST=J + RETURN + ENDIF + 200 END DO + ELSE + NP=0 + ENDIF + NP=NP+1 + NPLAST=NP + NPT=NP + IF(NPT .GT. MAXP) THEN + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,'Execution terminated, nodal limits exceeded. Backup written','LIMITS EXCEEDED') + CALL WRTOUT(0) + STOP + ENDIF +!IPK MAY03 + ICHG=0 + RETURN + END +! +!*********************************************************************** +! + SUBROUTINE DELETN(J) +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +! Search for elements that attach to node J and remove them +! + DO 200 N=1,NE + IF(IMAT(N) .GT. 0) THEN + NCN=NCORN(N) + DO 180 K=1,NCN + IF(NOP(N,K) .EQ. J) THEN +!IPK APR94 + IF(IMAT(N) .LT. 901 .OR. IMAT(N) .GT. 903) THEN + IF(MOD(K,2) .EQ. 0) THEN + IF(NCN .NE. 2) THEN + IF(NCN .NE. 5 .OR. K .EQ. 2) THEN + NOP(N,K)=0 + GO TO 200 + ENDIF +!IPK APR94 END CHANGES + ENDIF + ENDIF + ENDIF + IMAT(N)=0 + XC(N)=VOID + YC(N)=VOID + NCORN(N)=0. + IF(N .LT. NELAST) NELAST=N + DO 170 KK=1,8 + NOP(N,KK)=0 + 170 CONTINUE + IESKP(N)=1 + GO TO 200 + ENDIF + 180 CONTINUE + ENDIF + 200 END DO + + +!IPK FEB08 TEST FOR LOWERING NE + DO N=NE,1,-1 + IF(IMAT(N) .NE. 0) THEN + JJ=N + GO TO 225 + ENDIF + ENDDO + 225 NE=JJ + +! +! Remove node now +! + CORD(J,1)=VOID + CORD(J,2)=VOID + XUSR(J) = VOID + YUSR(J) = VOID + INSKP(J)=1 + INEW(J) = 0 + WD(J)=-9999. + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. + IF(NPLAST .GT. J) NPLAST=J +!IPK FEB08 TEST FOR LOWERING NE + IF(J .EQ. NP) THEN + DO N=NP,1,-1 + IF(INEW(N) .NE. 0) THEN + JJ=N + GO TO 250 + ENDIF + ENDDO + 250 NP=JJ + ENDIF + + RETURN + END +! +! +!*********************************************************************** + + function lenstr(str) +! +! Find length of string (position of last non-blank character) +! + character*(*) str + + n = len(str) + lenstr = n + do 10 i=0,n-1 + idx = n-i + if (str(idx:idx) .ne. ' ') then + lenstr = idx + return + endif + 10 continue + return + END +! +!**************************************************************** +! + subroutine prox(x,y,npts,xx,yy,ipt,iflag,inskp,ibox) +! x=array of x node locations +! y=array of y node location +! npts= max number of nodes +! xx=x screen lpcation +! yy=y screen location +! iflag=character flag +! inskp=array telling nodes to skip +! ibox=any box checked + save + CHARACTER*80 TITLE + CHARACTER*24 HLABL + CHARACTER*1 ALABL(10) + CHARACTER*40 MPDUM + COMMON /BLKA1/ TITLE,HLABL,ALABL & + & ,MPDUM +!ipk oct 95 lines defining MPDUM added +! +!ipk jan01 expand IPSW + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout +! + integer*2 inskp(*) +!IPK MAY02 + REAL*8 x(*),y(*) + character*1 iflag +! +! if(ibox .eq. 0) then +! nbx=2 +! call boxr(nbx) +! endif +! +! Get location of cursor +! + 10 call xyloc(xscrn,yscrn,iflag,ibox) +! write(90,*) 'ibox,xscrn,yscrn',ibox,xscrn,yscrn,irmain +! write(90,7893) iflag + 7893 format(' iflag',a2) +! read(*,*) junk + if(irmain .eq. 1) return + if(ibox .eq. 10) then + iflag = 'q' + return + elseif(ibox .eq. 9) then + iflag = 'r' +! elseif(ibox .eq. 7) then +! iflag = 'a' + endif +! +! + if (iflag .eq. 'q') then + return + elseif(iflag .eq. 'r') then + return + elseif(iflag .ne. 'c') then + + ibox=0 + if(iflag .eq. 't') return + if(iflag .eq. 'l') return + if(iflag .eq. 'f') return + if(iflag .eq. 'e') return + if(iflag .eq. 'a') return + if(iflag .eq. 'j') return + if(iflag .eq. 'z') return + if(iflag .eq. 'n') return + if(iflag .eq. 'g') return + if(iflag .eq. 'h') return +!ipk oct96 add line below + if(iflag .eq. 'b') return + if(iflag .eq. 'U') return +! + if(iflag .eq. 'm') go to 12 +!ipk jan98 write(*,*) char(7),char(7) + go to 10 + endif +! +! Compare to coordinates + 12 d = 1.E+20 + do 20 i=1,npts +!! write(*,*) 'i,npts',i,npts,inskp(i),x(i),y(i) + if(inskp(i) .ne. 0) go to 20 + dist = sqrt( (xscrn-x(i))**2 + (yscrn-y(i))**2) + if (dist .lt. d) then + d = dist + ipt = i + xx = x(i) + yy = y(i) + endif + 20 continue + return +! +! + END +!*********************************************************** + subroutine zoom +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! + dimension xot(5),yot(5) + character*1 iflag,ans +! +!ipk jun96 add zoomj + character*36 zoomh,zoomj,IFLAG32 + character*22 zoomi +!ipk jan98 + CHARACTER*80 lind + data zoomh/' Zooming, click at diagonal corners'/ + data zoomi/' Click left if size OK'/ +!ipk jun96 add zoomj + data zoomj/' Double click, click second point '/ +! +! + 80 CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,36) + +!jan09 xcc = 5.00 + xcc = 5.00*hsize/10. + ycc = 3.5 +! + 100 continue +! +! Get cursor location +! + CALL XYLOC(xscrn,yscrn,iflag,ibox) + IF(IRMAIN .EQ. 1) RETURN +! + if (iflag .eq. 'q') return +! + xp = xmin + xscrn + yp = ymin + yscrn + if(iflag .eq. 'c') then +! +! This option is creating an inset window +! +!ipk jun96 add new path + 120 continue + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + IF(IRMAIN .EQ. 1) RETURN + if(iflag .eq. 'c') then +! +! Look for a screen size +! + xsiz=abs(xscrn1-xscrn) + ysiz=abs(yscrn1-yscrn) +!ipk jun96 test for zero sizes + if(xsiz .lt. 0.001 .or. ysiz .lt. 0.001) then + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomj,0.,36) + go to 120 + endif + if(xscrn1 .lt. xscrn) xscrn=xscrn1 + if(yscrn1 .lt. yscrn) yscrn=yscrn1 + fact=HSIZE/xsiz +!jan09 if(7./ysiz .lt. fact) fact=7./ysiz + if(7.5/ysiz .lt. fact) fact=7.5/ysiz + xot(1)=xscrn + xot(5)=xscrn + yot(1)=yscrn + yot(5)=yscrn + yot(2)=yscrn + xot(4)=xscrn +!jan09 xscrn=xscrn+5./fact +!jan09 yscrn=yscrn+3.5/fact + xscrn=xscrn+xcc/fact + yscrn=yscrn+3.75/fact +!jan09 xot(2)=xscrn+5./fact + xot(2)=xscrn+xcc/fact + xot(3)=xot(2) +!jan09 yot(3)=yscrn+3.5/fact + yot(3)=yscrn+3.75/fact + yot(4)=yot(3) + call DASHLN(xot,yot,5,1) + xp=xscrn + yp=yscrn + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomi,0.,22) + CALL XYLOC(xscrn1,yscrn1,iflag,ibox) + IF(IRMAIN .EQ. 1) RETURN + if(iflag .ne. 'c') go to 80 + go to 280 +! +! pan right +! + else if(iflag .eq. 'r') then + fact=1.0 +!jan09 xscrn=xscrn+5.0 + xscrn=xscrn+hsize/2. + xp=xscrn + yp=yscrn +! +! pan left +! + else if(iflag .eq. 'l') then + fact=1.0 +!jan09 xscrn=xscrn-5.0 + xscrn=xscrn-hsize/2. + xp=xscrn + yp=yscrn + endif +! +! redraw at half size +! + elseif(iflag .eq. 'r') then + fact = 0.500 +! +! user controlled redraw +! + else + call setd(23) + write (*,*) ' factor ' + read(*,*) fact + call setd(2) + endif + do 250 i=1,np + if(cord(i,1) .gt. void) then + inskp(i)=0 + endif + 250 continue + do 270 i=1,ne + if(imat(i) .gt. 0) then + ieskp(i)=0 + endif + 270 continue + 280 continue + pscale = pscale/fact + xmino=xmin + ymino=ymin +! + xmin = xp - (xcc*pscale) + ymin = yp - (ycc*pscale) +! + if(iflag .eq. 'c') then +! CALL PLOTS(0) +!ipk nov97 add (0) + CALL PLOTOT(0) + return + elseif(iflag .eq. 'r') then +! CALL PLOTS(0) +!ipk nov97 add (0) + CALL PLOTOT(0) + return + elseif(iflag .eq. 'l') then +! CALL PLOTS(0) +!ipk nov97 add (0) + CALL PLOTOT(0) + return + endif + call setd(23) + write(lind,*) 'Illegal zoom press return to continue' + call symbl & + & (1.1,7.1,0.20,LIND,0.0,80) + ndig=1 + CALL GTCHARX(IFLAG32,NDIG,5.0,7.6) +!ipk jan98 write(*,*) 'O.K. to plot at this scale? (y)es .or. (n)o' +!ipk jan98 write(*,*) 'Note n means redraw old plot' +!ipk jan98 read(*,'(a)') ans +!ipk jan98 call setd(2) +!ipk jan98 if (ans .eq. 'y') then +! CALL PLOTS(0) +!ipk nov97 add (0) + CALL PLOTOT(0) + return +!ipk jan98 endif + pscale = pscale * fact + xmin=xmino + ymin=ymino +! CALL PLOTS(0) +!ipk nov97 add (0) + CALL PLOTOT(0) + return + END +!*********************************************************** + SUBROUTINE DELETM(ISW) +! + USE BLK1MOD + + INCLUDE 'BFILES.I90' +! INCLUDE 'BLK1.COM' +! +! COMMON /ICN1/ ICN(MAXP) + DIST(N1,N2)=SQRT((CORD(N1,1)-CORD(N2,1))**2 & + & +(CORD(N1,2)-CORD(N2,2))**2) + DO 150 J=1,MAXP + ICN(J)=0 + 150 END DO + IF(ISW .EQ. 2) GO TO 650 +! First sort out the potential midsides +! Note that transition elements caues a problem +! Find these first + IRDONE=0 + DO 200 N=1,NE + IF(NCORN(N) .EQ. 5 .AND. IMAT(N) .LT. 901) THEN +! +! We have a transition mark node number as if it were corner +! + ICN(NOP(N,3))=1 + ICN(NOP(N,1))=2 + ICN(NOP(N,4))=2 + ICN(NOP(N,5))=2 + ELSE + if(imat(n) .eq. 0) then + ncorn(n)=0 + go to 200 + endif +! +! Store ICN = 2 for corner nodes +! + NCN=NCORN(N) +!IPKOCT93 IF(IMAT(N) .GT. 900) THEN + IF(IMAT(N) .GT. 900 .AND. IMAT(N) .LT. 904) THEN + MST=1 + ELSE + MST=2 + ENDIF + DO 180 M=1,NCN,MST + ICN(NOP(N,M))=2 + 180 CONTINUE + ENDIF + 200 END DO +! +! test ISW +! if isw=0 then delete all midsides except at transition +! if isw=1 then delete only midsides that are truely in the middle +! + IF(ISW .EQ. 0) THEN + DO 400 N=1,NE +!IPKOCT93 IF(IMAT(N) .LT. 901) THEN + IF(IMAT(N) .LT. 901 .OR. IMAT(N) .GT. 903) THEN + IF(NCORN(N) .EQ. 5) THEN + NCN=3 + ELSE + NCN=NCORN(N) + ENDIF + + DO 350 M=2,NCN,2 + J=NOP(N,M) +!SEP93 IPK + IF(J .EQ. 0) GO TO 350 +!SEP93 IPK + IF(ICN(J) .NE. 1) THEN + NOP(N,M)=0 + IF(ICN(J) .EQ. 0) THEN +! +! Remove node now +! + CORD(J,1)=VOID + CORD(J,2)=VOID + XUSR(J) = VOID + YUSR(J) = VOID + INSKP(J)=1 + INEW(J) = 0 + WD(J)=-9999. + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. +!IPK MAY03 + ICHG=0 + IF(NPLAST .GT. J) NPLAST=J + ENDIF + ENDIF + 350 CONTINUE + ENDIF + 400 CONTINUE + ELSE + DO 600 N=1,NE + IF(IMAT(N) .LT. 901) THEN + IF(NCORN(N) .EQ. 5) THEN + NCN=3 + ELSE + NCN=NCORN(N) + ENDIF + DO 550 M=2,NCN,2 + J1=M-1 + IF(M .EQ. NCN) THEN + J2=1 + ELSE + J2=M+1 + ENDIF + J=NOP(N,M) +!ipk jul99 + if(j .gt. 0) then +!ipk jan01 + IF(INEW(J) .EQ. 0 .or. inew(j) .eq. 2) THEN + inew(j)=0 + NOP(N,M)=0 + GO TO 550 + ENDIF + else + go to 550 + endif + ! +! Test for distance separation of midside node +! + XMID=(CORD(NOP(N,J1),1)+CORD(NOP(N,J2),1))/2. + YMID=(CORD(NOP(N,J1),2)+CORD(NOP(N,J2),2))/2. + DM=SQRT((XMID-CORD(J,1))**2+(YMID-CORD(J,2))**2) + DL=DIST(J1,J2) + IF(DM .LT. 0.005*DL) THEN + IF(ICN(J) .NE. 1) THEN + NOP(N,M)=0 + IF(ICN(J) .EQ. 0) THEN +! +! Remove node now +! + CORD(J,1)=VOID + CORD(J,2)=VOID + XUSR(J) = VOID + YUSR(J) = VOID + INSKP(J)=1 + INEW(J) = 0 + WD(J)=-9999. + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. +!IPK MAY03 + ICHG=0 + IF(NPLAST .GT. J) NPLAST=J + ENDIF + ENDIF + ENDIF + 550 CONTINUE + ENDIF + 600 CONTINUE + ENDIF +!IPK FEB08 RESET NP + + DO J=NP,1,-1 + IF(INEW(J) .NE. 0) THEN + JJ=J + GO TO 625 + ENDIF + ENDDO + 625 CONTINUE + NP=JJ + + RETURN +!- +!-.....FIND MISSING NODE NUMBERS..... +!- + 650 CONTINUE + DO 700 I=1,MAXP + 700 ICN(I) = 0 + DO 725 J = 1, NE + IF( IMAT(J) .EQ. 0 ) GO TO 725 + DO 720 K = 1, 8 + IF( NOP(J,K) .LE. 0) GOTO 720 + ICN(NOP(J,K))=999 + 720 CONTINUE + 725 END DO +! +! Remove nodes +! + DO 800 J=1,NP + IF(ICN(J) .EQ. 0) THEN + CORD(J,1)=VOID + CORD(J,2)=VOID + XUSR(J) = VOID + YUSR(J) = VOID + INSKP(J)=1 + INEW(J) = 0 + WD(J)=-9999. + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. + IF(NPLAST .GT. J) NPLAST=J + !IPK MAY03 + ICHG=0 + ENDIF + 800 END DO + +!IPK FEB08 RESET NP + + DO J=NP,1,-1 + IF(INEW(J) .NE. 0) THEN + JJ=J + GO TO 900 + ENDIF + ENDDO + 900 CONTINUE + NP=JJ + RETURN + END +!**************************************************************** +! + subroutine prox2(x,y,npts,xx,yy,ipt,xx2,yy2,ipt2,iflag,inskp,ibox) + save + CHARACTER*80 TITLE + CHARACTER*24 HLABL + CHARACTER*1 ALABL(10) + CHARACTER*40 MPDUM + COMMON /BLKA1/ TITLE,HLABL,ALABL ,MPDUM +!ipk oct 95 lines defining MPDUM added +! +!ipk jan01 expand IPSW + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout +! + integer*2 inskp(*) +!IPK MAY02 + REAL*8 x(*),y(*) + character*1 iflag +! +! if(ibox .eq. 0) then +! nbx=2 +! call boxr(nbx) +! endif +! +! Get location of cursor +! + 10 call xyloc(xscrn,yscrn,iflag,ibox) + if(irmain .eq. 1) return + if(ibox .eq. 10) then + iflag = 'q' + return + elseif(ibox .eq. 9) then + iflag = 'r' + endif +! +! + if (iflag .eq. 'q') then + return + elseif(iflag .eq. 'r') then + return + elseif(iflag .ne. 'c') then + ibox=0 + if(iflag .eq. 't') return + if(iflag .eq. 'l') return + if(iflag .eq. 'f') return + if(iflag .eq. 'e') return + if(iflag .eq. 'a') return + if(iflag .eq. 'j') return + if(iflag .eq. 'z') return + if(iflag .eq. 'n') return + if(iflag .eq. 'g') return + if(iflag .eq. 'h') return +! + if(iflag .eq. 'm') go to 12 +!ipk jan98 write(*,*) char(7),char(7) + go to 10 + endif +! +! Compare to coordinates +! + ipt2=0 + 12 d = 1.E+20 + do 20 i=1,npts + if(inskp(i) .ne. 0) go to 20 + dist = sqrt( (xscrn-x(i))**2 + (yscrn-y(i))**2) + if (dist .lt. d) then + if(i .ne. ipt) then + xx2=x(i) + yy2=y(i) + ipt2=i + d = dist + go to 20 + endif + endif + 20 continue + return +! + END + SUBROUTINE CVF(FPN,IDEC,NUMSTR,NUMC) +! +! Routine to convert number to array and prepare for plotting +! + CHARACTER*36 NUMSTR + CHARACTER*36 FMT,FMT1 + + IF(FPN .NE. 0.) THEN + if(idec .eq. 1) then + NDIG = ALOG10(ABS(FPN)+0.05) + elseif(idec .eq. 2) then + NDIG = ALOG10(ABS(FPN)+0.005) + elseif(idec .eq. 3) then + NDIG = ALOG10(ABS(FPN)+0.0005) + else + NDIG = ALOG10(ABS(FPN)+0.50005) + endif + ELSE + NDIG = 0 + ENDIF +! +! Check for Numbers than 10 +! + IF(NDIG .LE. 0) THEN +! +! Check for negative numbers +! + IF(FPN .LT. 0.) THEN +! +! Check for integer plot +! + IF(IDEC .LT. 0) THEN + NUMC = 2 + IF(FPN .EQ. 0) NUMC=1 + ELSE +! +! This is a negative number less than 10 +! + NUMC = IDEC+3 + ENDIF +! +! Check for integer plot probably a zero +! + ELSEIF(IDEC .LT. 0) THEN + NUMC = 1 + ELSE +! +! This is a positive number less than 1 +! + NUMC = IDEC+2 + ENDIF +! +! Now check numbers of magnitude greater than 1 +! + ELSEIF(FPN .LT. 0.) THEN +! +! Check for integer plot. A negative number +! + IF(IDEC .LT. 0) THEN + NUMC = NDIG+2 + ELSE +! +! This is a negative number smaller than -1. +! + NUMC = IDEC+NDIG+3 + ENDIF + +! +! Check for integer plot. A positive number +! + ELSEIF(IDEC .LT. 0) THEN + NUMC = NDIG+1 + ELSE +! +! This is a positive number greater than 1. +! + NUMC = IDEC+NDIG+2 + ENDIF + IF(IDEC .LT. 0) THEN + IF(FPN .LT. 0.) THEN + NUM = FPN-0.5 + ELSE + NUM = FPN+0.5 + ENDIF + WRITE(FMT,97) NUMC + WRITE(NUMSTR,FMT) NUM + 97 FORMAT('(I',i1,')') + ELSE +!ipk mar95 fix bug that causes error when IDEC >12 + if(idec .gt. 9) then + write(fmt1,99) numc,idec + 99 format('(F',i2,'.',i2,')') + else + WRITE(FMT1,98) NUMC,IDEC + 98 FORMAT('(F',i2,'.',i1,')') + endif + WRITE(NUMSTR,FMT1) FPN + ENDIF + RETURN + END +!ipk oct96 routines below added + + SUBROUTINE GTCHARX(DATA,NDIG,XLC,YLC) + COMMON /RECOD/ IRECD,TSPC + + CHARACTER*32 DATA + if(irecd .eq. 2) then + read(91,'(A32)') DATA + CALL INTRVL(TA,0) + 70 CALL INTRVL(TA,1) + IF(TA .LT. TSPC) GO TO 70 + return + endif + + 80 CONTINUE + DO 90 I=1,NDIG + DATA(I:I)=' ' + 90 END DO +! + I = 1 + 10 CONTINUE + I = I+1 + call keybrd(key) + IF (KEY .EQ. 8) THEN + I = I-2 + xp=XLC+(i+1)*0.20 + call drblk(xp,YLC+0.23,0.20,0.30,-11) + GO TO 10 + ENDIF + IF(KEY .EQ. 13 .OR. I .EQ. ndig+2) GO TO 200 + if(key .eq. 1072 .or. key .eq. 1075 .or. key .eq. 1077 .or.& + & key .eq. 1080) go to 200 + DATA(I-1:I-1)=CHAR(KEY) + xp=XLC+i*0.20 + call drblk(xp,YLC+0.23,0.20,0.30,-11) + call rblue + call symbl(xp,YLC,0.20,data(i-1:i-1),0.0,1) + 100 CONTINUE + GO TO 10 + 200 CONTINUE + NDIG=I-2 + call rblue + RETURN +!ipk mar94 add + END + SUBROUTINE DRBLK(XS,YS,XL,YL,ICOL) + DIMENSION X(4),Y(4) + X(1)=XS + X(2)=XS + X(3)=XS+XL + X(4)=XS+XL + Y(1)=YS + Y(2)=YS-YL + Y(3)=Y(2) + Y(4)=YS +! WRITE(90,*) 'GOING TO POLYFL',X,Y,ICOL + CALL POLYFL(X,Y,4,ICOL) + call rblue + RETURN + END + SUBROUTINE GTFPNX(FPN,NDEC,NDIG,XLC,YLC) + CHARACTER*11 DATA + CHARACTER*30 MES + + REAL HSIZE + COMMON /SSIZE/ HSIZE + + DATA MES/'Error reading number, Reenter.'/ + 80 CONTINUE + DO 90 I=1,11 + DATA(I:I)=' ' + 90 END DO +! + I = 1 + NDEC=-2 + 10 CONTINUE + I = I+1 + call keybrd(key) +! WRITE(90,*) 'BACK FROMKEYBRD',KEY,I + IF (KEY .EQ. 8) THEN + I = I-2 + xp=xlc+(i+1)*0.20 + call drblk(xp,ylc+0.23,0.20,0.30,13) + GO TO 10 + ENDIF + IF(KEY .EQ. 46) THEN + NDEC=-1 + ENDIF + IF(KEY .EQ. 13) GO TO 200 + if(key .eq. 1072 .or. key .eq. 1075 .or. key .eq. 1077 .or.& + & key .eq. 1080) go to 200 + IF(NDEC .GE. -1) NDEC=NDEC+1 + DATA(I:I)=CHAR(KEY) +! WRITE(90,'(A)') ' GETTING CHAR',DATA(I:I) + xp=xlc+i*0.20 +! WRITE(90,*) 'GOING TO DRBLK',XP,YLC + call drblk(xp,ylc+0.23,0.20,0.30,-11) +! WRITE(90,*) 'BACK FROM DRBLK' + call rblue + call symbl(xp,ylc,0.20,data(i:i),0.0,1) + 100 CONTINUE + GO TO 10 + 200 CONTINUE + NDIG=I-2 + READ(DATA,5000,ERR=300) FPN + 5000 FORMAT(1X,F10.0) + call rblue + RETURN + 300 CONTINUE + CALL SYMBL(3.0,1.73,0.20,MES,0.0,30) + GO TO 80 + END + SUBROUTINE GTINTX(INUM,NDIG,XLC,YLC) + CHARACTER*11 DATA + CHARACTER*30 MES + DATA MES/'Error reading integer, Reenter'/ + 80 CONTINUE + DO 90 I=1,11 + DATA(I:I)=' ' + 90 END DO +! + I = 1 + 10 CONTINUE + I = I+1 + call keybrd(key) + IF (KEY .EQ. 8) THEN + I = I-2 + xp=xlc+(i+1)*0.20 + call drblk(xp,ylc+0.00,0.20,0.32,-11) + GO TO 10 + ENDIF + IF(KEY .EQ. 13) GO TO 200 + if(key .eq. 1072 .or. key .eq. 1075 .or. key .eq. 1077 .or.& + & key .eq. 1080) go to 200 + DATA(I:I)=CHAR(KEY) + xp=xlc+i*0.20 + call drblk(xp,ylc+0.00,0.20,0.32,-11) + call rblue + call symbl(xp,ylc-0.20,0.20,data(i:i),0.0,1) + 100 CONTINUE + GO TO 10 + 200 CONTINUE + NDIG=I-2 + READ(DATA,5000,ERR=300) INUM + 5000 FORMAT(1X,I10) + call rblue + RETURN + 300 CONTINUE + CALL SYMBL(3.0,1.73,0.20,MES,0.0,30) + GO TO 80 + END + SUBROUTINE WRTBOX(IDELV) + dimension x(5),y(5) + CHARACTER*6 label + COMMON /SSIZE/ HSIZE + DATA label/'(e)lsw'/ +! +! Draw box around selections with colour +! + Y(1)=7.5 + Y(2)=7.5 + Y(3)=7.995 + Y(4)=7.995 + Y(5)=7.5 + X(1)=6.0*HSIZE/10. + X(2)=7.0*HSIZE/10. + X(3)=7.0*HSIZE/10. + X(4)=6.0*HSIZE/10. + X(5)=6.0*HSIZE/10. + IF(IDELV .EQ. 1) THEN + IBLK=12 + ELSE + IBLK= 8 + ENDIF + CALL POLYFL(X,Y,5,IBLK) + CALL RBLACK + CALL PLOTT(X(1),Y(1),3) + CALL PLOTT(X(2),Y(2),2) + CALL PLOTT(X(3),Y(3),2) + CALL PLOTT(X(4),Y(4),2) + CALL PLOTT(X(1),Y(1),2) + call symbl(6.02*hsize/10.,7.6,0.20,label,0.0,6) + RETURN + END + + SUBROUTINE UNDOACT + + USE BLK1MOD +! INCLUDE '!BLK1.COM' + +! IF(NEUNDO .GT. 0) THEN +! DO N=1,NEUNDO +! J=IELDEL(N) +! CALL DELTEL(J) +! ENDDO +! ELSE +! RETURN +! ENDIF + IF(NPUNDO .GT. 0) THEN + DO N=1,NPUNDO + J=NODDEL(N) + if(j .gt. 0) CALL DELETN(J) + ENDDO + ENDIF + NPUNDO=0 + NEUNDO=0 + WRITE(90,*) 'NESAV,NEFSAV',NESAV,NEFSAV,NE,NENTRY + IF(NESAV .GT. 0) THEN + DO J=1,NESAV + DO K=1,8 + NOP(J,K)=NOPSV(J,K) + ENDDO + NCN = 2 + IF (NOP(J,3) .NE. 0) NCN = 3 + IF (NOP(J,4) .NE. 0) NCN = 4 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .NE. 0) NCN = 5 + IF (NOP(J,5) .NE. 0 .AND. NOP(J,4) .EQ. 0) NCN = 6 + IF (NOP(J,6) .NE. 0) NCN = 6 + IF (NOP(J,7) .NE. 0) NCN = 8 + NCORN(J) = NCN + IESKP(J) = 0 + IMAT(J)=IMATSV(J) + ENDDO + NE=NESAV + ENDIF + NESAV=0 + IF(NENTRY .GT. NEFSAV) THEN + IF(NEFSAV .GT. 0) THEN + DO N=1,NEFSAV + DO M=1,3 + NEF(N,M)=NEFSV(N,M) + ENDDO + ENDDO + ENDIF + NENTRY=NEFSAV + ENDIF + NEFSAV=NENTRY + CALL PLOTOT(-1) + CALL HEDR + RETURN + END + + SUBROUTINE GETXC + + USE BLK1MOD + + DO J=1,NE + XXC=0. + YYC=0. + IF(IMAT(J) .EQ. 0) GO TO 50 + NCN = NCORN(J) + IF(NCN .EQ. 9) THEN + NCNR=8 + ELSE + NCNR=NCN + ENDIF + DO 25 K=1,NCNR + N = NOP(J,K) +! + IF (N .EQ. 0) GO TO 25 + IF (CORD(N,1) .LT. VDX) GOTO 25 +! ! + IF (NCN .NE. 5 .OR. K .LT. 5) THEN + IF (MOD(K,2) .EQ. 1) THEN + XXC = XXC + CORD(N,1) + YYC = YYC + CORD(N,2) + ENDIF + ENDIF + 25 END DO + + IF(NCN .LT. 9) THEN + XC(J) = 2.*XXC/NCN + YC(J) = 2.*YYC/NCN + ELSE + XC(J)= CORD(NOP(J,9),1) + YC(J)= CORD(NOP(J,9),2) + ENDIF + 50 CONTINUE + ENDDO + RETURN + END + + SUBROUTINE DELETEM + USE WINTERACTER + USE BLK1MOD + SAVE + +! implicit none + + include 'd.inc' + + INCLUDE 'TXFRM.COM' + + INCLUDE 'BFILES.I90' + + CHARACTER*1 IFLAG + CHARACTER*24 MESSAG + INTEGER NTYPR,ITIMETHRU + DATA MESSAG/'GET ELEMENT TYPE NUMBER '/ + + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + call wdialogload(IDD_GETINT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_GETINT) + ierr=infoerror(1) + NFD=0 + CALL WDialogPutString(IDF_STRING1,MESSAG) + CALL WDialogPutInteger(IDF_INTEGER1,NFD) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) +! Branch depending on type of message. +! + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetInteger(IDF_INTEGER1,NFD) + GO TO 200 + ENDIF + ENDDO +200 CONTINUE + IF(NFD .EQ. 0) RETURN +! ASK FOR ELEMENT NUMBER +! LOOP ON ELEMENTS DROPPING ELEMENTS OF GIVEN TYPE + DO N=1,NE + IF(IMAT(N) .EQ. NFD) THEN + DO K=1,8 + NOP(N,K)=0 + ENDDO + IMAT(N)=0 + NCORN(N)=0 + ENDIF + ENDDO + RETURN + END + +! +!**************************************************************** +! + subroutine proxel(x,y,npts,xx,yy,ipt,iflag,inskp,ibox,neac) +! x=array of x node locations +! y=array of y node location +! npts= max number of nodes +! xx=x screen lpcation +! yy=y screen location +! iflag=character flag +! inskp=array telling nodes to skip +! ibox=any box checked + save + CHARACTER*80 TITLE + CHARACTER*24 HLABL + CHARACTER*1 ALABL(10) + CHARACTER*40 MPDUM + COMMON /BLKA1/ TITLE,HLABL,ALABL & + & ,MPDUM +!ipk oct 95 lines defining MPDUM added +! +!ipk jan01 expand IPSW + COMMON /HEDS/ NP,NE,NHTP,NMESS,NBRR,IPSW(15),IRMAIN,ISCRN,icolon(12),IQSW(2),IRDISP,ntempin,igfgsw,igfgswb,ICRIN,IPW1,WIDEL,WIDSCL,itrianout +! + integer*2 inskp(*) + INTEGER neac(*) +!IPK MAY02 + REAL*8 x(*),y(*) + character*1 iflag +! +! if(ibox .eq. 0) then +! nbx=2 +! call boxr(nbx) +! endif +! +! Get location of cursor +! + 10 call xyloc(xscrn,yscrn,iflag,ibox) +! write(90,*) 'ibox,xscrn,yscrn',ibox,xscrn,yscrn,irmain +! write(90,7893) iflag + 7893 format(' iflag',a2) +! read(*,*) junk + if(irmain .eq. 1) return + if(ibox .eq. 10) then + iflag = 'q' + return + elseif(ibox .eq. 9) then + iflag = 'r' +! elseif(ibox .eq. 7) then +! iflag = 'a' + endif +! +! + if (iflag .eq. 'q') then + return + elseif(iflag .eq. 'r') then + return + elseif(iflag .ne. 'c') then + + ibox=0 + if(iflag .eq. 't') return + if(iflag .eq. 'l') return + if(iflag .eq. 'f') return + if(iflag .eq. 'e') return + if(iflag .eq. 'a') return + if(iflag .eq. 'j') return + if(iflag .eq. 'z') return + if(iflag .eq. 'n') return + if(iflag .eq. 'g') return + if(iflag .eq. 'h') return +!ipk oct96 add line below + if(iflag .eq. 'b') return + if(iflag .eq. 'U') return +! + if(iflag .eq. 'm') go to 12 +!ipk jan98 write(*,*) char(7),char(7) + go to 10 + endif +! +! Compare to coordinates + 12 d = 1.E+20 + do ii=1,8 + i=neac(ii) + if(neac(ii) .eq. 0) cycle +!! write(*,*) 'i,npts',i,npts,inskp(i),x(i),y(i) + if(inskp(i) .ne. 0) cycle + dist = sqrt( (xscrn-x(i))**2 + (yscrn-y(i))**2) + if (dist .lt. d) then + d = dist + ipt = i + xx = x(i) + yy = y(i) + endif + enddo + return +! +! + END + \ No newline at end of file diff --git a/src/src83e/WINNEW.F90 b/src/src83e/WINNEW.F90 new file mode 100644 index 0000000..4b6ec46 --- /dev/null +++ b/src/src83e/WINNEW.F90 @@ -0,0 +1,729 @@ +!IPK LAST UPDATE SEP 23 2015 REVISE org NUMBERS + SUBROUTINE get_label(dlin,title) + + use winteracter + + implicit none + + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: ITYPE,ierr + + character*40 dlin,title + write(90,'(a)') 'dlin',dlin + write(90,'(a)') 'lind',title + + call wdialogload(IDD_DIALOG1) + ierr=infoerror(1) + + write(90,'(a)') 'dlin-0',dlin + write(90,'(a)') 'lind-0',title + CALL WDialogPutString(idf_label5,dlin) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG1) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + + + do +!! CALL WMessage(ITYPE,MESSAGE) +! +! Branch depending on type of message. +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetstring(idf_string24,title) + write(90,'(a)') 'dlin-1',dlin + write(90,'(a)') 'lind-1',title + return + endif + return + enddo + + return + + end + +! ---------------------------------------------------------------------------- + + subroutine labl(x,y,llen,ht,string) + USE WINTERACTER + character*(*) string + integer llen + character*80 outstring + data rsclx,rscly/100.,100./ + DO i=1,llen + outstring(i:i)=string(i:i) + ENDDO + + ix=x*rsclx + iy=y*rscly + CALL gim_a_string(ix,iy,ht,outstring,llen) + RETURN + end + + SUBROUTINE gim_a_string(ix,iy,ht,outstring,lenth) + USE WINTERACTER + CHARACTER*(*) OUTSTRING + CALL WGrTextFont(102,0,ht*0.0133333,ht*0.04) +! CALL IGrCharSet(' ') +! CALL IGrCharSize(ht,ht) + call WGrTextOrientation(0) +! CALL IGrCharJustify('L') + x=ix/100. + y=iy/100. + CALL WGrTextString(x,y,outstring(:lenth)) + +! CALL IGrCharOut(x,y,outstring(:lenth)) + RETURN + END SUBROUTINE + + SUBROUTINE change_color(icl) + USE WINTERACTER + DIMENSION ICOLRS(0:16) + + data icolrs/224,0,160,175,159,112,128,96,80,& + 48,63,24,16,47,223,7,224/ +! 240 + ICV=ICOLRS(mod(ICL,16)) + CALL IGrcolourN(ICV) + RETURN + END SUBROUTINE + + SUBROUTINE fill_a_polygon(x,y,npts) + USE WINTERACTER + dimension x(*),y(*) + CALL IGrFillPattern(4,0,0) + call IGrPolygonComplex(x,y,npts) + RETURN + END SUBROUTINE + + SUBROUTINE gim_a_charac(key,cha,x,y) + USE WINTERACTER + CHARACTER*(*) cha + INTEGER :: ITYPE, KEY + INTEGER, PARAMETER :: ID_EXIT = 40002 + + TYPE(WIN_MESSAGE) :: MESSAGE + + 100 CONTINUE + + CALL WMessage(ITYPE, MESSAGE) + SELECT CASE (ITYPE) + CASE (KeyDown) ! Key pressed + KEY = MESSAGE%VALUE1 + MOUSEX = MESSAGE%X + MOUSEY = MESSAGE%Y + +! check key status + if(KEY .lt. 127) then + cha=char(KEY) + go to 250 + else + go to 100 + endif + CASE (MenuSelect) ! Menu item selected + SELECT CASE (MESSAGE%VALUE1) + CASE (ID_EXIT) + call WindowClose + END SELECT + END SELECT + GO TO 100 + 250 CONTINUE + RETURN + END SUBROUTINE + + SUBROUTINE clear_screen + USE WINTERACTER + INCLUDE 'TXFRM.COM' + TYPE (WIN_FONT) :: FONT +! FONT%IBCOL = TextWhite +! CALL WindowFont(FONT) +! IRGB = WRGB(220,220,220) + CALL WindowClear(rgb=irgb) ! clear to yellow + RETURN + END SUBROUTINE + + SUBROUTINE gim_a_line(ix,iy) + USE WINTERACTER + x=ix/100. + y=iy/100. + CALL IGrLineto(x,y) + RETURN + END SUBROUTINE + + SUBROUTINE move_da_pointer(ix, iy) + USE WINTERACTER + x=ix/100. + y=iy/100. + CALL IGrMoveto(x,y) + RETURN + END SUBROUTINE + + SUBROUTINE clear_box + USE WINTERACTER + + REAL HSIZE + COMMON /SSIZE/ HSIZE + + dimension x(4),y(4) + x(1)=0. + x(2)=HSIZE + x(3)=HSIZE + x(4)=0. + y(1)=7.50 + y(2)=7.50 + y(3)=8.0 + y(4)=8.0 + + call Rwhite + + call IGrColourN(48) + + CALL IGrFillPattern(4,0,0) + + call IGrPolygonComplex(x,y,4) + + call RBlue + + return + END SUBROUTINE + + SUBROUTINE get_rid_window + USE WINTERACTER + call WindowClose + RETURN + END SUBROUTINE + + SUBROUTINE flush_screen + RETURN + END SUBROUTINE + + SUBROUTINE RMINFO + + use winteracter + + implicit none + + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + LOGICAL :: OPENED + INTEGER :: IERR + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + + call wdialogload(IDD_DIALOG09) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG09) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + return + endif + return + enddo + + RETURN + END SUBROUTINE + + SUBROUTINE GETMDIS(nmapf,nsigf,icolsw,rad,colint) + + use winteracter + + implicit none + + include 'd.inc' + CHARACTER(LEN=255) :: FNAME + CHARACTER(LEN=3) :: SUB + LOGICAL :: OPENED + INTEGER :: IERR,NMAPF,NSIGF,icolsw + REAL :: RAD,COLINT + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + + call wdialogload(IDD_DIALOG10) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_DIALOG10) + ierr=infoerror(1) + + CALL WDialogPutINTEGER(IDF_INTEGER1,nsigf) + + CALL WDialogPutINTEGER(IDF_INTEGER2,nmapf) + + CALL WDialogPutReal(IDF_REAL1,rad) + + CALL WDialogPutReal(IDF_REAL2,colint) + + call wdialogputcheckbox(idf_check1,icolsw) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + CALL WDialogGetINTEGER(IDF_INTEGER1,nsigf) + + CALL WDialogGetINTEGER(IDF_INTEGER2,nmapf) + + call wdialogGetcheckbox(idf_check1,icolsw) + + CALL WDialogGetReal(IDF_REAL1,rad) + + CALL WDialogGetReal(IDF_REAL2,colint) + + return + endif + return + enddo + + RETURN + END SUBROUTINE + + SUBROUTINE THICKL + CALL IGrLineWidth(2,2,2) + RETURN + END + + SUBROUTINE THINL + CALL IGrLineWidth(1,1,1) + RETURN + END + + SUBROUTINE OUTORG(FNAME) + + CHARACTER(LEN=255) :: FNAME + + INCLUDE 'TXFRM.COM' + + REAL HSIZE + COMMON /SSIZE/ HSIZE + +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + OPEN(104,FILE=FNAME,STATUS ='UNKNOWN', FORM ='FORMATTED') +!!! WRITE(104,'(4G16.8)') -XS,-YS,HSIZE*TXSCAL-XS,7.5*TXSCAL-YS + WRITE(104,'(4G16.8)') -XS,-YS,HSIZE*TXSCAL-XS,8.0*TXSCAL-YS + CLOSE(104) + RETURN + END + + SUBROUTINE DRAWBK(I,IMZ) + + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + INCLUDE 'BFILES.I90' + + REAL HSIZE + COMMON /SSIZE/ HSIZE + + IF(IMZ .EQ. -1) THEN + VRANGE=7.5 + ELSE + VRANGE=8.0 + ENDIF + XBKMN=((BFMINMAX(I,1)+XS)/TXSCAL)/HSIZE + XBKMX=((BFMINMAX(I,3)+XS)/TXSCAL)/HSIZE + YBKMN=((BFMINMAX(I,2)+YS)/TXSCAL)/VRANGE + YBKMX=((BFMINMAX(I,4)+YS)/TXSCAL)/VRANGE +! WRITE(90,*) 'BACKGND',XBKMN,XBKMX,YBKMN,YHSIZEBKMX + IF(XBKMN .GT. 1.) RETURN + IF(XBKMX .LT. 0.) RETURN + IF(YBKMN .GT. 1.) RETURN + IF(YBKMX .LT. 0.) RETURN + XRANGE=XBKMX-XBKMN + YRANGE=YBKMX-YBKMN + IF(XBKMX .GT. 1.) THEN + XGRMX=(1.-XBKMN)/XRANGE + XBKMX=1.0 + ELSE + XGRMX=1. + ENDIF + IF(XBKMN .LT. 0.) THEN + XGRMN=-XBKMN/XRANGE + XBKMN=0. + ELSE + XGRMN=0. + ENDIF + IF(YBKMX .GT. 1.) THEN + YGRMX=(1.-YBKMN)/YRANGE + YBKMX=1.0 + ELSE + YGRMX=1. + ENDIF + IF(YBKMN .LT. 0.) THEN + YGRMN=-YBKMN/YRANGE + YBKMN=0. + ELSE + YGRMN=0. + ENDIF +! WRITE(90,*) 'BACKGN2',XBKMN,XBKMX,YBKMN,YBKMX +! WRITE(90,*) 'XGR ',XGRMN,YGRMN,XGRMX,YGRMX + CALL IGrArea(XBKMN,YBKMN,XBKMX,YBKMX) + CALL IGrReplayArea(XGRMN,YGRMN,XGRMX,YGRMX) + call IGrReplay(BFNAME(I)) + CALL IGrArea(0.0,0.0,1.0,1.0) + RETURN + END + + SUBROUTINE DRAWBKBM(I,IMZ) + + USE WINTERACTER + + REAL HSIZE + COMMON /SSIZE/ HSIZE + + CHARACTER*1 IFLAG + INTEGER, DIMENSION(6) :: INFO + + INCLUDE 'TXFRM.COM' +!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL + + INCLUDE 'BFILES.I90' +! DATA IHAND1,IHAND2/0,0/ + INTEGER :: iw,ih,ihandle,ient,IHAND1,IHAND2,IXPM,IYPX,IXPX,IYPM + common /hands/ ihandle,IHAND1,IHAND2,IXPM,IYPX,IXPX,IYPM + + XBKMN=((BFMINMAX(I,1)+XS)/TXSCAL) + XBKMX=((BFMINMAX(I,3)+XS)/TXSCAL) + YBKMN=((BFMINMAX(I,2)+YS)/TXSCAL) + YBKMX=((BFMINMAX(I,4)+YS)/TXSCAL) +! WRITE(90,*) 'BACKGND-cm',XBKMN,XBKMX,YBKMN,YBKMX + CALL IGrUnitsToPixels(0.,0.,IXPM,IYPM) + CALL IGrUnitsToPixels(HSIZE,8.0,IXPXC,IYPXC) +! WRITE(90,*) 'PIXELS',IXPM,IYPXC-IYPXC,IXPXC,IYPXC-IYPM + CALL IGrUnitsToPixels(XBKMN,YBKMN,IXPM,IYPM) + CALL IGrUnitsToPixels(XBKMX,YBKMX,IXPX,IYPX) + IYPX=IYPXC-IYPX + IYPM=IYPXC-IYPM +! WRITE(90,*) 'PIXELS',IXPM,IYPX,IXPX,IYPM,IXPXC,IYPXC + IF(XBKMN .GT. HSIZE) RETURN + IF(XBKMX .LT. 0.) RETURN + IF(YBKMN .GT. 8.) RETURN + IF(YBKMX .LT. 0.) RETURN + CALL IGrFileInfo(BFNAME(I),INFO,6) +! WRITE(90,*)'BITMAP INFO',INFO + IF(INFO(1) .EQ. 1 .or. info(1) .eq. 2 .or. info(1) .eq. 15 .or. info(1) .eq. 19) THEN + IXPIX=INFO(2) + IYPIX=INFO(3) + ENDIF + XRANGE=IXPX-IXPM + YRANGE=IYPM-IYPX +! WRITE(90,*) 'RANGE',XRANGE,YRANGE + FRACX1=0. + FRACX2=0. + FRACY1=0. + FRACY2=0. + IF(IXPX .GT. IXPXC) THEN + FRACX1=(IXPX-IXPXC)/XRANGE + IXPX = IXPXC + ENDIF + IF(IYPM .GT. IYPXC) THEN + FRACY1=(IYPM-IYPXC)/YRANGE + IYPM = IYPXC + ENDIF + IF(IXPM .LT. 0) THEN + FRACX2=-IXPM/XRANGE + IXPM=0 + ENDIF + IF(IYPX .LT. 0) THEN + FRACY2=-IYPX/YRANGE + IYPX=0 + ENDIF + +! WRITE(90,*) 'BACKGN2-bm',IXPM,IYPX,IXPX,IYPM +! WRITE(90,*) 'FRAC-bm ',FRACX1,FRACX2,FRACY1,FRACY2 + IF(IHAND1 .NE. 0) THEN + CALL WBitmapDestroy(IHAND1) + CALL WBitmapDestroy(IHAND2) + ENDIF +! WRITE(90,*) 'PIXEL INFO',IXPIX,IYPIX + CALL WBitMapCreate(IHAND1,IXPIX,IYPIX) + IERR = InfoError(LastError) +! WRITE(90,*) 'ERROR CREATE', IERR,IHAND1 + CALL IGrSelect(DrawBitmap,IHAND1) + if(ihand1 .eq. 0) then + IERR = InfoError(LastError) + CALL WMessageBox(OKOnly,ExclamationIcon,CommonOK,& + 'Too many pixels for image to display correctly '//CHAR(13)//'Image will not register ','IMAGE ERROR') + endif +! WRITE(90,*) 'ERROR SELECT', IERR + CALL IGrLoadImage(BFNAME(I),1) + IERR = InfoError(LastError) +! WRITE(90,*) 'ERROR LOAD', IERR + + IX2PIX=IXPIX*(1.-FRACX1-FRACX2) + IY2PIX=IYPIX*(1.-FRACY1-FRACY2) + IXLPIX=IXPIX*FRACX2 + IYLPIX=IYPIX*FRACY2 + IXMPIX=IXPIX*(1.-FRACX1) + IYMPIX=IYPIX*(1.-FRACY1) +! WRITE(90,*) 'HANDL2',IHAND2,IX2PIX,IY2PIX +! WRITE(90,*) 'LOCAL ',IXLPIX,IYLPIX,IXMPIX,IYMPIX + CALL WBitMapCreate(IHAND2,IX2PIX,IY2PIX) + CALL IGrSelect(DrawBitmap,IHAND2) + CALL WBitMapPutPart(IHAND1,0,IXLPIX,IYLPIX,IXMPIX,IYMPIX) + IF(IDDSW .EQ. 1) THEN + CALL IGrSelect(DrawWin) + ELSE + CALL IGrSelect(DrawBitmap,IHANDLE) + ENDIF + IERR = InfoError(LastError) +! WRITE(90,*) 'ERROR SELECT DRAW', IERR + CALL WBitmapPut(IHAND2,1,1,IXPM,IYPX,IXPX,IYPM) +! call gim_an_event(ix,iy,iflag) + + RETURN + END + + Subroutine panel012(ibkon) + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: n,ibkon,IERR +! real :: + character*3 :: sub + + call wdialogload(IDD_DIALOG012) + ierr=infoerror(1) + + do n=1,nbkfl + CALL WDialogPutString(idf_string1+n-1,BFNAME(n)) + call wdialogputcheckbox(idf_check1+n-1,iswbkfl(n)) + enddo + + call wdialogputcheckbox(idf_check11,ibkon) + + CALL WDialogSelect(IDD_DIALOG012) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + do n=1,nbkfl + call wdialogGetcheckbox(idf_check1+n-1,iswbkfl(n)) + CALL GETSUB(BFNAME(n),SUB) + if(sub .eq. 'bmp') then + if(iswbkfl(n) .eq. 1) iswbkfl(n)=2 + ELSEIF(SUB .EQ. 'pcx') then + if(iswbkfl(n) .eq. 1) ISWBKFL(N) = 2 + ELSEIF(SUB .EQ. 'png' .or. sub .eq. 'jpg') then + if(iswbkfl(n) .eq. 1) ISWBKFL(N) = 2 + endif + enddo + + call wdialogGetcheckbox(idf_check11,ibkon) + + ENDIF + RETURN + END + + SUBROUTINE UNDO(IYES) + + USE WINTERACTER + + INCLUDE 'D.INC' + + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do wish to undo?'//& + CHAR(13)//' ','Undo option') +! +! If answer 'No', return +! + iyes=1 + IF (WInfoDialog(4).EQ.2) iyes=0 + return + end + + subroutine frame(xmn,ymn,xmx,ymx) + + CALL PLOTT(xmn,ymn,3) + CALL PLOTT(xmx,ymn,2) + CALL PLOTT(xmx,ymx,2) + CALL PLOTT(xmn,ymx,2) + CALL PLOTT(xmn,ymn,2) + return + end + + SUBROUTINE CIRCLE(CX,CY,rad) + dimension x(8),y(8) + DO I=1,8 + ANGLE=FLOAT(I-1)*6.28318/8. + X(I)=CX+rad*COS(ANGLE) + Y(I)=CY+rad*SIN(ANGLE) + ENDDO +! write(90,*) 'circle',x,y + CALL IGrPolygonComplex(x,y,8) + return + end + + Subroutine GETHDRTYP(IHDSWT) + + use winteracter + + implicit none + + include 'D.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: IHDSWT,IERR + + call wdialogload(IDD_HEADERTP) + ierr=infoerror(1) + + call wdialogputRadioButton(idf_radio1) + + CALL WDialogSelect(IDD_HEADERTP) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,IHDSWT) + return + endif + IHDSWT=1 + RETURN + enddo + RETURN + END + + Subroutine panelfil + + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: n,iflon,IERR +! real :: + character*3 :: sub + + call wdialogload(IDD_SELTFL2) + ierr=infoerror(1) + + write(90,*) 'iactvfil,itotfil',iactvfil,itotfil + do n=1,itotfil + write(90,'(a)') 'file',n,fnameout(n) + CALL WDialogPutString(idf_string25+n-1,FNAMEOUT(n)) + if(n .eq. iactvfil) then + call wdialogputradiobutton(idf_radio1+n-1) + endif + enddo + CALL WDialogSelect(IDD_SELTFL2) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + DO + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + call wdialogGetradiobutton(idf_radio1,iactvfil) + write(90,*) 'Selected iactvfil', iactvfil + RETURN + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + RETURN + ENDIF + ENDDO + END + + + + subroutine plotcr(x,y,siz) + + CALL PLOTT(x-siz/2.,y,3) + CALL PLOTT(x+siz/2,y,2) + CALL PLOTT(x,y-siz/2.,3) + CALL PLOTT(x,y+siz/2.,2) + return + end + + SUBROUTINE OUTJPGW(FNAME,INFO) + + CHARACTER(LEN=255) :: FNAME + INTEGER INFO(3) + INCLUDE 'TXFRM.COM' + + REAL HSIZE + COMMON /SSIZE/ HSIZE + XR=HSIZE*TXSCAL-XS + YT=8.0*TXSCAL-YS + XSIZ=HSIZE*TXSCAL/FLOAT(INFO(2)) + YSIZ=-8*TXSCAL/FLOAT(INFO(3)) + + OPEN(104,FILE=FNAME,STATUS ='UNKNOWN', FORM ='FORMATTED') + WRITE(104,*) XSIZ + WRITE(104,*) ' 0.0' + WRITE(104,*) ' 0.0' + WRITE(104,*) YSIZ + WRITE(104,*) -XS + WRITE(104,*) YT + + CLOSE(104) + + RETURN + END + diff --git a/src/src83e/WINTER.ICO b/src/src83e/WINTER.ICO new file mode 100644 index 0000000..a29a006 Binary files /dev/null and b/src/src83e/WINTER.ICO differ diff --git a/src/src83e/WRTBIN.F90 b/src/src83e/WRTBIN.F90 new file mode 100644 index 0000000..9e25a70 --- /dev/null +++ b/src/src83e/WRTBIN.F90 @@ -0,0 +1,106 @@ + SUBROUTINE WRTBIN + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + DIMENSION IREC(40),FREC(40) + + CHARACTER*4 IPACKB(1200),IPACKT(77) + + DATA (IREC(I),I=1,40) / 40*0 / + DATA (FREC(I),I=1,40) / 40*0. / + +! Write GFGEN banners + + IREC(1) = 435 + MFLG = 100 + WRITE(IOT1) MFLG,IREC(1),NP,NE + IWRT1 = 1200 + DO I=11,1200 + IPACKB(I)=' ' + ENDDO + IPACKB(1)='RMA ' + IPACKB(2)='IMPL' + IPACKB(3)='EMEN' + IPACKB(4)='TATI' + IPACKB(5)='ON O' + IPACKB(6)='F SM' + IPACKB(7)='S OU' + IPACKB(8)='TPUT' + IPACKB(9)=' FOR' + IPACKB(10)='MAT ' + + WRITE (IOT1) IWRT1, (IPACKB(I),I= 1,IWRT1) + + IWRT2 = 40 + IWRT3 = 40 + WRITE (IOT1) IWRT2, IWRT3,(IREC(I),I=1, IWRT2), (FREC(I),I=1,IWRT3) + DO I=1,77 + IPACKT(I)=' ' + IF(I .LT. 73) THEN + IPACKT(I)(1:1)=TITLE(I:I) + ENDIF + ENDDO + IWRT4 = 77 + WRITE (IOT1) IWRT4, (IPACKT(I),I= 1,IWRT4) + + DO J=1,NP +!IPK FEB05 + CORDSN(J,1)=XUSR(J) + CORDSN(J,2)=YUSR(J) + ENDDO + DO J=1,NE + IMATL(J)=IMAT(J) + ENDDO + ALPHA=0. + WRITE(IOT1) NP,NE,((CORDSN(J,K),K=1,2),ALPHA,WD(J),J=1,NP)& + ,((NOP(J,K),K=1,8),IMATL(J),THTA(J),IEM(J),J=1,NE) + WRITE(IOT1) (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,NP) + + + RETURN + END + + + SUBROUTINE RDBIN(IIIN) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + IIN=IIIN + +! Read GFGEN banners + + READ(IIN) MFLG,IREC,N,M + READ(IIN) IWRT1,(IDUM,I=1,IWRT1) + READ(IIN) IWRT2,IWRT3,(IDUM,I=1,IWRT2),(FDUM,I=1,IWRT3) + READ(IIN) IWRT4,(IDUM,I=1,IWRT4) + + READ(IIN) N1,M1,((CORDSN(J,K),K=1,2),ALPHA,WD(J),J=1,N1),& + ((NOP(J,K),K=1,8),IMATL(J),TH0,I3,J=1,M1) + READ(IIN) (WIDTH(J),SS1(J),SS2(J),WIDS(J),J=1,N1) + + DO J=1,N1 + DO K=1,2 + CORD(J,K)=CORDSN(J,K) + ENDDO + XUSR(J)=CORD(J,1) + YUSR(J)=CORD(J,2) + ENDDO + + DO J=1,M1 + IMAT(J)=IMATL(J) +!ipk feb08 + ncorn(j)=0 + DO K=1,8 + if(nop(j,k) .gt. 0) ncorn(j)=k + ENDDO + ENDDO + NP=N1 + NE=M1 + + + CLOSE(IIN) + + RETURN + END diff --git a/src/src83e/XN.F90 b/src/src83e/XN.F90 new file mode 100644 index 0000000..24a2c34 --- /dev/null +++ b/src/src83e/XN.F90 @@ -0,0 +1,200 @@ + DOUBLE PRECISION FUNCTION XN(IT,K,X,Y) + + SAVE + DOUBLE PRECISION X,Y +! +!......FUNCTION TO DEFINE SHAPE FUNCTION VALUES +! + IF(IT .EQ. 2) THEN +! +!......TRIANGULAR ELEMENT +! + GO TO ( 110,120,130,140,150,160),K + 110 XN=(1.-2.*X-2.*Y)*(1.-X-Y) + RETURN + 120 XN=4.*X*(1.-X-Y) + RETURN + 130 XN=(2.*X-1.)*X + RETURN + 140 XN=4.*X*Y + RETURN + 150 XN=(2.*Y-1.)*Y + RETURN + 160 XN=4.*Y*(1.-X-Y) + RETURN +! +!......QUADRILATERAL ELEMENT +! + ELSEIF(IT .EQ. 1) THEN + GO TO (510,520,530,540,550,560,570,580),K + 510 XN=(1.-X)*(1.-Y)*(-X-Y-1.)/4. + RETURN + 520 XN=(1.-X*X)*(1.-Y)/2. + RETURN + 530 XN=(1.+X)*(1.-Y)*(X-Y-1.)/4. + RETURN + 540 XN=(1.+X)*(1.-Y*Y)/2. + RETURN + 550 XN=(1.+X)*(1.+Y)*(X+Y-1.)/4. + RETURN + 560 XN=(1.-X*X)*(1.+Y)/2. + RETURN + 570 XN=(1.-X)*(1.+Y)*(-X+Y-1.)/4. + RETURN + 580 XN=(1.-X)*(1.-Y*Y)/2. + ELSE + GO TO (610,620,630,640,650,660,670,680,690),K + 610 XN=(1.-X)*(1.-Y)*X*Y/4. + RETURN + 620 XN=-Y*(1.-X*X)*(1.-Y)/2. + RETURN + 630 XN=-(1.+X)*(1.-Y)*X*Y/4. + RETURN + 640 XN=X*(1.+X)*(1.-Y*Y)/2. + RETURN + 650 XN=(1.+X)*(1.+Y)*X*Y/4. + RETURN + 660 XN=Y*(1.-X*X)*(1.+Y)/2. + RETURN + 670 XN=-(1.-X)*(1.+Y)*X*Y/4. + RETURN + 680 XN=-X*(1.-X)*(1.-Y*Y)/2. + RETURN + 690 XN=(1.+X)*(1.-X)*(1.+Y)*(1.-Y) + RETURN + ENDIF + END + DOUBLE PRECISION FUNCTION DNX(IT,K,X,Y) + + SAVE + DOUBLE PRECISION X,Y +!- +!......FUNCTION TO DETERMINE X-DERIVATIVE OF SHAPE FUNCTION +!- + IF(IT .EQ. 2) THEN +!- +!......TRIANGULAR ELEMENT +!- + GO TO (110,120,130,140,150,160),K + 110 DNX=-3. +4.*X+4.*Y + RETURN + 120 DNX=4.-8.*X-4.*Y + RETURN + 130 DNX=4.*X-1. + RETURN + 140 DNX=4.*Y + RETURN + 150 DNX=0. + RETURN + 160 DNX=-4.*Y + RETURN +!- +!......QUADRILATERAL ELEMENT +!- + ELSEIF(IT .EQ. 1) THEN + GO TO (510,520,530,540,550,560,570,580),K + 510 DNX=-(1.-Y)*(-2.*X-Y)/4. + RETURN + 520 DNX=-X*(1.-Y) + RETURN + 530 DNX=(1.-Y)*(2.*X-Y)/4. + RETURN + 540 DNX=(1.-Y*Y)/2. + RETURN + 550 DNX=(1.+Y)*(2.*X+Y)/4. + RETURN + 560 DNX=-X*(1.+Y) + RETURN + 570 DNX=-(1.+Y)*(-2.*X+Y)/4. + RETURN + 580 DNX=-(1.-Y*Y)/2. + RETURN + ELSE + GO TO (610,620,630,640,650,660,670,680,690),K + 610 DNX=(Y-Y**2)*(1.-2.*X)/4. + RETURN + 620 DNX= X*(Y-Y**2) + RETURN + 630 DNX=-(Y-Y**2)*(1.+2.*X)/4. + RETURN + 640 DNX=(1.-Y*Y)/2.*(1.+2.*X) + RETURN + 650 DNX=(Y+Y**2)*(1.+2.*X)/4. + RETURN + 660 DNX=-X*(Y+Y**2) + RETURN + 670 DNX=-(Y+Y**2)*(1.-2.*X)/4. + RETURN + 680 DNX=-(1.-Y*Y)/2.*(1.-2.*X) + RETURN + 690 DNX=-2.*X*(1.-Y**2) + RETURN + ENDIF + END + DOUBLE PRECISION FUNCTION DNY(IT,K,X,Y) + SAVE + DOUBLE PRECISION X,Y +!- +! +!......FUNCTION TO DETERMINE Y-DERIVATIVE OF SHAPE FUNCTION +!- + IF(IT .EQ. 2) THEN +!- +!......TRIANGULAR ELEMENT +!- + GO TO (110,120,130,140,150,160),K + 110 DNY=-3.+4.*X+4.*Y + RETURN + 120 DNY=-4.*X + RETURN + 130 DNY=0. + RETURN + 140 DNY=4.*X + RETURN + 150 DNY=4.*Y-1. + RETURN + 160 DNY=4.-4.*X-8.*Y + RETURN +!- +!......QUADRILATERAL ELEMENT +!- + ELSEIF(IT .EQ. 1) THEN + GO TO (510,520,530,540,550,560,570,580),K + 510 DNY=-(1.-X)*(-2.*Y-X)/4. + RETURN + 520 DNY=-(1.-X*X)/2. + RETURN + 530 DNY=-(1.+X)*(X-2.*Y)/4. + RETURN + 540 DNY=-Y*(1.+X) + RETURN + 550 DNY=(1.+X)*(2.*Y+X)/4. + RETURN + 560 DNY=(1.-X*X)/2. + RETURN + 570 DNY=(1.-X)*(2.*Y-X)/4. + RETURN + 580 DNY=-Y*(1.-X) + RETURN + ELSE + GO TO (610,620,630,640,650,660,670,680,690),K + 610 DNY=(X-X**2)*(1.-2.*Y)/4. + RETURN + 620 DNY=-(1.-X*X)/2.*(1.-2.*Y) + RETURN + 630 DNY=-(X+X**2)*(1.-2.*Y)/4. + RETURN + 640 DNY=-Y*(X+X**2) + RETURN + 650 DNY=(X+X**2)*(1.+2.*Y)/4. + RETURN + 660 DNY=(1.-X*X)/2.*(1.+2.*Y) + RETURN + 670 DNY=-(X-X**2)*(1.+2.*Y)/4. + RETURN + 680 DNY= Y*(X-X**2) + RETURN + 690 DNY=-2.*Y*(1.-X**2) + RETURN + ENDIF + END diff --git a/src/src83e/ZOOM.BMP b/src/src83e/ZOOM.BMP new file mode 100644 index 0000000..27841b8 Binary files /dev/null and b/src/src83e/ZOOM.BMP differ diff --git a/src/src83e/ZOOMNEW.F90 b/src/src83e/ZOOMNEW.F90 new file mode 100644 index 0000000..a21abf9 --- /dev/null +++ b/src/src83e/ZOOMNEW.F90 @@ -0,0 +1,104 @@ +!*********************************************************** + subroutine zoomnew(xscrn,yscrn,xscrn1,yscrn1,iflag) +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + character*1 iflag +! +! +!ipk jun96 add zoomj + character*43 zoomh,zoomj + character*23 zoomi +!ipk jan98 + CHARACTER*80 lind + data zoomh/' Zooming, click and drag to form rectangle'/ + data zoomi/' Click right if size OK'/ +!ipk jun96 add zoomj + data zoomj/' Double click, click second point '/ +! +! + 80 CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomh,0.,43) + +!jan09 xcc = 5.00 +!jan09 xp = 5.00 + xcc = 5.00*hsize/10. + xp = 5.00*hsize/10. + ycc = 3.5 + yp = 3.5 +! +! Got cursor location +! + if(iflag .eq. 'r') then +! This option is scaling a window +! +! +! Look for a screen size +! + xsiz=abs(xscrn1-xscrn) + ysiz=abs(yscrn1-yscrn) +!ipk jun96 test for zero sizes + if(xsiz .lt. 0.001 .or. ysiz .lt. 0.001) then + CALL CLRBOX + CALL SYMBL(0.,7.70,0.20,zoomj,0.,43) + return + endif + if(xscrn1 .lt. xscrn) xscrn=xscrn1 + if(yscrn1 .lt. yscrn) yscrn=yscrn1 + fact=HSIZE/xsiz + if(7.5/ysiz .lt. fact) fact=7.5/ysiz +!jan09 if(8./ysiz .lt. fact) fact=8./ysiz +!jan09 xscrn=xscrn+5./fact + xscrn=xscrn+xcc/fact + yscrn=yscrn+3.5/fact + xp=xscrn + yp=yscrn + CALL CLRBOX +! CALL SYMBL(0.,7.70,0.20,zoomi,0.,22) + go to 250 + elseif(iflag .eq. 'w') then + call rescal + return + elseif(iflag .eq. 'y')then + fact=0.5 + elseif(iflag .eq. 'x') then + fact=0.25 + elseif(iflag .eq. 'v')then + fact=1.0 + xp=xp-5. + elseif(iflag .eq. 'u') then + fact=1.0 + xp=xp+5. + elseif(iflag .eq. 't')then + fact=1.0 + yp=yp+3.5 + elseif(iflag .eq. 's') then + fact=1.0 + yp=yp-3.5 + elseif(iflag .eq. 'd') then + fact=1.0 + xp=xp-xscrn + yp=yp-yscrn + endif + do i=1,np + if(cord(i,1) .gt. void) then + inskp(i)=0 + endif + enddo + do i=1,ne + if(imat(i) .gt. 0) then + ieskp(i)=0 + endif + enddo + 250 continue + pscale = pscale/fact + xmino=xmin + ymino=ymin +! + xmin = xp - (xcc*pscale) + ymin = yp - (ycc*pscale) +! + CALL PLOTOT(0) + if(nmess .eq. 11) call pltpt + return + END diff --git a/src/src83e/addmap.f90 b/src/src83e/addmap.f90 new file mode 100644 index 0000000..21a5b63 --- /dev/null +++ b/src/src83e/addmap.f90 @@ -0,0 +1,86 @@ + SUBROUTINE ADDMAP +! +! ROUTINE TO ADD TWO MAPS FILES TOGETHER +! + + USE WINTERACTER + + USE BLKMAP + USE BLK1MOD + USE BLK2MOD + + include 'd.inc' + + + CHARACTER(LEN=255) :: FNAME,FNAMGE,FNAMRM,FNAMEB + CHARACTER(LEN=3) :: SUB,SUB1 + +! FIRST WRITE EXISTING MAP TO SCRATCH + close(99) + OPEN(99,FORM='BINARY',STATUS='SCRATCH') + + +! SAVE THE CONTROL INFORMATION + KEEP1=klint + JEEP1=jlint + + CALL WRTMAP(99) + REWIND 99 + +! NEXT READ NEW MAP AND ALSO WRITE TO A SECOND SCRATCH +! FIRST OPEN A MAP FILE + CALL WSelectFile(ID_STRING1,PromptOn,FNAME,'Load Map File') + + IF (WInfoDialog(ExitButtonCommon).EQ.CommonOpen) THEN + + CALL IlowerCase(FNAME) + CALL GETSUB(FNAME,SUB) + + IF(SUB .EQ. 'map') then + IMP=9 + OPEN(9,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'asc' .or. SUB .EQ. 'grd') then + IMP=94 + OPEN(94,FILE=FNAME,STATUS='OLD') + ELSEIF(SUB .EQ. 'mpb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='unformatted',action='read') + ELSEIF(SUB .EQ. 'mbb') then + imp=92 + OPEN(IMP ,FILE=FNAME,STATUS='OLD',form='binary',action='read') + ENDIF + ENDIF + CALL RDMAP(2,IMP,0,0) + NEWMAXK=KEEP1+klint + NEWMAXPL=JEEP1+jlint + IF(NEWMAXPL .GT. MAXPL) THEN +!! +! NOW OPEN THE FILE FOR SAVING + OPEN(98,FORM='BINARY',STATUS='SCRATCH') + + CALL WRTMAP(98) + REWIND 98 + + +! WORK OUT SIZES AND ALLOCATE ARRAYS + + + deallocate (CMAP,XMAP,YMAP,VAL,imap,NCRS) + + allocate (CMAP(MAXPL,2),XMAP(MAXPL),YMAP(MAXPL),VAL(MAXPL)) + + ALLOCATE (imap(maxpl),NCRS(MAXPL)) + + CALL RDMAP(2,98,0,0) ! XXXXX + CLOSE(98) + ENDIF +! READ IN AND MERGE MAP FILES + + JSTT=JLINT + KSTT=KLINT + CALL RDMAP(2,99,JSTT,KSTT) + CLOSE(99) + call PLOTOT(0) + CALL HEDR + RETURN + END \ No newline at end of file diff --git a/src/src83e/addmesht.f90 b/src/src83e/addmesht.f90 new file mode 100644 index 0000000..2301d0f --- /dev/null +++ b/src/src83e/addmesht.f90 @@ -0,0 +1,307 @@ + SUBROUTINE ADDMESHT + + USE BLK1MOD + USE WINTERACTER + INCLUDE 'BFILES.I90' + INCLUDE 'TXFRM.COM' + + INTEGER OUTPOL,TWO,ZERO,IFILOUT + INTEGER NTRIAN(5000,2),ICT + REAL XMAP1(5000),YMAP1(5000) + + CHARACTER*1 ANSW(10),ANS + CHARACTER(LEN=80) :: DATAIN,OPTIONS + CHARACTER(LEN=96) :: LOCDIR + LOGICAL EXISTS + DATA ANSW/' ',' ',' ',' ',' ','b','n','z','r','q'/ + do k=1,80 + options(k:k)=' ' + enddo + TWO=2 + ZERO=0 + OUTPOL=23 + ICT=0 +! add headers + NHTPSV=NHTP + NMESSSV=NMESS + NBRRSV=NBRR + NHTP=0 + NMESS=48 + NBRR=5 + call hedr +! go and get points to form outline + 200 CALL xyloc(XTEMP,YTEMP,ans,IBOX) + siz=0.1 + call drawcr(xtemp,ytemp,siz) + IF(IRMAIN .EQ. 1) RETURN +! + IF(ANS .EQ. 'c') THEN + if(ibox .eq. 0) go to 400 + I=IBOX + ANS=ANSW(I) + ENDIF + IF(ANS .EQ. 'b') THEN + ICT=ICT-1 + GO TO 200 + ELSEIF(ANS .EQ. 'n') THEN + GO TO 500 + ELSEIF(ANS .EQ. 'q') THEN + RETURN + ENDIF +400 ICT=ICT+1 + XMAP1(ICT) = XTEMP*TXSCAL - XS + YMAP1(ICT) = YTEMP*TXSCAL - YS + IF(ICT .GT. 1) THEN + NTRIAN(ICT-1,1)=ICT-1 + NTRIAN(ICT-1,2)=ICT + ENDIF + GO TO 200 + 500 CONTINUE + NTRIAN(ICT,1)=ICT + NTRIAN(ICT,2)=1 + +! write current data to a scratch file for later addition + IFILOUT=IACTVFIL+50 + CALL WRTFIL(IFILOUT) +! +! IF(IACTVFIL .GT. 0) THEN +! CALL WRTFIL(50) +! IFILOUT=IACTVFIL+50 +! CALL WRTFIL(IFILOUT) +! CALL ZEROOUT +! IACTVFIL=ITOTFIL +! ELSE +! IACTVFIL=1 +! ENDIF +! +!! clear screen +! CALL clscrn + +! form TRIANG file + + OPEN(OUTPOL,FILE='TEST.POLY', STATUS='UNKNOWN') + WRITE(OUTPOL,*) ICT,TWO,ZERO,ZERO + DO K=1,ICT + WRITE(OUTPOL,*) K,XMAP1(K),YMAP1(K) + ENDDO + WRITE(OUTPOL,*) ICT,ZERO + DO J=1, ICT + WRITE(OUTPOL,*) J,ntrian(J,1),ntrian(J,2) + ENDDO + WRITE(OUTPOL,*) ZERO + FLUSH (OUTPOL) + REWIND (OUTPOL) + CLOSE (OUTPOL) + +! OPTIONS = ' -pqa5000V TEST' + OPTIONS(1:3) = ' -p' + nct=3 + iswq=1 + iswy=0 + id1=100 + CALL PANELFILLT(ISWQ,ISWY,ID1) + + IF(ISWQ .EQ. 1) THEN + NCT=NCT+1 + OPTIONS(NCT:NCT)='q' + ENDIF + IF(ISWY .EQ. 1) THEN + NCT=NCT+1 + OPTIONS(NCT:NCT)='q' + ENDIF + ID1=ID1**2/2 + WRITE(OPTIONS(NCT+1:NCT+12),'(''a'',I6.6,'' TEST'')') ID1 +! go to TRIANGLE + INQUIRE (FILE = 'test.1.ele', EXIST = exists) + if(exists) then + open(77,file= 'test.1.ele') + close(77,status='DELETE') + ENDIF + + INQUIRE (FILE = 'test.1.node', EXIST = exists) + if(exists) then + open(77,file= 'test.1.node') + close(77,status='DELETE') + ENDIF + + INQUIRE (FILE = 'test.1.poly', EXIST = exists) + if(exists) then + open(77,file= 'test.1.poly') + close(77,status='DELETE') + ENDIF + + INQUIRE (FILE = "C:\Program Files\RMA\TRIANGLE.EXE", EXIST = exists) + if(.not. exists) then + INQUIRE (FILE = "TRIANGLE.EXE", EXIST = exists) + if(.not. exists) then + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'TRIANGLE is not available in '//CHAR(13)//& + 'C:\Program Files\RMA\ directory'//CHAR(13)//'Do you wish to define directory?'& + ,'WARNING TRIANGLE IS NOT AVAILABLE') + +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) return + CALL GETDIR(LOCDIR) + else + LOCDIR(1:8)='TRIANGLE' +! WRITE(155,*) LOCDIR + RESULT= RUNQQ(LOCDIR, OPTIONS) + GO TO 600 + endif + endif + RESULT= RUNQQ("C:\Program Files\RMA\TRIANGLE", OPTIONS) +! RESULT= RUNQQ("TRIANGLE", OPTIONS) + +600 IIN=10 + OPEN(IIN,FILE='TEST.1.ELE', STATUS='OLD') + +! write(155,*) 'going to get newfile' + CALL GETNEWFIL(IIN,0,-1,-1) + !IADD=50+iactvfil+1 + !CALL RDTOCLIP(IADD) + ! + !IF(IADD .EQ. 51) THEN + !write(90,*) 'finished addmesh' + ! + !NHTP=NHTPSV + !NMESS=NMESSSV + !NBRR=NBRRSV + !call hedr + !ELSE + ! CALL ADDMESH(0) + NHTP=NHTPSV + NMESS=NMESSSV + NBRR=NBRRSV + call hedr + CALL PLOTOT(0) + +! CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to delete unused nodes?'//& +! CHAR(13)//' ','Delete unused nodes?') +! ! +!! If answer 'No', return +!! +! IF (WInfoDialog(4).EQ.2) return +!! +!! Delete all unused nodes +!! +! CALL DELETM(2) +! +! ENDIF + +! get new mesh +! add meshes together + RETURN + END + + SUBROUTINE UNDOGEN + USE BLK1MOD + INCLUDE 'BFILES.I90' + ALLOCATABLE NODETRAN(:) + DATA VDX9/-9.E9/ + +! Loop through nodes assigning new number and adding to list + + IF(.NOT. ALLOCATED(NODETRAN)) ALLOCATE (NODETRAN(maxp)) + + CALL ZEROOUT + IADD=50+IACTVFIL + CALL RDTOCLIP(IADD) + + DO N=1,NPSTO(1) + IF(XUSRSTO(N,1) .GT. VDX9) THEN + CALL GETNOD(J) + NODETRAN(N)=J + XUSR(J)=XUSRSTO(N,1) + YUSR(J)=YUSRSTO(N,1) + WD(J)=WDSTO(N,1) + WIDTH(J)=WIDTHSTO(N,1) + SS1(J)=SS1STO(N,1) + SS2(J)=SS2STO(N,1) + WIDS(J)=WIDSSTO(N,1) + WIDBS(J)=WIDBSSTO(N,1) + SSO(J)=SSOSTO(N,1) + BS1(J)=BS1STO(N,1) + INSKP(J) = 0 + INEW(J) = 1 + ENDIF + ENDDO + +! Loop through elements assigning new number and adding to list + + DO N=1,NESTO(1) + IF(IMATSTO(N,1) .GT. 0) THEN + CALL GETELM(M) + DO K=1,8 + IF(NOPSTO(N,K,1) .GT. 0) THEN + J=NODETRAN(NOPSTO(N,K,1)) + NOP(M,K)=J + ELSE + NOP(M,K)=0 + ENDIF + ENDDO + IMAT(M)=IMATSTO(N,1) + THTA(M)=THTASTO(N,1) + IESKP(M)=0 + NCN = 2 + IF (NOP(M,3) .NE. 0) NCN = 3 + IF (NOP(M,4) .NE. 0) NCN = 4 + IF (NOP(M,5) .NE. 0 .AND. NOP(M,4) .NE. 0) NCN = 5 + IF (NOP(M,5) .NE. 0 .AND. NOP(M,4) .EQ. 0) NCN = 6 + IF (NOP(M,6) .NE. 0) NCN = 6 + IF (NOP(M,7) .NE. 0) NCN = 8 + NCORN(M) = NCN + + ENDIF + ENDDO + +! if(iswt .eq. 0) CALL RESCAL + CALL RESCAL + CALL HEDR + + RETURN + END + SUBROUTINE GETDIR(LOCDIR) + use winteracter + + implicit none + + include 'D.inc' + INCLUDE 'BFILES.I90' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + CHARACTER*96 LOCDIR + integer ierr,K,KL + + call wdialogload(IDD_GETFL) + ierr=infoerror(1) + + CALL WDialogPutString(idf_string1,locdir) +! LOCDIR='C:\Users\RMA5440\TRIANGLE\TRIANGLE' + + CALL WDialogSelect(IDD_GETFL) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + CALL WDialogGetString(idf_string1,locdir) + DO K=96,1,-1 + KL=K + IF(LOCDIR(K:K) .NE. ' ') GO TO 200 + ENDDO + LOCDIR(1:8)='TRIANGLE' + RETURN +200 CONTINUE + LOCDIR(KL+1:KL+9)='\TRIANGLE' + WRITE(90,*) LOCDIR + RETURN + endif + enddo + END \ No newline at end of file diff --git a/src/src83e/addtomesh.f90 b/src/src83e/addtomesh.f90 new file mode 100644 index 0000000..939703a --- /dev/null +++ b/src/src83e/addtomesh.f90 @@ -0,0 +1,628 @@ +!ipk last update sep 20 2013 add more output of progress and flushing of messages + SUBROUTINE ADDTOMESH(IADDFIL,ISWT) + +! iswt = 0 ADD TO MESH +! ISWT = 1 MERGE MESHES + + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD + + INCLUDE 'D.INC' + +! INCLUDE 'BLK1.COM' + INCLUDE 'BFILES.I90' + + IADD=IADDFIL+50 + CALL RDTOCLIP(IADD) + + IF(ISWT .EQ. 1) THEN + CALL OUTLINES(1) + ISWT1=0 +! IF(NOUTLST(2) .EQ. 0) THEN + ISWT2=1 +! ELSE +! ISWT2=0 +! ENDIF + CALL MERGEMESH1(ISWT1,ISWT2) + write(90,*) 'finished mergemesh1' + IF(ISWT2 .EQ. 0) CALL MERGEMESH +! CALL MERGEMESH + write(90,*) 'finished mergemesh' + flush(90) + ENDIF + + CALL ADDMESH(0) + write(90,*) 'finished addmesh' + + IF(ISWT .EQ. 1 ) THEN + CALL WMessageBox(YesNo,QuestionIcon,CommonOK,'Do you wish to delete unused nodes?'//& + CHAR(13)//' ','Delete unused nodes?') + ! +! If answer 'No', return +! + IF (WInfoDialog(4).EQ.2) return +! +! Delete all unused nodes +! + CALL DELETM(2) + ENDIF + + RETURN + END + + + SUBROUTINE RDTOCLIP(IUNIT) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + CHARACTER*80 ALINE + + REWIND IUNIT + READ(IUNIT) TITLE,NPSTO(1),NESTO(1) + WRITE(90,*) 'IN RDTOCLIP',IUNIT + WRITE(90,*) TITLE,NPSTO(1),NESTO(1) + READ(IUNIT) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempinc + WRITE(90,*) ISLP,IPRT,IPNN,IPEN,IPO,IRO,IPP,IRFN & + & ,IGEN,NXZL,NITST,ISCTXT,IFILL,IALTGM,NLAYD,xadded,yadded,ntempinc + READ(IUNIT) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + WRITE(90,*) HORIZ,VERT,XSALE,YSALE,XFACT,YFACT,AR,ANG + IF(IPP .GT. 0) READ(IIN) ALINE + + READ(IUNIT) ((NOPSTO(J,K,1),K=1,8),IMATSTO(J,1),THTASTO(J,1),J=1,NESTO(1)) + + READ(IUNIT) & + & (XUSRSTO(J,1),YUSRSTO(J,1),WDSTO(J,1),WIDTHSTO(J,1),SS1STO(J,1),SS2STO(J,1),WIDSSTO(J,1), & + & WIDBSSTO(J,1),SSOSTO(J,1),BS1STO(J,1),J=1,NPSTO(1)) + + READ(IUNIT) NLSTSTO(1) + IF(NLSTSTO(1) .GT. 0) THEN + READ(IUNIT) (LLISTSTO(J,1),J=1,NLSTSTO(1)), & + ((ILISTSTO(J,I,1),I=1,LLISTSTO(J,1)),J=1,NLSTSTO(1)) + ENDIF + + READ(IUNIT) NENTRYC,NLAYDC,NCLMSTO(1) + IF(NENTRYC .GT. 0) THEN + READ(IUNIT) ((NEFC,J=1,3),I=1,NENTRYC) + ENDIF + IF(NLAYDC .GT. 0) THEN + READ(IUNIT) (LAYC,I=1,NPSTO(1)) + ENDIF + IF(NCLMSTO(1) .GT. 0) THEN + READ(IUNIT) ((ICCLNSTO(I,J,1),J=1,350),I=1,NCLMSTO(1)) + ENDIF + + REWIND IUNIT + RETURN + END + + SUBROUTINE ADDMESH(ISWT) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + + ALLOCATABLE NODETRAN(:) + DATA VDX9/-9.E9/ + +! Loop through nodes assigning new number and adding to list + + IF(.NOT. ALLOCATED(NODETRAN)) ALLOCATE (NODETRAN(maxp)) + + IF(ISWT .EQ. 0) THEN + DO N=1,NPSTO(1) + IF(XUSRSTO(N,1) .GT. VDX9) THEN + CALL GETNOD(J) + NODETRAN(N)=J + XUSR(J)=XUSRSTO(N,1) + YUSR(J)=YUSRSTO(N,1) + WD(J)=WDSTO(N,1) + WIDTH(J)=WIDTHSTO(N,1) + SS1(J)=SS1STO(N,1) + SS2(J)=SS2STO(N,1) + WIDS(J)=WIDSSTO(N,1) + WIDBS(J)=WIDBSSTO(N,1) + SSO(J)=SSOSTO(N,1) + BS1(J)=BS1STO(N,1) + INSKP(J) = 0 + INEW(J) = 1 + ENDIF + ENDDO + ELSE + DO N=1,NPSTO(1) + NODETRAN(N)=N + ENDDO + ENDIF + +! Loop through elements assigning new number and adding to list + + DO N=1,NESTO(1) + IF(IMATSTO(N,1) .GT. 0) THEN + CALL GETELM(M) + DO K=1,8 + IF(NOPSTO(N,K,1) .GT. 0) THEN + J=NODETRAN(NOPSTO(N,K,1)) + NOP(M,K)=J + ELSE + NOP(M,K)=0 + ENDIF + ENDDO + IMAT(M)=IMATSTO(N,1) + THTA(M)=THTASTO(N,1) + IESKP(M)=0 + NCN = 2 + IF (NOP(M,3) .NE. 0) NCN = 3 + IF (NOP(M,4) .NE. 0) NCN = 4 + IF (NOP(M,5) .NE. 0 .AND. NOP(M,4) .NE. 0) NCN = 5 + IF (NOP(M,5) .NE. 0 .AND. NOP(M,4) .EQ. 0) NCN = 6 + IF (NOP(M,6) .NE. 0) NCN = 6 + IF (NOP(M,7) .NE. 0) NCN = 8 + NCORN(M) = NCN + + ENDIF + ENDDO + + if(iswt .eq. 0) CALL RESCAL + CALL HEDR + + RETURN + END + + SUBROUTINE MERGEMESH1(ISWT1,ISWT2) + + USE BLK1MOD + USE BLK2MOD + USE WINTERACTER + +! INCLUDE 'BLK1.COM' + + REAL*8 ELXMIN,ELXMAX,ELYMIN,ELYMAX,XLC,YLC,XXX,YYY + LOGICAL LSTAT + + ALLOCATABLE ELXMIN(:),ELXMAX(:),ELYMIN(:),ELYMAX(:),KEY(:),NKEY(:) + DIMENSION XOUT1(1000),YOUT1(1000) + IF(.NOT. ALLOCATED(ELXMIN)) & + ALLOCATE (ELXMIN(MAXE),ELXMAX(MAXE),ELYMIN(MAXE),ELYMAX(MAXE),KEY(MAXE),NKEY(MAXP)) + + IF(ISWT2 .EQ. 0) GO TO 110 +! first eliminate any elements inside outline + CALL KCONST(0) + NKEP=0 + DO K=1,10 + IF(NOUTLST(K) .LE. 0) THEN + DO J=1,NPSTO(1) + XXXX=XUSRSTO(J,1) + YYYY=YUSRSTO(J,1) + LSTAT=IGrInsidePolygon(XOUT(1,K),YOUT(1,K),-NOUTLST(K),XXXX,YYYY) + IF(LSTAT) THEN + NKEP(J)=1 + ENDIF + ENDDO + ENDIF + ENDDO + DO K=1,10 + IF(NOUTLST(K) .GT. 0) THEN + DO J=1,NPSTO(1) + IF(NKEP(J) .EQ. 1) CYCLE + XXXX=XUSRSTO(J,1) + YYYY=YUSRSTO(J,1) +! WRITE(155,*) J,XXXX,YYYY + LSTAT=IGrInsidePolygon(XOUT(1,K),YOUT(1,K),NOUTLST(K),XXXX,YYYY) +! WRITE(155,*) J,LSTAT + IF(LSTAT) THEN + DO L=1,NDELM(J) + NCAN=NECON(J,L) + CALL DELEM(NCAN) + ENDDO + ENDIF + ENDDO + ENDIF +100 CONTINUE + ENDDO + IF(ISWT2 .EQ. 1) RETURN +! First sort coordinates for min of element connection + +! List all limiting values + 110 CONTINUE + DO N=1,NE + IF(IMAT(N) .GT. 0) THEN + ELXMIN(N)=XUSR(NOP(N,1)) + ELXMAX(N)=XUSR(NOP(N,1)) + ELYMIN(N)=YUSR(NOP(N,1)) + ELYMAX(N)=YUSR(NOP(N,1)) + DO M=2,8 + IF(NOP(N,M) .NE. 0) THEN + ELXMIN(N)=MIN(ELXMIN(N),XUSR(NOP(N,M))) + ELXMAX(N)=MAX(ELXMAX(N),XUSR(NOP(N,M))) + ELYMIN(N)=MIN(ELYMIN(N),YUSR(NOP(N,M))) + ELYMAX(N)=MAX(ELYMAX(N),YUSR(NOP(N,M))) + ENDIF + ENDDO + ELSE + ELXMIN(N)=VOID + ELXMAX(N)=VOID + ELYMIN(N)=VOID + ELYMAX(N)=VOID + ENDIF + ENDDO + + CALL SORTDB(XUSRSTO,NKEY,NPSTO(1)) + + CALL SORTDB(ELXMIN,KEY,NE) + +! Loop on elements to check for overlap + + + DO KK=1,NESTO(1) + IF (NOPSTO(KK,6,1) .EQ. 0) CYCLE + IF(IMATSTO(KK,1) .GT. 0) THEN + if(mod(kk,1000) .eq. 0) write(90,*) 'merged',kk + flush(90) + KL=1 + 200 CONTINUE + IF(ISWT1 .EQ. 0) THEN + DO K=KL,8 + J=NOPSTO(KK,K,1) + IF(J .GT. 0) THEN + KLL=KL + XXX=XUSRSTO(J,1) + YYY=YUSRSTO(J,1) + GO TO 220 + ENDIF + ENDDO + KLL=8 + GO TO 400 + 220 CONTINUE + ELSE + XXX=0. + YYY=0. + DO K=1,7,2 + JJ=NOPSTO(KK,K,1) + IF(JJ .GT. 0) THEN + XXX=XXX+XUSRSTO(JJ,1) + YYY=YYY+YUSRSTO(JJ,1) + ENDIF + ENDDO + IF(JJ .EQ. 0) THEN + XXX=XXX/3. + YYY=YYY/3. + ELSE + XXX=XXX/4. + YYY=YYY/4. + ENDIF + ENDIF +! Search on elements to find a startin point + + DO NN=1,NE + + N=KEY(NN) + IF(IMAT(N) .GT. 0) THEN +!- +!...... DETERMINE ELEMENT TYPE +!- + NCN=8 + IT=1 + IF(NOP(N,7) .EQ. 0) THEN + NCN=6 + IT=2 + ENDIF + IF(NOP(N,6) .EQ. 0) THEN + GOTO 350 + ENDIF +! Test for point inside an element + + +! Test for max and min within + + IF(XXX .GT. ELXMIN(N)) THEN + IF(XXX .GT. ELXMAX(N)) GO TO 350 + IF(YYY .GT. ELYMIN(N)) THEN + IF(YYY .GT. ELYMAX(N)) GO TO 350 + +! Now get local coordinate as final test + + CALL GPTEV(N,XXX,YYY,XLC,YLC,IT,NCN) + + IF(IT .EQ. 2) THEN + IF(XLC .LT. 0. .OR. YLC .LT. 0. .OR. XLC+YLC .GT. 1.) THEN + GO TO 350 + ELSE + CALL DELEM(KK) + GO TO 400 + ENDIF + ELSE + IF(XLC .LT. -1. .OR. YLC .LT. -1. .OR. & + XLC .GT. 1. .OR. YLC .GT. 1.) THEN + GO TO 350 + ELSE + CALL DELEM(KK) + GO TO 400 + ENDIF + ENDIF + + ENDIF + ENDIF + ENDIF + 350 CONTINUE + ENDDO + KL=KLL+1 + IF(KL .LT. 8 .AND. ISWT1 .EQ. 0) GO TO 200 + ENDIF + +! Finished test + + 400 CONTINUE + ENDDO + RETURN + END + + + SUBROUTINE GPTEV(N,XSW,YSW,XG,YG,IT,NCN) +!- +!......EVALUATE FUNCTION AT GRID POINTS +!- +!- N = ELEMENT NUMBER +!_ XSW = X COORDINATE OF DESIRED POINT +!_ YSW = Y COORDINATE OF DESIRED POINT +! XG = X LOCAL COORDINATE +! YG = Y LOCAL COORDINATE +! IT = SWITCH FOR CHOICE BETWEEN LINEAR AND QUADRATIC WEIGHTING +! = 1 FOR LINEAR +! = 2 FOR QUADRATIC +! FROM COMMON +! NOP = LIST OF NODAL CONNECTIONS AROUND AN ELEMET +! XUSR = REAL*8 ARRAY OF NODAL COORDINATES +! + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + REAL*8 XN,DNX,DNY,XSW,YSW + DOUBLE PRECISION XG,YG,XK,YK,XP,YP +!- + DIMENSION X(9),Y(9),WGT(8) +!- + DATA TOL/0.01/ +!- + +!- +!......ESTABLISH LOCAL COORDINATES FOR EACH NODE POINT OF ELEMENT +!- + K1=NOP(N,1) + X(1)=0. + Y(1)=0. + DO 300 K=3,NCN,2 + K2=NOP(N,K) + X(K)=XUSR(K2)-XUSR(K1) + Y(K)=YUSR(K2)-YUSR(K1) + 300 END DO + X(2)=X(3)/2. + Y(2)=Y(3)/2. + X(4)=(X(3)+X(5))/2. + Y(4)=(Y(3)+Y(5))/2. + IF(IT .EQ. 2) THEN + X(6)=X(5)/2. + Y(6)=Y(5)/2. + + xminl=min(x(1),x(3),x(5)) + yminl=min(y(1),y(3),y(5)) + xmaxl=max(x(1),x(3),x(5)) + ymaxl=max(y(1),y(3),y(5)) + ELSE + X(6)=(X(5)+X(7))/2. + Y(6)=(Y(5)+Y(7))/2. + X(8)=X(7)/2. + Y(8)=Y(7)/2. + + xminl=min(x(1),x(3),x(5),x(7)) + yminl=min(y(1),y(3),y(5),y(7)) + xmaxl=max(x(1),x(3),x(5),x(7)) + ymaxl=max(y(1),y(3),y(5),y(7)) + ENDIF + + +!- +!......ESTABLISH LOCAL COORDINATES OF DESIRED POINT +!- + XP=XSW-XUSR(K1) + YP=YSW-YUSR(K1) + + XG=0. + YG=0. +!- +!......ITERATE TO FIND LOCAL COORDINATE +!- + DO ITER=1,10 + DXKDX=0. + DXKDY=0. + DYKDX=0. + DYKDY=0. + XK=-XP + YK=-YP + DO K=2,NCN + XK=XK+XN(IT,K,XG,YG)*X(K) + YK=YK+XN(IT,K,XG,YG)*Y(K) + DXKDX=DXKDX+DNX(IT,K,XG,YG)*X(K) + DYKDX=DYKDX+DNX(IT,K,XG,YG)*Y(K) + DXKDY=DXKDY+DNY(IT,K,XG,YG)*X(K) + DYKDY=DYKDY+DNY(IT,K,XG,YG)*Y(K) + END DO + DET=DXKDX*DYKDY-DXKDY*DYKDX + DX=(-DYKDY*XK+DXKDY*YK)/DET + DY=( DYKDX*XK-DXKDX*YK)/DET + XG=XG+DX + YG=YG+DY + IF(ABS(DX).LT.TOL .AND. ABS(DY).LT.TOL) GO TO 420 + END DO +!- +!......NOW GET WEIGHTING FUNCTIONS FOR QUAD FUNCTION +!- + 420 CONTINUE + + + RETURN + END + + SUBROUTINE DELEM(J) +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! +!- +!......DELETE ELEMENT +! +! Search for elements that attach to node J and remove them +! + + IMATSTO(J,1)=0 + DO KK=1,8 + NOPSTO(J,KK,1)=0 + ENDDO +! + + RETURN + END + + + SUBROUTINE MERGEMESH + + USE BLK1MOD + LOGICAL LSTAT +! INCLUDE 'BLK1.COM' + +! Loop on element to be added + + DO N=1,NESTO(1) + + IF(IMATSTO(N,1) .NE. 0) THEN + if(mod(n,1000) .eq. 0) write(90,*) 'adding',n,nesto(1) + flush(90) + IF(IMATSTO(N,1) .GT. 900 .AND. IMATSTO(N,1) .LT. 904) THEN + X1=XUSRSTO(NOPSTO(N,1,1),1) + Y1=YUSRSTO(NOPSTO(N,1,1),1) + CALL CHECKIN(X1,Y1,LSTAT) + IF(ISTATUS .EQ. 5) THEN + CALL DELEM(N) + GO TO 400 + ENDIF + GO TO 400 + ENDIF + +! loop on sides + + DO M=1,7,2 + N1=NOPSTO(N,M,1) + IF(M .EQ. 3 .AND. NOPSTO(N,5,1) .EQ. 0) GO TO 400 + IF(N1 .GT. 0) THEN + IF((M .EQ. 5 .AND. NOPSTO(N,7,1) .EQ. 0) .OR. (M .EQ. 7)) THEN + N2=NOPSTO(N,1,1) + ELSE + N2=NOPSTO(N,M+2,1) + ENDIF + IF(NKEP(N1) .EQ. 1 .AND. NKEP(N2) .EQ. 1) GO TO 380 + +! Now loop trough existing elements + + DO I=1,NE + IF(IMAT(I) .NE. 0) THEN + DO J=1,7,2 + M1=NOP(I,J) + IF(J .EQ. 3 .AND. NOP(I,5) .EQ. 0) GO TO 360 + IF(M1 .GT. 0) THEN + IF((J .EQ. 5 .AND. NOP(I,7) .EQ. 0) .OR. (J .EQ. 7)) THEN + M2=NOP(I,1) + ELSE + M2=NOP(I,J+2) + ENDIF + if(m2 .eq. 0) cycle + X1=XUSRSTO(N1,1) + X2=XUSRSTO(N2,1) + Y1=YUSRSTO(N1,1) + Y2=YUSRSTO(N2,1) + X3=XUSR(M1) + X4=XUSR(M2) + Y3=YUSR(M1) + Y4=YUSR(M2) + CALL IGrIntersectLine(X1,Y1,X2,Y2,X3,Y3,X4,Y4,XINTER,YINTER,ISTATUS) + IF(ISTATUS .EQ. 5) THEN + CALL DELEM(N) + GO TO 400 + ENDIF + ENDIF + ENDDO + ENDIF +360 CONTINUE + ENDDO + ENDIF +380 CONTINUE + ENDDO + ENDIF + 400 CONTINUE + ENDDO + + RETURN + END + + SUBROUTINE CHECKIN(X1,Y1,LSTAT) + USE BLK1MOD + LOGICAL LSTAT + DIMENSION XP(4),YP(4) +! Now loop trough existing elements + + DO I=1,NE + IF(IMAT(I) .NE. 0) THEN + JJ=0 + DO J=1,7,2 + INODE=NOP(I,J) + IF(INODE .GT. 0) THEN + JJ=JJ+1 + XP(JJ)=XUSR(INODE) + YP(JJ)=YUSR(INODE) + ENDIF + ENDDO + LSTAT=IGrInsidePolygon(XP,YP,JJ,X1,Y1) + IF(LSTAT) RETURN + ENDIF + ENDDO + RETURN + END + SUBROUTINE KCONST(isw1) +! +! ESTABLISH ELEMENT CONNECTED TO ELEMENT TABLE +! + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' +! +! INITIALIZE +! + NCM=11 + DO 200 J=1,NCM + DO 200 N=1,NPSTO(1) + 200 NECON(N,J)=0 + DO 230 N=1,NPSTO(1) + 230 NDELM(N)=0 +! +! FORM TABLE OF ELEMENTS CONNECTED TO EACH NODE +! + DO 300 M=1,NESTO(1) + IF(IMATSTO(M,1) .EQ. 0) GO TO 300 + if(isw1 .eq. 1) then + if(imat(m) .eq. 999) go to 300 + endif + DO 280 K=1,8 + N=NOPSTO(M,K,1) + IF (N .GT. 0) THEN + NDELM(N)=NDELM(N)+1 + J=NDELM(N) + NECON(N,J)=M +!ipkoct93 ELSE +!ipkoct93 GO TO 300 + ENDIF + 280 CONTINUE + 300 END DO + RETURN + END + \ No newline at end of file diff --git a/src/src83e/adjustopt.f90 b/src/src83e/adjustopt.f90 new file mode 100644 index 0000000..e9fbd60 --- /dev/null +++ b/src/src83e/adjustopt.f90 @@ -0,0 +1,49 @@ +!IPK NEW ROUTINE SEP 9 2006 + SUBROUTINE ADJUSTOPT(NTYP,NLOCC) +! +! Generate continuity lines +! + + USE WINTERACTER + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: NTYP,NLOCC + + + call wdialogload(IDD_SETOPT) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_SETOPT) + ierr=infoerror(1) + + IF(NTYP .EQ. 1) THEN + call wdialogputRadioButton(idf_radio1) + ELSE + call wdialogputRadioButton(idf_radio2) + ENDIF + call wdialogputcheckbox(IDF_check1,NLOCC) + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ntyp) + + call wdialogGetcheckbox(IDF_check1,NLOCC) + GO TO 100 + ENDIF + + enddo + + 100 CONTINUE + return + end diff --git a/src/src83e/backc.f90 b/src/src83e/backc.f90 new file mode 100644 index 0000000..f463e5f --- /dev/null +++ b/src/src83e/backc.f90 @@ -0,0 +1,40 @@ + SUBROUTINE backc(ient) + + use winteracter + + implicit none + + include 'd.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: iw,ih,ihandle,ient,IHAND1,IHAND2,IXPM,IYPX,IXPX,IYPM,IRGB + common /hands/ ihandle,IHAND1,IHAND2,IXPM,IYPX,IXPX,IYPM + if(ient .eq. 1) then + iw=WinfoWindow(WindowWidth) + ih=WinfoWindow(WindowHeight) + WRITE(90,*) 'IW,IH',IW,IH + IF(IHANDLE .EQ. 0) THEN + IRGB = WRGB(220,220,220) + call WBitmapCreate(ihandle,iw,ih,irgb) + call IGrSelect(DrawBitmap,ihandle) +! CALL WBitmapPut(IHAND2,1,1,IXPM,IYPX,IXPX,IYPM) + ELSE + call IGrSelect(DrawBitmap,ihandle) +! CALL WBitmapPut(IHAND2,1,1,IXPM,IYPX,IXPX,IYPM) + + ENDIF + return + else + call IGrSelect(DrawWin) + call WBitmapPut(ihandle,0,0) + call WBitmapDestroy(ihandle) + ihandle=0 + + endif + return + end diff --git a/src/src83e/blkmap.f90 b/src/src83e/blkmap.f90 new file mode 100644 index 0000000..79c64a5 --- /dev/null +++ b/src/src83e/blkmap.f90 @@ -0,0 +1,17 @@ + MODULE BLKMAP + +! PARAMETER (MAXPL=500000,MAXELMP=50000) + + REAL*8 XCEN,YCEN,RADS,MAP,XMAP,YMAP,CMAP + + ALLOCATABLE NOPEL(:,:),XCEN(:),YCEN(:)& + ,RADS(:) ,NKEY(:),CMAP(:,:)& + ,XMAP(:),YMAP(:),VAL(:),CCMAP(:) + + INTEGER IEDGE(15000,2),IGAP(15000),NELFM(15000) + + INTEGER NELTS,MAXPL,MAXELMP + + ALLOCATABLE imap(:),NCRS(:) + + END MODULE diff --git a/src/src83e/cgen.f90 b/src/src83e/cgen.f90 new file mode 100644 index 0000000..4ac2e45 --- /dev/null +++ b/src/src83e/cgen.f90 @@ -0,0 +1,151 @@ + SUBROUTINE CGEN + +! Routine to establish contour lines + + USE BLKMAP + USE BLK1MOD +! INCLUDE 'BLK1.COM' + DIMENSION XINT(2),YINT(2),CSEL(100)& + ,X(5),Y(5),VALC(5) + COMMON /CCGEN/ XCLIN(4000,2),YCLIN(4000,2),ALIN(-4000:4000,2),IUSED(4000) + COMMON /OPTION/ SWITCH(4),NUMV,CONTUR(99),IQUAL,XCSQ,NUMCOL + common itempel(5000) + +! Set up contours to be developed +! + CALL TOLMAX(WD,TTMIN,TTMAX) + + + ISZ=1 + CALL CSET(TTMIN,TTMAX,isz) + + NCLIN=NUMV + + DO N=1,NUMV + CSEL(N)=CONTUR(N) + ENDDO + +! Loop through each contour then each element + + DO J=1,NCLIN + + ILIN=0 + DO N=1,NE + IF(IMAT(N) .GT. 0 .AND. IMAT(N) .LT. 901 .AND. NCORN(N) .GT. 5) THEN + ISWT=0 + NCNX=NCORN(N)/2 + DO K=1,3 + X(K)=XUSR(NOP(N,2*K-1)) + Y(K)=YUSR(NOP(N,2*K-1)) + VALC(K)=WD(NOP(N,2*K-1)) + ENDDO + NCNXX=3 + CALL CGENTR(N,ISWT,NCNXX,X,Y,VALC,CSEL(J),XINT,YINT) + IF(ISWT .GT. 0) THEN + ILIN=ILIN+1 + DO K=1,2 + XCLIN(ILIN,K)=XINT(K) + YCLIN(ILIN,K)=YINT(K) + ENDDO + itempel(ilin)=n + ENDIF + + IF(NCNX .EQ. 4) THEN + ISWT=0 + DO K=3,5 + IF(K .LT. 5) THEN + KK=2*K-1 + ELSE + KK=1 + ENDIF + X(K-2)=XUSR(NOP(N,KK)) + Y(K-2)=YUSR(NOP(N,KK)) + VALC(K-2)=WD(NOP(N,KK)) + ENDDO + CALL CGENTR(N,ISWT,NCNXX,X,Y,VALC,CSEL(J),XINT,YINT) + IF(ISWT .GT. 0) THEN + ILIN=ILIN+1 + DO K=1,2 + XCLIN(ILIN,K)=XINT(K) + YCLIN(ILIN,K)=YINT(K) + ENDDO + ENDIF + ENDIF + ENDIF + ENDDO + do k=1,ilin + write(199,'(2i5,4f15.3)') k,itempel(k),xclin(k,1),yclin(k,1),xclin(k,2),yclin(k,2) + enddo + +! Join up points to form contour lines + + IF(ILIN .GT. 0) CALL JLINE(ILIN,CSEL(J)) + + ENDDO + MAXPTS=MAXPTS+1 + CMAP(MAXPTS,1) = VOID + CMAP(MAXPTS,2) = VOID + XMAP(MAXPTS) = VOID + YMAP(MAXPTS) = VOID + + RETURN + + END + + SUBROUTINE CGENTR(N,ISWT,NCN,X,Y,VAL,CVAL,XINT,YINT) + +! Routine to find line (if it exists) across element N + + DIMENSION X(5),Y(5),VAL(5),XINT(2),YINT(2) + +! Get the max and min + + IF(NCN .EQ. 3) THEN + CMAX=MAX(VAL(1),VAL(2),VAL(3)) + CMIN=MIN(VAL(1),VAL(2),VAL(3)) + ELSE + CMAX=MAX(VAL(1),VAL(2),VAL(3),VAL(4)) + CMIN=MIN(VAL(1),VAL(2),VAL(3),VAL(4)) + ENDIF + +! Test if there is a contour + + IF(CVAL .LT. CMIN .OR. CVAL .GT. CMAX) THEN + +! No then return + + ISWT=0 + RETURN + ELSE + +! Yes, determine end locations + + ISWT=1 + ENDIF + +! Find the line number that it crosses + + X(NCN+1)=X(1) + Y(NCN+1)=Y(1) + VAL(NCN+1)=VAL(1) + + DO K=1,NCN + IF(CVAL .GE. VAL(K) .AND. CVAL .LT. VAL(K+1)) THEN + FRAC=(CVAL-VAL(K))/(VAL(K+1)-VAL(K)) + XINT(ISWT)=X(K)+FRAC*(X(K+1)-X(K)) + YINT(ISWT)=Y(K)+FRAC*(Y(K+1)-Y(K)) + write(199,'(2i5,4f12.4)') n,k,frac,cval,val(k),val(k+1) + ISWT=ISWT+1 + ELSEIF(CVAL .LT. VAL(K) .AND. CVAL .GE. VAL(K+1)) THEN + FRAC=(VAL(K)-CVAL)/(VAL(K)-VAL(K+1)) + XINT(ISWT)=X(K)+FRAC*(X(K+1)-X(K)) + YINT(ISWT)=Y(K)+FRAC*(Y(K+1)-Y(K)) + write(199,'(2i5,4f12.4)') n,k,frac,cval,val(k),val(k+1) + ISWT=ISWT+1 + ENDIF + + ENDDO + + RETURN + END + diff --git a/src/src83e/chck.bmp b/src/src83e/chck.bmp new file mode 100644 index 0000000..7149d76 Binary files /dev/null and b/src/src83e/chck.bmp differ diff --git a/src/src83e/deln2.f90 b/src/src83e/deln2.f90 new file mode 100644 index 0000000..baa355f --- /dev/null +++ b/src/src83e/deln2.f90 @@ -0,0 +1,239 @@ + SUBROUTINE DELN2(NVERT,ISWT1) + + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + CHARACTER*80 LIND + CHARACTER*1 ANS + DATA SPAC/0.0/ + VOID = -1.E10 + NEDGE=0 + NINTV=1 + NGAP=0 + +! Check options + + IF(ISWT1 .EQ. 0) THEN + CALL TRIANOPT(NINTV,SPAC) + ELSE + NINTV=1 + SPAC=0 + ENDIF + +! Sort points into ascending x order + + CALL SORTDB(XUSR,NKEY,NVERT) + +! Drop points based on spacing + + IF(ISWT1 .NE. 0) THEN + IF(NINTV .GT. 1 .OR. SPAC .GT. 0.) THEN + CALL DROPPTS(NVERT,NINTV,SPAC) + ENDIF + ENDIF + +! Get location of supertriangle + + iprt=0 + + call supert(XUSR,YUSR,NVERT) + + NELTS=1 + + NVERTM=NVERT-3 + +! Loop on the vertices + + DO NN=1,NVERT-3 + +! process next point + + N=NKEY(NN) +! Skip out if inactive point + IF(N .EQ. 0) GO TO 500 + IF(LIST(N) .EQ. 0) GO TO 500 + + IF(NN .LT. NVERTM) THEN + DO KK=NN+1,NVERTM + K=NKEY(KK) + IF(K .NE. 0) THEN + IF(XUSR(N) .EQ. XUSR(K)) THEN + IF(YUSR(N) .EQ. YUSR(K)) THEN + WRITE(45,*) 'IDENT',N,K + NKEY(KK)=0 + ENDIF + ELSE + GO TO 200 + ENDIF + ENDIF + 200 CONTINUE + ENDDO + ENDIF + +! Set edge buffers to zero + + IF(NEDGE .GT. 0) THEN + DO J=1,NEDGE + IEDGE(J,1)=0 + IEDGE(J,2)=0 + END DO + ELSE + DO J=1,100 + IEDGE(J,1)=0 + IEDGE(J,2)=0 + END DO + ENDIF + NEDGE=0 + +! test for point in circumcircle + + if(n .eq. 6) then + aa=0 + endif + DO J=1,NELTS + CALL INSIDCIRC(XUSR,YUSR,J,N,ISWT) + WRITE(156,*) J,N,ISWT + +! If inside process edges + + IF(ISWT .EQ. 1) THEN + CALL PROCESS(J,NEDGE,NGAP) + WRITE(156,*) J,NEDGE,NGAP + ENDIF + END DO + +! Setup to form new triangles + + CALL SETEDG(NEDGE) + +! Now form triangles as needed + + DO J=1,NEDGE + NELFM(J)=0 + IF(IEDGE(J,1) .NE. 0) THEN + CALL FORMT(XUSR,YUSR,J,N,NGAP,KK,WD) + NELFM(J)=KK + ENDIF + END DO + + DO J=1,NEDGE + IF(NELFM(J) .GT. 0) THEN + CALL TESTTR(XUSR,YUSR,NELFM(J),WD) + ENDIF + ENDDO + + NEDGE=0 + iprt=1 + if(iprt .eq. 0) go to 500 + DO J=1,NELTS + IF(NOPEL(J,1) .GT. 0) THEN + WRITE(155,'(2i5,2i10,19x,''1'')') J,(NOPEL(J,K),K=1,3) + ENDIF + END DO + ninnin=9999 +! write(150+nn,'(i5)') ninnin + +! do j=1,nvert +! write(150+nn,'(i10,f16.6,f20.6,f10.2)') j,xusr(j),yusr(j),val(j) +! enddo +! write(150+nn,'(i10)') ninnin + 500 continue + END DO + +! Get rid of elements from super point + + CALL RIDPOINT(NVERT) + + XUSR(NP+1)=VOID + XUSR(NP+2)=VOID + XUSR(NP+3)=VOID + YUSR(NP+1)=VOID + YUSR(NP+2)=VOID + YUSR(NP+3)=VOID + DO J=1,NELTS + DO K=1,3 + NOPSTO(J,2*K-1,1)=NOPEL(J,K) + NOPSTO(J,2*K,1)=0 + ENDDO + NOPSTO(J,7,1)=0 + NOPSTO(J,8,1)=0 + IMATSTO(J,1)=1 + THTASTO(J,1)=0. + ENDDO + NP=NP-3 + NPSTO(1)=NP + NESTO(1)=NELTS + +! Get edge nodes for later filling + +! IF(ISWT1 .EQ. 0) THEN +! CALL GETEDG +! ENDIF + if(iswt1 .eq. 2) then + do j=1,np + xusrsto(j,1)=xusr(j) + yusrsto(j,1)=yusr(j) + enddo + call mergemesh1(1) +! call mergemesh + endif + CALL ADDMESH(1) + + RETURN + END SUBROUTINE + + + SUBROUTINE GETEDG + + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + +! Look for edges that are duplicates + + DO N=1,NESTO(1) + DO NN=1,3 + N1=NOPEL(N,NN) + IF(NN .EQ. 3) THEN + N2=NOPEL(N,1) + ELSE + N2=NOPEL(N,NN+1) + ENDIF + + DO M=1,NESTO(1) + DO MM=1,3 + M1=NOPEL(M,MM) + IF(M1 .EQ. N2) THEN + +! Keep looking for match + + IF(MM .EQ. 3) THEN + M2=NOPEL(M,1) + ELSE + M2=NOPEL(M,MM+1) + ENDIF + IF(M2 .EQ. N1) THEN + +! We have a match, this is no edge skip out to next side + + GO TO 400 + ENDIF + ENDIF + ENDDO + ENDDO + +! No match these nodes are on an edge + + NINC(N1)=1 + NINC(N2)=1 + + 400 CONTINUE + ENDDO + ENDDO + RETURN + END \ No newline at end of file diff --git a/src/src83e/disp.bmp b/src/src83e/disp.bmp new file mode 100644 index 0000000..f2c35ee Binary files /dev/null and b/src/src83e/disp.bmp differ diff --git a/src/src83e/droppts.f90 b/src/src83e/droppts.f90 new file mode 100644 index 0000000..f013402 --- /dev/null +++ b/src/src83e/droppts.f90 @@ -0,0 +1,41 @@ + SUBROUTINE DROPPTS(NVERT,NINTV,SPAC) + + USE BLKMAP + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + + NN=0 + DO NM=1,NVERT + N=NKEY(NM) + IF(LIST(N) .EQ. 1) THEN + NN=NN+1 + IF(MOD(NN-1,NINTV) .EQ. 0) THEN + LIST(N)=1 + ELSE + LIST(N)=0 + ENDIF + ENDIF + ENDDO + + IF(SPAC .GT. 0.) THEN + DO NM=1,NVERT + N=NKEY(NM) + IF(LIST(N) .EQ. 1) THEN + IF(N .LT. NVERT) THEN + DO M=N+1,NVERT + IF(LIST(M) .EQ. 1) THEN + DISQ=(XUSR(M)-XUSR(N))**2+(XUSR(M)-XUSR(N))**2 + IF(DISQ .LT. SPAC**2) THEN + LIST(M)=0 + ENDIF + ENDIF + ENDDO + ENDIF + ENDIF + ENDDO + ENDIF + + RETURN + END diff --git a/src/src83e/form999.f90 b/src/src83e/form999.f90 new file mode 100644 index 0000000..95fd482 --- /dev/null +++ b/src/src83e/form999.f90 @@ -0,0 +1,421 @@ +!IPK NEW ROUTINE SEP 9 2006 + SUBROUTINE FORM999(ISWT9,iswtw,NELC) +! +! Generate continuity lines +! + + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD + include 'd.inc' + +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INCLUDE 'TXFRM.COM' + CHARACTER*1 IFLAG + DIMENSION DIRL(5000),IPROCES(MAXE) +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR + + DATA SPAC/10./,ieltyp/1/,ielsw/1/,iensw/0/ + +! DIST(N1,N2)=SQRT((CORD(N1,1)-CORD(N2,1))**2 & +! & +(CORD(N1,2)-CORD(N2,2))**2) +! PROJ(N1,N2,DR)= (CORD(N2,1)-CORD(N1,1))*COS(DR)+(CORD(N2,2)-CORD(N1,2))*SIN(DR) +! +! WRITE(150,*) 'IN FORM999',ISWT9,iswtw,NELC +! FLUSH(150) + if(iswtw .eq. 1) THEN + IFRMEL=0 + IGTWEL=0 + CALL ADD999(ISWT9,NELC) + RETURN + ENDIF + CALL WMessageBox(YesNo, QuestionIcon, 1,'Are 1-D elements already formed?','1-D ELEMENTS') + +! If answer 'Yes' set ifrmel to 0 +! + IF (WInfoDialog(4) .EQ. 2) then + IFRMEL=1 +!NO +! WRITE(150,*) 'GOING TO FROM1DEL' +! FLUSH(150) + CALL FORM1DEL +! WRITE(150,*) 'BACK FROM FROM1DEL' +! FLUSH(150) + + ELSE +!YES + IFRMEL=0 + + + CALL WMessageBox(YesNo, QuestionIcon, 1,'Is width data available?','WIDTH DATA') + +! If answer 'Yes' set igtwel to 0 +! + IF (WInfoDialog(4) .EQ. 2) then +!NO + IGTWEL=1 + CALL SETWID +! WRITE(150,*) 'BACK FROM SETWID' +! FLUSH(150) + ELSE +!YES + IGTWEL=0 +! CALL CCLINE(2) +! WRITE(150,*) 'GOING TO ADD999' +! FLUSH(150) + CALL ADD999(ISWT9,NELC) +! WRITE(150,*) 'BACK FROM ADD999' +! FLUSH(150) + CALL HEDR + RETURN + ENDIF + +100 CONTINUE + + ENDIF + +! GET NODAL CONNECTIONS +! WRITE(150,*) 'ABOUT TO GO TO NDNECON' +! FLUSH(150) + IERR=0 + CALL NDNECON(IERR) + +! START ALONG LINE OF ELEMENTS + + DO N=1,NTRAC + + N1=ITRAC(N) + IF(N .GT. 1) THEN + N0=ITRAC(N-1) + ENDIF + IF(N .LT. NTRAC) THEN + N2=ITRAC(N+1) + ENDIF + +! Get direction + + IF(N .EQ. 1) THEN + DIRX=XUSR(N2)-XUSR(N1) + DIRY=YUSR(N2)-YUSR(N1) + DIRL(N)=ATAN2(DIRX,-DIRY) + ELSEIF(N .EQ. NTRAC) THEN + DIRX=XUSR(N1)-XUSR(N0) + DIRY=YUSR(N1)-YUSR(N0) + DIRL(N)=ATAN2(DIRX,-DIRY) + ELSE + DIRX=XUSR(N2)-XUSR(N0) + DIRY=YUSR(N2)-YUSR(N0) + DIRL(N)=ATAN2(DIRX,-DIRY) + ENDIF + ENDDO + +! Move nodes apart adding new numbers + + DO N=1,NTRAC +! WRITE(150,*) 'STARTING NTRAC ITRAC',N,ITRAC(N) + N1=ITRAC(N) + CALL GETNOD(J) + JTRAC(N)=J +! XUSR(J)=XUSR(N1)-WIDTHD(N1)/2.*COS(DIRL(N)) +! YUSR(J)=YUSR(N1)-WIDTHD(N1)/2.*SIN(DIRL(N)) + XUSR(J)=XUSR(N1)-WIDTH(N1)/2.*COS(DIRL(N)) + YUSR(J)=YUSR(N1)-WIDTH(N1)/2.*SIN(DIRL(N)) + CORD(J,1)=(XUSR(J)+XS)/TXSCAL + CORD(J,2)=(YUSR(J)+YS)/TXSCAL + INEW(J)=1 + INSKP(J) = 0 + WD(J)=-9999. + WIDTH(J)=0. + SS1(J)=0. + SS2(J)=0. + WIDS(J)=0. + WIDBS(J)=0. + SSO(J)=0. + + CALL GETNOD(J1) + KTRAC(N)=J1 +! XUSR(J1)=XUSR(N1)+WIDTHD(N1)/2.*COS(DIRL(N)) +! YUSR(J1)=YUSR(N1)+WIDTHD(N1)/2.*SIN(DIRL(N)) + XUSR(J1)=XUSR(N1)+WIDTH(N1)/2.*COS(DIRL(N)) + YUSR(J1)=YUSR(N1)+WIDTH(N1)/2.*SIN(DIRL(N)) + CORD(J1,1)=(XUSR(J1)+XS)/TXSCAL + CORD(J1,2)=(YUSR(J1)+YS)/TXSCAL + INEW(J1)=1 + INSKP(J1) = 0 + WD(J1)=-9999. + WIDTH(J1)=0. + SS1(J1)=0. + SS2(J1)=0. + WIDS(J1)=0. + WIDBS(J1)=0. + SSO(J1)=0. + ENDDO + DO N=1,NTRAC-1 + CALL GETELM(J) + NOP(J,1)=ITRAC(N+1) + NOP(J,3)=ITRAC(N) + NOP(J,5)=JTRAC(N) + NOP(J,7)=JTRAC(N+1) + NOP(J,2)=0 + NOP(J,4)=0 + NOP(J,6)=0 + NOP(J,8)=0 + IMAT(J)=999 + NCORN(J) = 8 + IESKP(J) = 0 + CALL GETELM(J) + NOP(J,1)=ITRAC(N) + NOP(J,3)=ITRAC(N+1) + NOP(J,5)=KTRAC(N+1) + NOP(J,7)=KTRAC(N) + NOP(J,2)=0 + NOP(J,4)=0 + NOP(J,6)=0 + NOP(J,8)=0 + IMAT(J)=999 + NCORN(J) = 8 + IESKP(J) = 0 + NE = MAX(J,NE) + ENDDO + NE = MAX(J,NE) + + + RETURN + END + + SUBROUTINE FORM1DEL + + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD + include 'd.inc' + +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INCLUDE 'TXFRM.COM' + CHARACTER*1 IFLAG +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR + + CALL WMessageBox(YesNo, QuestionIcon, 1,'Are 1-D nodes already defined?','FORM 1-D ELEMENTS') + +! If answer 'Yes' set ifrmel to 0 +! + IF (WInfoDialog(4) .ne. 2) then + +! yes + CALL FRMEL(1) + ELSE +! no + CALL WMessageBox(YesNo, QuestionIcon, 1,'Use same width etc properties ?','FORM 1-D ELEMENTS') + +! If answer 'Yes' set IGWID=1 +! + IF (WInfoDialog(4) .ne. 2) then + +! yes + IGWID=1 + ELSE + IGWID=0 +! no + ENDIF + + CALL WMessageBox(OKCancel, 4, 1,'Click on each node to form elements?'//CHAR(13)// & + 'Then click quit to continue','FORM 1-D ELEMENTS') + JREF=0 + NTRAC=0 + NHTP=0 + NBRR=3 + NMESS=15 + CALL HEDR + + 100 CONTINUE + CALL XYLOC(XX,YY,IFLAG,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + GO TO 200 + ENDIF +! + IF (IFLAG .EQ. 'c') THEN +! + call getnod(j) + NTRAC=NTRAC+1 + ITRAC(NTRAC)=J + INSKP(J)=0 + CORD(J,1) = XX + CORD(J,2) = YY + INEW(J) = 1 +! + XUSR(J) = XX*TXSCAL - XS + YUSR(J) = YY*TXSCAL - YS + IF (J .GT. NP) NP = J + call pltnod(j,1) + IF(JREF .EQ.0) THEN + WIDTH(J)=50. + call nodedisp(j) + ELSE + WIDTH(J)=WIDTH(J1) + WD(J)=WD(J1) + SS1(J)=SS1(J1) + SS2(J)=SS2(J1) + WIDS(J)=WIDS(J1) + WIDBS(J)=WIDBS(J1) + SSO(J)=SSO(J1) + BS1(J)=BS1(J1) + IF(IGWID .EQ. 0) THEN + call nodedisp(j) + ENDIF + CALL PLTNOD(J,0) + call getelm(k) + NOP(K,1)=J1 + NOP(K,2)=0 + NOP(K,3)=J + NCORN(K)=3 + IMAT(K)=1 + IESKP(K) = 0 + NE = MAX(K,NE) + IERC=0 + CALL PLTELM(K,IERC) + + ENDIF + J1=J + JREF=1 + GO TO 100 + ENDIF + ENDIF + + 200 CONTINUE + call clscrn + CALL PLOTOT(1) + NHTP=1 + NMESS=0 + NBRR=0 + CALL HEDR + RETURN + END + + SUBROUTINE SETWID + + CALL FRMEL(0) + RETURN + END + + SUBROUTINE FRMEL(ISW) + + USE WINTERACTER + USE BLK1MOD + USE BLK2MOD + include 'd.inc' + +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INCLUDE 'TXFRM.COM' + CHARACTER*1 IFLAG +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + + integer :: N1,N2,N3,IERR + + NHTP=0 + NBRR=3 + NMESS=15 + CALL HEDR + + IF(ISW .EQ. 1) THEN + CALL WMessageBox(YesNo, QuestionIcon, 1,'Is width data available?','WIDTH DATA') + +! If answer 'Yes' set igtwel to 0 +! + IF (WInfoDialog(4) .EQ. 2) then +!NO + IGTWEL=1 + ELSE +!YES + IGTWEL=0 + ENDIF + ELSE + + IGTWEL=1 + ENDIF + + IF(IGTWEL .EQ. 1) THEN + CALL WMessageBox(YesNo, QuestionIcon, 1,'Use same width etc properties ?','FORM 1-D ELEMENTS') + +! If answer 'Yes' set IGWID=1 +! + IF (WInfoDialog(4) .ne. 2) then + +! yes + IGWID=1 + ELSE + IGWID=0 +! no + ENDIF + ENDIF + NTRAC=0 + 100 CONTINUE + CALL PROX(CORD(1,1),CORD(1,2),NP,XX,YY,J,IFLAG,INSKP,IBOX) + IF(IRMAIN .EQ. 1) RETURN + IF(IFLAG .EQ. 'q' .OR. (IFLAG .EQ. 'c' .AND. IBOX .EQ. 10))THEN + GO TO 200 + ENDIF +! + IF (IFLAG .EQ. 'c') THEN +! + IF(IGTWEL .EQ. 1) THEN + IF(NTRAC .EQ. 0) THEN + call nodedisp(j) + ELSE + WIDTH(J)=WIDTH(J1) + WD(J)=WD(J1) + SS1(J)=SS1(J1) + SS2(J)=SS2(J1) + WIDS(J)=WIDS(J1) + WIDBS(J)=WIDBS(J1) + SSO(J)=SSO(J1) + BS1(J)=BS1(J1) + IF(IGWID .EQ. 0) THEN + call nodedisp(j) + ENDIF + ENDIF + ENDIF + CALL PLTNOD(J,0) +! IF(ISW .EQ. 1) THEN + if(ntrac .ne. 0) then + call getelm(k) + NOP(K,1)=J1 + NOP(K,2)=0 + NOP(K,3)=J + NCORN(K)=3 + IMAT(K)=1 + IESKP(K) = 0 + NE = MAX(K,NE) + IERC=0 + CALL PLTELM(K,IERC) + ENDIF + J1=J + NTRAC=NTRAC+1 + ITRAC(NTRAC)=J + GO TO 100 + ENDIF + 200 CONTINUE + RETURN + END \ No newline at end of file diff --git a/src/src83e/formlinel.f90 b/src/src83e/formlinel.f90 new file mode 100644 index 0000000..a8c5955 --- /dev/null +++ b/src/src83e/formlinel.f90 @@ -0,0 +1,265 @@ + SUBROUTINE FORMLINEL(I1D,I2D,JST,JEND,JKP,XLENGTH,ITYPB,ICTT) +! +! Routine to create a form series of nodes along a line +! + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + INCLUDE 'TXFRM.COM' +! COMPUTE OVERALL LENGTH + REAL*8 XNEXT,YNEXT,FRAC,XCUR,YCUR,ZNEXT(3),ZCUR(3) + REAL*8 EMB + EMB=5. + TOTLEN=0. + DO J=JST,JEND-1 + TOTLEN=TOTLEN+SQRT((ALXX(J+1)-ALXX(J))**2+(ALYY(J+1)-ALYY(J))**2) + ENDDO +! ESTIMATE NUMBER OF ELEMENTS + NELTS=TOTLEN*TXSCAL/XLENGTH+1 + if(ictt .ne. 0) then + nelts=nelts+2 + if(ictt .eq. 1) then + XLENGTH=TOTLEN*TXSCAL/(NELTS-2) + else + XLENGTH=(TOTLEN*TXSCAL-EMB*2)/(NELTS-2) + ENDIF + ELSE + XLENGTH=TOTLEN*TXSCAL/NELTS + ENDIF +! GET NEW NODE LOCATIONS AND CREAT ELEMENT +! JFIST=0 + IF(JKP .EQ. 0) THEN +! JFIST=1 + CALL GETNOD(J) + JKP=J +! +! Store ALXX and ALYY into it +! + + CORD(J,1) = ALXX(1) + CORD(J,2) = ALYY(1) + WD(J)=HMID(J) + HSET(J,1)=HLEFT(1) + HSET(J,2)=HMID(1) + HSET(J,3)=HRIGHT(1) + IF(ALWD(1).GT. 0.) THEN + WIDTHD(J)=ALWD(1) + ENDIF + INEW(J) = 1 + INSKP(J) = 0 +! + XUSR(J) = ALXX(1)*TXSCAL - XS + YUSR(J) = ALYY(1)*TXSCAL - YS +! +! Display point +! + ENDIF + CALL PLTNOD(JKP,1) + JPTC=JST+1 + XLENGTHR=XLENGTH/TXSCAL + XCUR=ALXX(JST) + YCUR=ALYY(JST) + DO N=1,NELTS + IF(NELTS .EQ. 1) THEN + XNEXT=ALXX(JEND) + YNEXT=ALYY(JEND) + if(ictt .eq. 0) then + ZNEXT(1)=HLEFT(JEND) + ZNEXT(2)=HMID(JEND) + ZNEXT(3)=HRIGHT(JEND) + else + ZNEXT(1)=HLEFT(JST) + ZNEXT(2)=HMID(JST) + ZNEXT(3)=HRIGHT(JST) + endif + CALL GETNOD(J) + + IF(ALWD(J).GT. 0.) THEN + WIDTHD(J)=ALWD(JEND) + ENDIF + ELSEIF(N .EQ. 1 .AND. ICTT .NE. 0) THEN + IF(ICTT .EQ. 1) THEN + XNEXT=XCUR + YNEXT=YCUR + ZCUR(1)=HLEFT(JST) + ZCUR(2)=HMID(JST) + ZCUR(3)=HRIGHT(JST) + ZNEXT(1)=HLEFT(JST) + ZNEXT(2)=HMID(JST) + ZNEXT(3)=HRIGHT(JST) + ELSE + ANGLEL=ATAN2(ALYY(JPTC)-ALYY(JPTC-1),ALXX(JPTC)-ALXX(JPTC-1)) + XNEXT=XCUR+EMB/TXSCAL*COS(ANGLEL) + YNEXT=YCUR+EMB/TXSCAL*SIN(ANGLEL) + ZCUR(1)=HLEFT(JST) + ZCUR(2)=HMID(JST) + ZCUR(3)=HRIGHT(JST) + ENDIF + CALL GETNOD(J) + IF(ALWD(J).GT. 0.) THEN + WIDTHD(J)=ALWD(JST) + ENDIF +! ELSEIF(N .EQ. 1 .AND. ICTT .EQ. 0) THEN +! ANGLEL=ATAN2(ALYY(JPTC)-ALYY(JPTC-1),ALXX(JPTC)-ALXX(JPTC-1)) +! XNEXT=XCUR+EMB/TXSCAL*COS(ANGLEL) +! YNEXT=YCUR+EMB/TXSCAL*SIN(ANGLEL) +! ZCUR(1)=HLEFT(JST+1) +! ZCUR(2)=HMID(JST+1) +! ZCUR(3)=HRIGHT(JST+1) +! CALL GETNOD(J) +! IF(ALWD(J).GT. 0.) THEN +! WIDTHD(J)=ALWD(JST+1) +! ENDIF + ELSEIF(N .EQ. NELTS .AND. ICTT .NE. 0) THEN + IF(ICTT .EQ. 1) THEN + XNEXT=ALXX(JEND) + YNEXT=ALYY(JEND) + ZCUR(1)=HLEFT(JEND) + ZCUR(2)=HMID(JEND) + ZCUR(3)=HRIGHT(JEND) + ZNEXT(1)=ZCUR(1) + ZNEXT(2)=ZCUR(2) + ZNEXT(3)=ZCUR(3) + ELSE + XNEXT=ALXX(JEND) + YNEXT=ALYY(JEND) + ZCUR(1)=HLEFT(JEND) + ZCUR(2)=HMID(JEND) + ZCUR(3)=HRIGHT(JEND) + ENDIF + CALL GETNOD(J) + IF(ALWD(J).GT. 0.) THEN + WIDTHD(J)=ALWD(JST) + ENDIF + ELSE + 500 ANGLEL=ATAN2(ALYY(JPTC)-ALYY(JPTC-1),ALXX(JPTC)-ALXX(JPTC-1)) + XNEXT=XCUR+XLENGTHR*COS(ANGLEL) + YNEXT=YCUR+XLENGTHR*SIN(ANGLEL) + IF(ALXX(JPTC)-ALXX(JPTC-1) .NE. 0.) THEN + FRAC=(XNEXT-ALXX(JPTC-1))/(ALXX(JPTC)-ALXX(JPTC-1)) + ELSEIF(ALYY(JPTC)-ALYY(JPTC-1) .NE. 0.) THEN + FRAC=(YNEXT-ALYY(JPTC-1))/(ALYY(JPTC)-ALYY(JPTC-1)) + ELSE + FRAC=1.5 + ENDIF + + IF(FRAC .GT. 1.00001 .AND. JPTC .LT. JEND) THEN + XLENGTHR=XLENGTHR-SQRT((ALXX(JPTC)-XCUR)**2+(ALYY(JPTC)-YCUR)**2) + XCUR=ALXX(JPTC) + YCUR=ALYY(JPTC) + ZCUR(1)=HLEFT(JPTC) + ZCUR(2)=HMID(JPTC) + ZCUR(3)=HRIGHT(JPTC) + JPTC=JPTC+1 + GO TO 500 + ENDIF + if(n .eq. nelts .and. ictt .eq. 0) then + ZNEXT(1)=HLEFT(JPTC-1) + ZNEXT(2)=HMID(JPTC-1) + ZNEXT(3)=HRIGHT(JPTC-1) + else + ZNEXT(1)=HLEFT(JPTC-1)+FRAC*(HLEFT(JPTC)-HLEFT(JPTC-1)) + ZNEXT(2)=HMID(JPTC-1)+FRAC*(HMID(JPTC)-HMID(JPTC-1)) + ZNEXT(3)=HRIGHT(JPTC-1)+FRAC*(HRIGHT(JPTC)-HRIGHT(JPTC-1)) + endif + if(ictt .eq. 2) then + ZNEXT(1)=-9999. + ZNEXT(2)=-9999. + ZNEXT(3)=-9999. + endif +! GET NEW LOCATION + + CALL GETNOD(J) + + IF(ALWD(1).GT. 0.) THEN + WIDTHD(J)=ALWD(JPTC-1)+FRAC*(ALWD(JPTC)-ALWD(JPTC-1)) + ENDIF + ENDIF +! +! Store GRIDX and GRIDY into it +! + CORD(J,1) = XNEXT + CORD(J,2) = YNEXT + WD(J)=ZNEXT(2) + HSET(J,1)=ZNEXT(1) + HSET(J,2)=ZNEXT(2) + HSET(J,3)=ZNEXT(3) + INEW(J) = 1 + INSKP(J) = 0 +! + XUSR(J) = XNEXT*TXSCAL - XS + YUSR(J) = YNEXT*TXSCAL - YS +! +! Display point +! + CALL PLTNOD(J,1) + XCUR=XNEXT + YCUR=YNEXT + XLENGTHR=XLENGTH/TXSCAL + + IF(I1D .EQ. 1 .OR. I2D .EQ. 1) THEN + IF(N .EQ. 1) THEN + J1=JKP + IF(ALWD(1) .NE. 0.) GO TO 600 + call nodedisp(jKP) + ENDIF + IF(ALWD(1) .NE. 0.) GO TO 600 + WIDTHD(J)=WIDTHD(J1) + WD(J)=WD(J1) + SS1(J)=SS1(J1) + SS2(J)=SS2(J1) + WIDS(J)=WIDS(J1) + WIDBS(J)=WIDBS(J1) + SSO(J)=SSO(J1) + BS1(J)=BS1(J1) +600 CONTINUE +! IF(N .EQ. 1 .AND. ICTT .EQ. 1) THEN +! J1=J +! CYCLE +! ELSEIF(N .EQ. NELTS .AND. ICTT .EQ. 1) THEN + IF(N .EQ. NELTS .AND. ICTT .EQ. 1) THEN + WIDTHD(J1)=WIDTHD(J) + WD(J1)=WD(J) + SS1(J1)=SS1(J) + SS2(J1)=SS2(J) + WIDS(J1)=WIDS(J) + WIDBS(J1)=WIDBS(J) + SSO(J1)=SSO(J) + BS1(J1)=BS1(J) + XUSR(J1)=XUSR(J) + YUSR(J1)=YUSR(J) + CORD(J1,1)=CORD(J,1) + CORD(J1,2)=CORD(J,2) + HSET(J1,1)=HSET(J,1) + HSET(J1,2)=HSET(J,2) + HSET(J1,3)=HSET(J,3) + ENDIF + call getelm(k) + if(n .eq. 1 .and. ictt .eq. 0 .and. jst .ne. 1) then + wd(j1)=wd(j) + hset(j1,1)=hset(j,1) + hset(j1,2)=hset(j,2) + hset(j1,3)=hset(j,3) + endif + NOP(K,1)=J1 + NOP(K,2)=0 + NOP(K,3)=J + NCORN(K)=3 + IMAT(K)=ITYPB + if(ictt .eq. 1) then + if(n .eq. 1) imat(k)= 2000 + if(n .eq. nelts) imat(k)= 2001 + endif + IESKP(K) = 0 + NE = MAX(K,NE) + IERC=0 + CALL PLTELM(K,IERC) + J1=J + ENDIF + + ENDDO + JKP=J + RETURN + END + + \ No newline at end of file diff --git a/src/src83e/frmnodt.f90 b/src/src83e/frmnodt.f90 new file mode 100644 index 0000000..6874960 --- /dev/null +++ b/src/src83e/frmnodt.f90 @@ -0,0 +1,58 @@ + SUBROUTINE FRMNODT(X1,Y1,X2,Y2,X3,Y3,NPTS) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + +! X1,X2,X3 AND Y1,Y2,Y3 are vertices of triangle +! NPTS is the nominal number of elements on each side + + +! Work along first side AND backwards along second line + + DO N=1,NPTS-1 + RATIO=FLOAT(N)/FLOAT(NPTS) + X12=X1+RATIO*(X2-X1) + Y12=Y1+RATIO*(Y2-Y1) + X32=X3+RATIO*(X2-X3) + Y32=Y3+RATIO*(Y2-Y3) + +! Now get interior points + + NINT=NPTS-N + DO M=1,NINT-1 + RATIO=FLOAT(M)/FLOAT(NINT) + XNEW=X12+RATIO*(X32-X12) + YNEW=Y12+RATIO*(Y32-Y12) + CALL DEFNOD(XNEW,YNEW) + ENDDO + ENDDO + RETURN + END + + SUBROUTINE DEFNOD(XNEW,YNEW) + + USE BLK1MOD + USE BLK2MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'BLK2.COM' + INCLUDE 'TXFRM.COM' + + CALL GETNOD(N2) + CORD(N2,1) = XNEW + CORD(N2,2) = YNEW + WD(N2)=-9999. + WIDTH(N2) = 0. + SS1(N2)=0. + SS2(N2)=0. + WIDS(N2)=0. + BS1(N2)=0. + INSKP(N2)=0 + INEW(N2) = 1 +! + XUSR(N2) = CORD(N2,1)*TXSCAL - XS + YUSR(N2) = CORD(N2,2)*TXSCAL - YS + LIST(N2)=1 + CALL PLTNOD(N2,1) + + RETURN + END \ No newline at end of file diff --git a/src/src83e/getlaydat.f90 b/src/src83e/getlaydat.f90 new file mode 100644 index 0000000..831f520 --- /dev/null +++ b/src/src83e/getlaydat.f90 @@ -0,0 +1,58 @@ + SUBROUTINE GETLAYDAT(NLAY,ipos,rlay) + + use winteracter + + implicit none + + include 'D.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: IPOS,NLAY,I + INTEGER :: JNK,ierr + REAL :: rlay(9) + + call wdialogload(IDD_LAY) + ierr=infoerror(1) + + + IF(IPOS .EQ. 1) THEN + call wdialogputRadioButton(idf_radio1) + ELSE + call wdialogputRadioButton(idf_radio2) + ENDIF + CALL WDialogPutINTEGER(IDF_INTEGER1,NLAY) + do i=1,7 + CALL WGridPutCellReal(IDF_GRID1,i,1,rlay(i)) + enddo + + + CALL WDialogSelect(IDD_LAY) + ierr=infoerror(1) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + + do + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + call wdialoggetradiobutton(idf_radio1,ipos) + + CALL WDialogGetINTEGER(IDF_INTEGER1,NLAY) + do i=1,7 + CALL WGridGetCellReal(IDF_GRID1,i,1,rlay(i)) + enddo + return + ELSEIF (WInfoDialog(ExitButton) .EQ. IDCANCEL) THEN + RETURN + endif +!IPK SEP02 + return + enddo + RETURN + END diff --git a/src/src83e/interpelv.f90 b/src/src83e/interpelv.f90 new file mode 100644 index 0000000..1b393e4 --- /dev/null +++ b/src/src83e/interpelv.f90 @@ -0,0 +1,78 @@ + SUBROUTINE INTERPWLV(NODE1,H,ARIV,WRIV,DWRIV) + + USE BLK1MOD +! INCLUDE 'BLK1.COM' + + NLSEC11=NRIVCR1(node1) + IF(NRIVL(NLSEC11) .EQ. 0) THEN + IF(WTRIVCR1(node1) .gt. 0.) THEN + ARIV=0. + WRIV=0. + RETURN + ELSE + A11=0. + W11=0. + DW11=0. + GO TO 272 + ENDIF + ENDIF + DO K=2,NRIVL(NLSEC11) + DEPL=CRSDAT(NLSEC11,K,1)-CRSDAT(NLSEC11,1,1) + IF(DEPL .GT. H) THEN + FRAC= (H+CRSDAT(NLSEC11,1,1)-CRSDAT(NLSEC11,K-1,1))/& + (CRSDAT(NLSEC11,K,1)-CRSDAT(NLSEC11,K-1,1)) + A11=CRSDAT(NLSEC11,K-1,2)*(1.-FRAC) +& + CRSDAT(NLSEC11,K,2)*FRAC + W11=CRSDAT(NLSEC11,K-1,3)*(1.-FRAC) +& + CRSDAT(NLSEC11,K,3)*FRAC + DW11=(CRSDAT(NLSEC11,K,3)-CRSDAT(NLSEC11,K-1,3))/& + (CRSDAT(NLSEC11,K,1)-CRSDAT(NLSEC11,K-1,1)) + GO TO 272 + ENDIF + ENDDO + +!IPK MAY04 ALLOW FOR LEVEL ABOVE HIGHEST LAYER + + W11=CRSDAT(NLSEC11,NRIVL(NLSEC11),3) + DW11=0. + A11=CRSDAT(NLSEC11,NRIVL(NLSEC11),2)+W11*(H-DEPL) + + 272 CONTINUE + NLSEC12=NRIVCR2(node1) + IF(NRIVL(NLSEC12) .EQ. 0) THEN + IF(WTRIVCR2(node1) .gt. 0.) THEN + ARIV=0. + WRIV=0. + RETURN + ELSE + A12=0. + W12=0. + DW12=0. + GO TO 274 + ENDIF + ENDIF + DO K=2,NRIVL(NLSEC12) + DEPL=CRSDAT(NLSEC12,K,1)-CRSDAT(NLSEC12,1,1) + IF(DEPL .GT. H) THEN + FRAC= (H+CRSDAT(NLSEC12,1,1)-CRSDAT(NLSEC12,K-1,1))/& + (CRSDAT(NLSEC12,K,1)-CRSDAT(NLSEC12,K-1,1)) + A12=CRSDAT(NLSEC12,K-1,2)*(1.-FRAC) +& + CRSDAT(NLSEC12,K,2)*FRAC + W12=CRSDAT(NLSEC12,K-1,3)*(1.-FRAC) +& + CRSDAT(NLSEC12,K,3)*FRAC + DW12=(CRSDAT(NLSEC12,K,3)-CRSDAT(NLSEC12,K-1,3))/& + (CRSDAT(NLSEC12,K,1)-CRSDAT(NLSEC12,K-1,1)) + GO TO 274 + ENDIF + ENDDO +!IPK MAY04 ALLOW FOR LEVEL ABOVE HIGHEST LAYER + W12=CRSDAT(NLSEC12,NRIVL(NLSEC12),3) + DW12=0. + A12=CRSDAT(NLSEC12,NRIVL(NLSEC12),2)+W12*(H-DEPL) + 274 CONTINUE + ARIV=WTRIVCR1(node1)*A11+WTRIVCR2(node1)*A12 + WRIV=WTRIVCR1(node1)*W11+WTRIVCR2(node1)*W12 + DWRIV=WTRIVCR1(node1)*DW11+WTRIVCR2(node1)*DW12 + + 300 RETURN + END \ No newline at end of file diff --git a/src/src83e/resource.fd b/src/src83e/resource.fd new file mode 100644 index 0000000..c22a66d --- /dev/null +++ b/src/src83e/resource.fd @@ -0,0 +1,276 @@ +!MS$FREEFORM +! Microsoft Developer Studio generated include file. +! Used by rmagen73f.RC +! + integer, parameter :: IDD_DIALOG1 = 101 + integer, parameter :: IDD_DIALOG02 = 102 + integer, parameter :: IDD_DIALOG05 = 103 + integer, parameter :: IDD_DIALOG04 = 104 + integer, parameter :: IDD_DIALOG006 = 105 + integer, parameter :: IDD_DIALOG07 = 106 + integer, parameter :: IDD_DIALOG08 = 107 + integer, parameter :: IDD_DIALOG09 = 108 + integer, parameter :: IDD_DIALOG10 = 109 + integer, parameter :: IDD_DIALOG010 = 110 + integer, parameter :: IDD_DIALOG001 = 111 + integer, parameter :: IDD_REGST = 112 + integer, parameter :: IDD_DIALOG012 = 113 + integer, parameter :: IDD_SLRGNO = 114 + integer, parameter :: IDD_CONFIRM = 115 + integer, parameter :: IDD_nodedata = 116 + integer, parameter :: IDD_eltdata = 117 + integer, parameter :: IDD_SELNODE = 118 + integer, parameter :: IDD_SELELT = 119 + integer, parameter :: IDD_ELTERR = 120 + integer, parameter :: IDD_headertp = 121 + integer, parameter :: IDD_TRIAN = 122 + integer, parameter :: IDD_NODERR = 123 + integer, parameter :: IDD_TRIANG = 124 + integer, parameter :: IDD_QUAD = 125 + integer, parameter :: IDD_DIALOG06 = 126 + integer, parameter :: IDD_CSLOC = 127 + integer, parameter :: IDD_CREATM = 128 + integer, parameter :: IDD_TEMPLATE001 = 129 + integer, parameter :: IDD_CREATM1 = 130 + integer, parameter :: IDD_ORDEROUT = 131 + integer, parameter :: IDD_TEMPLATE002 = 132 + integer, parameter :: IDD_selcrsec = 133 + integer, parameter :: IDD_TEMPLATE003 = 134 + integer, parameter :: IDD_LIMITS = 135 + integer, parameter :: IDD_lAY = 136 + integer, parameter :: IDD_TEMPLATE004 = 137 + integer, parameter :: IDD_SELTFL2 = 148 + integer, parameter :: IDD_GETINT = 153 + integer, parameter :: IDD_GETFPN = 154 + integer, parameter :: IDD_GETINTP = 160 + integer, parameter :: IDF_LABEL1 = 1001 + integer, parameter :: IDF_LABEL2 = 1002 + integer, parameter :: IDF_LABEL3 = 1003 + integer, parameter :: IDF_LABEL4 = 1004 + integer, parameter :: IDF_CMAP8 = 1005 + integer, parameter :: IDF_LABEL6 = 1005 + integer, parameter :: IDF_CMAP9 = 1006 + integer, parameter :: IDF_LABEL8 = 1006 + integer, parameter :: IDF_CMAP0 = 1007 + integer, parameter :: IDF_LABEL9 = 1007 + integer, parameter :: IDF_CMAP1 = 1008 + integer, parameter :: IDF_LABEL10 = 1008 + integer, parameter :: IDF_CMAP2 = 1009 + integer, parameter :: IDF_LABEL12 = 1009 + integer, parameter :: IDF_CMAP10 = 1010 + integer, parameter :: IDF_CMAP11 = 1011 + integer, parameter :: IDF_CMAP3 = 1012 + integer, parameter :: IDF_STRING1 = 1013 + integer, parameter :: IDF_STRING2 = 1014 + integer, parameter :: IDF_STRING3 = 1015 + integer, parameter :: IDF_STRING4 = 1016 + integer, parameter :: IDF_STRING5 = 1017 + integer, parameter :: IDF_STRING6 = 1018 + integer, parameter :: IDF_STRING7 = 1019 + integer, parameter :: IDF_STRING8 = 1020 + integer, parameter :: IDF_STRING9 = 1021 + integer, parameter :: IDF_STRING10 = 1022 + integer, parameter :: IDF_STRING11 = 1023 + integer, parameter :: IDF_STRING12 = 1024 + integer, parameter :: IDF_STRING13 = 1025 + integer, parameter :: IDF_STRING14 = 1026 + integer, parameter :: IDF_STRING15 = 1027 + integer, parameter :: IDF_STRING16 = 1028 + integer, parameter :: IDF_STRING17 = 1029 + integer, parameter :: IDF_STRING18 = 1030 + integer, parameter :: IDF_STRING19 = 1031 + integer, parameter :: IDF_STRING20 = 1032 + integer, parameter :: IDF_STRING21 = 1033 + integer, parameter :: IDF_STRING22 = 1034 + integer, parameter :: IDF_STRING23 = 1035 + integer, parameter :: IDF_CHECK1 = 1036 + integer, parameter :: IDF_CHECK2 = 1037 + integer, parameter :: IDF_CHECK3 = 1038 + integer, parameter :: IDF_CHECK4 = 1039 + integer, parameter :: IDF_CHECK5 = 1040 + integer, parameter :: IDF_STRING24 = 1041 + integer, parameter :: IDF_CHECK6 = 1041 + integer, parameter :: IDF_LABEL5 = 1042 + integer, parameter :: IDF_CHECK7 = 1042 + integer, parameter :: IDF_STRING35 = 1042 + integer, parameter :: IDF_CMAP4 = 1043 + integer, parameter :: IDF_CHECK8 = 1043 + integer, parameter :: IDF_LABEL11 = 1043 + integer, parameter :: IDF_CMAP5 = 1044 + integer, parameter :: IDF_CHECK9 = 1044 + integer, parameter :: IDF_CMAP6 = 1045 + integer, parameter :: IDF_CHECK10 = 1045 + integer, parameter :: IDF_CMAP7 = 1046 + integer, parameter :: IDF_RADIO1 = 1047 + integer, parameter :: IDF_RADIO2 = 1048 + integer, parameter :: IDF_RADIO3 = 1049 + integer, parameter :: IDF_RADIO4 = 1050 + integer, parameter :: IDF_RADIO5 = 1051 + integer, parameter :: IDF_RADIO6 = 1052 + integer, parameter :: IDF_RADIO7 = 1053 + integer, parameter :: IDF_RADIO8 = 1054 + integer, parameter :: IDF_RADIO9 = 1055 + integer, parameter :: IDF_LABEL7 = 1056 + integer, parameter :: IDF_RADIO10 = 1056 + integer, parameter :: IDF_INTEGER1 = 1057 + integer, parameter :: IDF_RADIO11 = 1057 + integer, parameter :: IDF_INTEGER2 = 1058 + integer, parameter :: IDF_RADIO12 = 1058 + integer, parameter :: IDF_CHECK11 = 1059 + integer, parameter :: IDF_INTEGER3 = 1059 + integer, parameter :: IDF_RADIO17 = 1059 + integer, parameter :: IDF_REAL1 = 1060 + integer, parameter :: IDF_INTEGER4 = 1060 + integer, parameter :: IDF_REAL2 = 1061 + integer, parameter :: IDF_INTEGER5 = 1061 + integer, parameter :: IDF_REAL3 = 1062 + integer, parameter :: IDF_INTEGER6 = 1062 + integer, parameter :: IDF_RADIO18 = 1062 + integer, parameter :: IDF_REAL4 = 1063 + integer, parameter :: IDF_INTEGER7 = 1063 + integer, parameter :: IDF_REAL5 = 1064 + integer, parameter :: IDF_INTEGER8 = 1064 + integer, parameter :: IDF_REAL6 = 1065 + integer, parameter :: IDF_REAL7 = 1066 + integer, parameter :: IDF_REAL8 = 1067 + integer, parameter :: IDADJUST = 1068 + integer, parameter :: IDF_REAL9 = 1068 + integer, parameter :: IDFSWITCH = 1069 + integer, parameter :: IDF_REAL10 = 1069 + integer, parameter :: IDF_INTEGER9 = 1070 + integer, parameter :: IDF_INTEGER10 = 1071 + integer, parameter :: IDNEXT = 1072 + integer, parameter :: IDF_Delete = 1073 + integer, parameter :: IDFROTATE = 1074 + integer, parameter :: IDF_GRID1 = 1075 + integer, parameter :: IDF_RADIO13 = 1076 + integer, parameter :: ISS1 = 1077 + integer, parameter :: ISS2 = 1078 + integer, parameter :: ISS3 = 1079 + integer, parameter :: IDF_RADIO14 = 1080 + integer, parameter :: IDF_RADIO15 = 1081 + integer, parameter :: IDF_RADIO16 = 1082 + integer, parameter :: ISS4 = 1083 + integer, parameter :: ISS5 = 1084 + integer, parameter :: ISS6 = 1085 + integer, parameter :: ISS7 = 1086 + integer, parameter :: IDF_STRING25 = 1106 + integer, parameter :: IDF_STRING26 = 1107 + integer, parameter :: IDF_STRING27 = 1108 + integer, parameter :: IDF_STRING28 = 1109 + integer, parameter :: IDF_STRING29 = 1110 + integer, parameter :: IDF_STRING30 = 1111 + integer, parameter :: IDF_STRING31 = 1112 + integer, parameter :: IDF_STRING32 = 1113 + integer, parameter :: IDF_STRING33 = 1114 + integer, parameter :: IDF_STRING34 = 1115 + integer, parameter :: id_chck = 2001 + integer, parameter :: id_chk = 2002 + integer, parameter :: idchk = 2003 + integer, parameter :: IDC_BUTTON2 = 20001 + integer, parameter :: IDR_MENU1 = 30001 + integer, parameter :: ID_TOOLBAR1 = 30101 + integer, parameter :: ID_FILE = 40001 + integer, parameter :: ID_EXIT = 40002 + integer, parameter :: ID_NODE = 40003 + integer, parameter :: ID_ELTS = 40004 + integer, parameter :: ID_ORDRT = 40005 + integer, parameter :: ID_CCLN = 40006 + integer, parameter :: ID_CSEC1 = 40007 + integer, parameter :: ID_ZOOM = 40008 + integer, parameter :: ID_DRAW = 40009 + integer, parameter :: ID_HELP = 40010 + integer, parameter :: ID_ITEM11 = 40011 + integer, parameter :: ID_ITEM12 = 40012 + integer, parameter :: ID_ITEM13 = 40013 + integer, parameter :: ID_ITEM14 = 40014 + integer, parameter :: ID_ITEM15 = 40015 + integer, parameter :: ID_ITEM16 = 40016 + integer, parameter :: ID_ITEM17 = 40017 + integer, parameter :: ID_ITEM18 = 40018 + integer, parameter :: ID_ITEM19 = 40019 + integer, parameter :: ID_Clip = 40020 + integer, parameter :: ID_ITEM20 = 40021 + integer, parameter :: ID_ITEM73 = 40022 + integer, parameter :: ID_ITEM23 = 40023 + integer, parameter :: ID_ITEM24 = 40024 + integer, parameter :: ID_ZIN = 40025 + integer, parameter :: ID_ZOUT = 40026 + integer, parameter :: ID_OUT2 = 40027 + integer, parameter :: ID_OUT4 = 40028 + integer, parameter :: ID_RSET = 40029 + integer, parameter :: ID_UNDOM = 40030 + integer, parameter :: ID_PLEFT = 40031 + integer, parameter :: ID_PRIGHT = 40032 + integer, parameter :: ID_PUP = 40033 + integer, parameter :: ID_PDOWN = 40034 + integer, parameter :: ID_IDRWT = 40035 + integer, parameter :: ID_BSEL = 40036 + integer, parameter :: ID_REGST = 40037 + integer, parameter :: ID_network = 40038 + integer, parameter :: ID_TYPD = 40039 + integer, parameter :: ID_Help1 = 40040 + integer, parameter :: ID_DRAWD = 40041 + integer, parameter :: ID_MAPOPD = 40042 + integer, parameter :: ID_MMAP = 40043 + integer, parameter :: ID_Help2 = 40044 + integer, parameter :: ID_NMAP = 40045 + integer, parameter :: ID_LAYFL = 40046 + integer, parameter :: ID_BKF = 40047 + integer, parameter :: ID_ITEM56 = 40048 + integer, parameter :: ID_Nodedata = 40049 + integer, parameter :: ID_BACGD = 40050 + integer, parameter :: ID_Eltdata = 40051 + integer, parameter :: ID_DRAG = 40052 + integer, parameter :: ID_GETELM = 40053 + integer, parameter :: ID_mapm = 40054 + integer, parameter :: ID_map = 40055 + integer, parameter :: ID_DCONTR = 40056 + integer, parameter :: ID_SBIN = 40057 + integer, parameter :: ID_TRIAN = 40058 + integer, parameter :: ID_SWMAP = 40059 + integer, parameter :: ID_CONTR = 40060 + integer, parameter :: ID_CONTOPT = 40061 + integer, parameter :: ID_SWRM1 = 40062 + integer, parameter :: ID_LOADRM1 = 40063 + integer, parameter :: ID_ITYPN = 40064 + integer, parameter :: ID_ITYPC = 40065 + integer, parameter :: ID_cdata = 40066 + integer, parameter :: ID_ICOPY = 40067 + integer, parameter :: ID_SELRM1 = 40068 + integer, parameter :: ID_addmesh = 40069 + integer, parameter :: ID_MRGMESH = 40070 + integer, parameter :: ID_ITEM26 = 40071 + integer, parameter :: ID_ITEM22 = 40072 + integer, parameter :: ID_ALLNODES = 40073 + integer, parameter :: ID_UNUSNODES = 40074 + integer, parameter :: ID_TRIANG = 40075 + integer, parameter :: ID_QUAD = 40076 + integer, parameter :: ID_CSEC = 40077 + integer, parameter :: ID_CRSCAL = 40078 + integer, parameter :: ID_SAVCRS = 40079 + integer, parameter :: ID_crsf = 40080 + integer, parameter :: ID_CSLOC = 40081 + integer, parameter :: ID_UNDO = 40082 + integer, parameter :: ID_UNDOS = 40083 + integer, parameter :: ID_CREATM = 40084 + integer, parameter :: ID_CGEN = 40085 + integer, parameter :: ID_selarea = 40086 + integer, parameter :: ID_crsect = 40087 + integer, parameter :: ID_EDLAY = 40088 + integer, parameter :: ID_ORDR = 40089 + integer, parameter :: ID_ORDR1 = 40090 + integer, parameter :: ID_FILL = 40102 + integer, parameter :: ID_DELM = 40103 + integer, parameter :: ID_JOIN = 40104 + integer, parameter :: ID_STRING1 = 50001 + integer, parameter :: ID_STRING2 = 50002 + integer, parameter :: ID_STRING3 = 50003 + integer, parameter :: ID_STRING4 = 50004 + integer, parameter :: ID_STRING5 = 50005 + integer, parameter :: ID_STRING6 = 50006 + integer, parameter :: ID_STRING7 = 50007 + integer, parameter :: ID_STRING8 = 50008 + integer, parameter :: ID_STRING9 = 50009 + integer, parameter :: ID_STRING10 = 50010 + integer, parameter :: ID_STRING11 = 50011 diff --git a/src/src83e/resource.h b/src/src83e/resource.h new file mode 100644 index 0000000..a06556d --- /dev/null +++ b/src/src83e/resource.h @@ -0,0 +1,424 @@ +//{{NO_DEPENDENCIES}} +// Microsoft Visual C++ generated include file. +// Used by AC.rc +// +#define TCS_TABS 0x0000 +#define TCS_SINGLELINE 0x0000 +#define TCS_RIGHTJUSTIFY 0x0000 +#define TBS_HORZ 0x0000 +#define TBS_BOTTOM 0x0000 +#define TBS_RIGHT 0x0000 +#define IDOK 1 +#define TBS_AUTOTICKS 0x0001 +#define TVS_HASBUTTONS 0x0001 +#define VK_LBUTTON 0x01 +#define IDCANCEL 2 +#define TBS_VERT 0x0002 +#define TVS_HASLINES 0x0002 +#define VK_RBUTTON 0x02 +#define IDABORT 3 +#define VK_CANCEL 0x03 +#define IDRETRY 4 +#define TBS_TOP 0x0004 +#define TBS_LEFT 0x0004 +#define TVS_LINESATROOT 0x0004 +#define VK_MBUTTON 0x04 +#define IDIGNORE 5 +#define IDYES 6 +#define IDNO 7 +#define IDCLOSE 8 +#define TBS_BOTH 0x0008 +#define TVS_EDITLABELS 0x0008 +#define VK_BACK 0x08 +#define IDHELP 9 +#define VK_TAB 0x09 +#define VK_CLEAR 0x0C +#define VK_RETURN 0x0D +#define TBS_NOTICKS 0x0010 +#define TVS_DISABLEDRAGDROP 0x0010 +#define VK_SHIFT 0x10 +#define VK_CONTROL 0x11 +#define VK_MENU 0x12 +#define VK_PAUSE 0x13 +#define VK_CAPITAL 0x14 +#define VK_ESCAPE 0x1B +#define TBS_ENABLESELRANGE 0x0020 +#define TVS_SHOWSELALWAYS 0x0020 +#define VK_SPACE 0x20 +#define VK_PRIOR 0x21 +#define VK_NEXT 0x22 +#define VK_END 0x23 +#define VK_HOME 0x24 +#define VK_LEFT 0x25 +#define VK_UP 0x26 +#define VK_RIGHT 0x27 +#define VK_DOWN 0x28 +#define VK_SELECT 0x29 +#define VK_PRINT 0x2A +#define VK_EXECUTE 0x2B +#define VK_SNAPSHOT 0x2C +#define VK_INSERT 0x2D +#define VK_DELETE 0x2E +#define VK_HELP 0x2F +#define TBS_FIXEDLENGTH 0x0040 +#define VK_NUMPAD0 0x60 +#define VK_NUMPAD1 0x61 +#define VK_NUMPAD2 0x62 +#define VK_NUMPAD3 0x63 +#define VK_NUMPAD4 0x64 +#define VK_NUMPAD5 0x65 +#define IDD_DIALOG1 101 +#define VK_NUMPAD6 0x66 +#define IDD_DIALOG02 102 +#define VK_NUMPAD7 0x67 +#define IDD_DIALOG05 103 +#define VK_NUMPAD8 0x68 +#define IDD_DIALOG04 104 +#define VK_NUMPAD9 0x69 +#define IDD_DIALOG006 105 +#define VK_MULTIPLY 0x6A +#define IDD_DIALOG07 106 +#define VK_ADD 0x6B +#define IDD_DIALOG08 107 +#define VK_SEPARATOR 0x6C +#define IDD_DIALOG09 108 +#define VK_SUBTRACT 0x6D +#define IDD_DIALOG10 109 +#define VK_DECIMAL 0x6E +#define IDD_DIALOG010 110 +#define VK_DIVIDE 0x6F +#define IDD_DIALOG001 111 +#define VK_F1 0x70 +#define IDD_REGST 112 +#define VK_F2 0x71 +#define IDD_DIALOG012 113 +#define VK_F3 0x72 +#define IDD_SLRGNO 114 +#define VK_F4 0x73 +#define IDD_CONFIRM 115 +#define VK_F5 0x74 +#define IDD_nodedata 116 +#define VK_F6 0x75 +#define IDD_eltdata 117 +#define VK_F7 0x76 +#define IDD_SELNODE 118 +#define VK_F8 0x77 +#define IDD_SELELT 119 +#define VK_F9 0x78 +#define IDD_ELTERR 120 +#define VK_F10 0x79 +#define IDD_headertp 121 +#define VK_F11 0x7A +#define IDD_TRIAN 122 +#define VK_F12 0x7B +#define IDD_NODERR 123 +#define VK_F13 0x7C +#define IDD_TRIANG 124 +#define VK_F14 0x7D +#define IDD_QUAD 125 +#define VK_F15 0x7E +#define IDD_DIALOG06 126 +#define VK_F16 0x7F +#define IDD_CSLOC 127 +#define TBS_NOTHUMB 0x0080 +#define VK_F17 0x80 +#define IDD_CREATM 128 +#define VK_F18 0x81 +#define IDD_TEMPLATE001 129 +#define VK_F19 0x82 +#define IDD_CREATM1 130 +#define VK_F20 0x83 +#define IDD_ORDEROUT 131 +#define VK_F21 0x84 +#define IDD_TEMPLATE002 132 +#define VK_F22 0x85 +#define IDD_selcrsec 133 +#define VK_F23 0x86 +#define IDD_TEMPLATE003 134 +#define VK_F24 0x87 +#define IDD_LIMITS 135 +#define IDD_lAY 136 +#define IDD_TEMPLATE004 137 +#define IDD_DISPLIT 138 +#define IDD_DIRSPLIT 139 +#define IDD_SETOPT 140 +#define IDD_SETMAXMAP 141 +#define VK_NUMLOCK 0x90 +#define VK_SCROLL 0x91 +#define IDD_SELTFL2 148 +#define IDD_GETINT 153 +#define IDD_GETFPN 154 +#define VK_LSHIFT 0xA0 +#define IDD_GETINTP 160 +#define VK_RSHIFT 0xA1 +#define VK_LCONTROL 0xA2 +#define VK_RCONTROL 0xA3 +#define VK_LMENU 0xA4 +#define VK_RMENU 0xA5 +#define VK_ATTN 0xF6 +#define VK_CRSEL 0xF7 +#define VK_EXSEL 0xF8 +#define VK_EREOF 0xF9 +#define VK_PLAY 0xFA +#define VK_ZOOM 0xFB +#define VK_NONAME 0xFC +#define VK_PA1 0xFD +#define VK_OEM_CLEAR 0xFE +#define TCS_BUTTONS 0x0100 +#define TCS_MULTILINE 0x0200 +#define IDF_LABEL1 1001 +#define IDF_LABEL2 1002 +#define IDF_LABEL3 1003 +#define IDF_LABEL4 1004 +#define IDF_CMAP8 1005 +#define IDF_LABEL6 1005 +#define IDF_CMAP9 1006 +#define IDF_LABEL8 1006 +#define IDF_CMAP0 1007 +#define IDF_LABEL9 1007 +#define IDF_CMAP1 1008 +#define IDF_LABEL10 1008 +#define IDF_CMAP2 1009 +#define IDF_LABEL12 1009 +#define IDF_CMAP10 1010 +#define IDF_CMAP11 1011 +#define IDF_CMAP3 1012 +#define IDF_STRING1 1013 +#define IDF_STRING2 1014 +#define IDF_STRING3 1015 +#define IDF_STRING4 1016 +#define IDF_STRING5 1017 +#define IDF_STRING6 1018 +#define IDF_STRING7 1019 +#define IDF_STRING8 1020 +#define IDF_STRING9 1021 +#define IDF_STRING10 1022 +#define IDF_STRING11 1023 +#define TCS_FIXEDWIDTH 0x0400 +#define IDF_STRING12 1024 +#define IDF_STRING13 1025 +#define IDF_STRING14 1026 +#define IDF_STRING15 1027 +#define IDF_STRING16 1028 +#define IDF_STRING17 1029 +#define IDF_STRING18 1030 +#define IDF_STRING19 1031 +#define IDF_STRING20 1032 +#define IDF_STRING21 1033 +#define IDF_STRING22 1034 +#define IDF_STRING23 1035 +#define IDF_CHECK1 1036 +#define IDF_CHECK2 1037 +#define IDF_CHECK3 1038 +#define IDF_CHECK4 1039 +#define IDF_CHECK5 1040 +#define IDF_STRING24 1041 +#define IDF_CHECK6 1041 +#define IDF_LABEL5 1042 +#define IDF_CHECK7 1042 +#define IDF_STRING35 1042 +#define IDF_CMAP4 1043 +#define IDF_CHECK8 1043 +#define IDF_LABEL11 1043 +#define IDF_CMAP5 1044 +#define IDF_CHECK9 1044 +#define IDF_CMAP6 1045 +#define IDF_CHECK10 1045 +#define IDF_CMAP7 1046 +#define IDF_RADIO1 1047 +#define IDF_RADIO2 1048 +#define IDF_RADIO3 1049 +#define IDF_RADIO4 1050 +#define IDF_RADIO5 1051 +#define IDF_RADIO6 1052 +#define IDF_RADIO7 1053 +#define IDF_RADIO8 1054 +#define IDF_RADIO9 1055 +#define IDF_LABEL7 1056 +#define IDF_RADIO10 1056 +#define IDF_INTEGER1 1057 +#define IDF_RADIO11 1057 +#define IDF_INTEGER2 1058 +#define IDF_RADIO12 1058 +#define IDF_CHECK11 1059 +#define IDF_INTEGER3 1059 +#define IDF_RADIO17 1059 +#define IDF_REAL1 1060 +#define IDF_INTEGER4 1060 +#define IDF_REAL2 1061 +#define IDF_INTEGER5 1061 +#define IDF_REAL3 1062 +#define IDF_INTEGER6 1062 +#define IDF_RADIO18 1062 +#define IDF_REAL4 1063 +#define IDF_INTEGER7 1063 +#define IDF_REAL5 1064 +#define IDF_INTEGER8 1064 +#define IDF_REAL6 1065 +#define IDF_REAL7 1066 +#define IDF_REAL8 1067 +#define IDADJUST 1068 +#define IDF_REAL9 1068 +#define IDFSWITCH 1069 +#define IDF_REAL10 1069 +#define IDF_INTEGER9 1070 +#define IDF_INTEGER10 1071 +#define IDNEXT 1072 +#define IDF_Delete 1073 +#define IDFROTATE 1074 +#define IDF_GRID1 1075 +#define IDF_RADIO13 1076 +#define ISS1 1077 +#define ISS2 1078 +#define ISS3 1079 +#define IDF_RADIO14 1080 +#define IDF_RADIO15 1081 +#define IDF_RADIO16 1082 +#define ISS4 1083 +#define ISS5 1084 +#define ISS6 1085 +#define ISS7 1086 +#define IDF_STRING25 1106 +#define IDF_STRING26 1107 +#define IDF_STRING27 1108 +#define IDF_STRING28 1109 +#define IDF_STRING29 1110 +#define IDF_STRING30 1111 +#define IDF_STRING31 1112 +#define IDF_STRING32 1113 +#define IDF_STRING33 1114 +#define IDF_STRING34 1115 +#define id_chck 2001 +#define id_chk 2002 +#define idchk 2003 +#define TCS_RAGGEDRIGHT 0x0800 +#define TCS_FOCUSONBUTTONDOWN 0x1000 +#define IDC_BUTTON2 20001 +#define IDR_MENU1 30001 +#define ID_TOOLBAR1 30101 +#define TCS_FOCUSNEVER 0x8000 +#define ID_FILE 40001 +#define ID_Menu 40001 +#define ID_EXIT 40002 +#define ID_RESET 40002 +#define ID_NODE 40003 +#define ID_ELTS 40004 +#define ID_ORDRT 40005 +#define ID_CCLNA 40006 +#define ID_CSEC1 40007 +#define ID_ZOOM 40008 +#define ID_DRAW 40009 +#define ID_HELP 40010 +#define ID_ITEM11 40011 +#define ID_ITEM12 40012 +#define ID_ITEM13 40013 +#define ID_ITEM14 40014 +#define ID_ITEM15 40015 +#define ID_ITEM16 40016 +#define ID_ITEM17 40017 +#define ID_ITEM18 40018 +#define ID_ITEM19 40019 +#define ID_Clip 40020 +#define ID_ITEM20 40021 +#define ID_ITEM73 40022 +#define ID_ITEM23 40023 +#define ID_ITEM24 40024 +#define ID_ZIN 40025 +#define ID_ZOUT 40026 +#define ID_OUT2 40027 +#define ID_OUT4 40028 +#define ID_RSET 40029 +#define ID_UNDOM 40030 +#define ID_PLEFT 40031 +#define ID_PRIGHT 40032 +#define ID_PUP 40033 +#define ID_PDOWN 40034 +#define ID_IDRWT 40035 +#define ID_BSEL 40036 +#define ID_REGST 40037 +#define ID_network 40038 +#define ID_TYPD 40039 +#define ID_Help1 40040 +#define ID_DRAWD 40041 +#define ID_MAPOPD 40042 +#define ID_MMAP 40043 +#define ID_Help2 40044 +#define ID_NMAP 40045 +#define ID_LAYFL 40046 +#define ID_BKF 40047 +#define ID_ITEM56 40048 +#define ID_Nodedata 40049 +#define ID_BACGD 40050 +#define ID_Eltdata 40051 +#define ID_DRAG 40052 +#define ID_GETELM 40053 +#define ID_mapm 40054 +#define ID_map 40055 +#define ID_DCONTR 40056 +#define ID_SBIN 40057 +#define ID_TRIAN 40058 +#define ID_SWMAP 40059 +#define ID_CONTR 40060 +#define ID_CONTOPT 40061 +#define ID_SWRM1 40062 +#define ID_LOADRM1 40063 +#define ID_ITYPN 40064 +#define ID_ITYPC 40065 +#define ID_cdata 40066 +#define ID_ICOPY 40067 +#define ID_SELRM1 40068 +#define ID_addmesh 40069 +#define ID_MRGMESH 40070 +#define ID_ITEM26 40071 +#define ID_ITEM22 40072 +#define ID_ALLNODES 40073 +#define ID_UNUSNODES 40074 +#define ID_TRIANG 40075 +#define ID_QUAD 40076 +#define ID_CSEC 40077 +#define ID_CRSCAL 40078 +#define ID_SAVCRS 40079 +#define ID_crsf 40080 +#define ID_CSLOC 40081 +#define ID_UNDO 40082 +#define ID_UNDOS 40083 +#define ID_CREATM 40084 +#define ID_CGEN 40085 +#define ID_selarea 40086 +#define ID_crsect 40087 +#define ID_EDLAY 40088 +#define ID_ORDR 40089 +#define ID_ORDR1 40090 +#define ID_SPLITN 40091 +#define ID_FORM999 40092 +#define ID_OUTLAY 40093 +#define ID_g1d 40094 +#define ID_CCLN 40095 +#define ID_CHKCCLN 40096 +#define ID_GOUTLIN 40097 +#define ID_XOUTLIN 40098 +#define ID_FILL 40102 +#define ID_DELM 40103 +#define ID_JOIN 40104 +#define ID_STRING1 50001 +#define ID_STRING2 50002 +#define ID_STRING3 50003 +#define ID_STRING4 50004 +#define ID_STRING5 50005 +#define ID_STRING6 50006 +#define ID_STRING7 50007 +#define ID_STRING8 50008 +#define ID_STRING9 50009 +#define ID_STRING10 50010 +#define ID_STRING11 50011 + +// Next default values for new objects +// +#ifdef APSTUDIO_INVOKED +#ifndef APSTUDIO_READONLY_SYMBOLS +#define _APS_NEXT_RESOURCE_VALUE 101 +#define _APS_NEXT_COMMAND_VALUE 40003 +#define _APS_NEXT_CONTROL_VALUE 1000 +#define _APS_NEXT_SYMED_VALUE 101 +#endif +#endif diff --git a/src/src83e/rotate.bmp b/src/src83e/rotate.bmp new file mode 100644 index 0000000..87a06ef Binary files /dev/null and b/src/src83e/rotate.bmp differ diff --git a/src/src83e/setangle.f90 b/src/src83e/setangle.f90 new file mode 100644 index 0000000..5594250 --- /dev/null +++ b/src/src83e/setangle.f90 @@ -0,0 +1,91 @@ + SUBROUTINE SETANGLE +! +! THIS ROUTINE SETS THE ANGLES FOR 3-F VIEWS +! + use winteracter +! USE BLKV1 +! USE BLKV2 +! USE BLK + + USE BLK1MOD +! INCLUDE 'BLK1.COM' +! INCLUDE 'TXFRM.COM' +!- + + include 'D.inc' + +! +! Declare window-type and message variables +! + TYPE(WIN_STYLE) :: WINDOW + + TYPE(WIN_MESSAGE) :: MESSAGE + INTEGER :: IERR + DATA ITIM/0/ + + IF(ITIM .EQ. 0) THEN + HANG=0. + VANG=90. + VRTSCAL=100.0 + VRTORIG=0. + ITIM=1 + IASPCT=0 + IASPCTOLD=0 + ENDIF + + VANGOLD=VANG + HANGOLD=HANG + + call wdialogload(IDD_VIEWANG) + ierr=infoerror(1) + + CALL WDialogSelect(IDD_VIEWANG) + ierr=infoerror(1) + + 100 continue + CALL WDialogPutREAL(IDF_REAL1,HANG) + CALL WDialogPutREAL(IDF_REAL2,VANG) + CALL WDialogPutREAL(IDF_REAL3,VRTSCAL) + CALL WDialogPutREAL(IDF_REAL4,VRTORIG) + CALL WDialogPutCheckBox(IDF_check1,IASPCT) + + CALL WDialogShow(-1,-1,0,Modal) + ierr=infoerror(1) + + do +! + IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN + + + CALL WDialogGetREAL(IDF_REAL1,HANG) + CALL WDialogGetREAL(IDF_REAL2,VANG) + CALL WDialogGetREAL(IDF_REAL3,VRTSCAL) + CALL WDialogGetREAL(IDF_REAL4,VRTORIG) + CALL WDialogGetCheckBox(IDF_check1,IASPCT) + GO TO 200 +! else +! HANG=0. +! VANG=90. +! VRTSCAL=100. + endif + + enddo + + 200 CONTINUE + RETURN + END + + SUBROUTINE adjustang(hrad,vrad) + + USE BLK1MOD + + VANGOLD=VANG + HANGOLD=HANG + + VANG=VANG+VRAD*57. + HANG=HANG+HRAD*57. + + CALL PLOTOT(0) + + RETURN + END \ No newline at end of file diff --git a/src/src83e/winparam.h b/src/src83e/winparam.h new file mode 100644 index 0000000..6dbd884 --- /dev/null +++ b/src/src83e/winparam.h @@ -0,0 +1,235 @@ +#define IDOK 1 +#define IDCANCEL 2 +#define IDABORT 3 +#define IDRETRY 4 +#define IDIGNORE 5 +#define IDYES 6 +#define IDNO 7 +#define IDCLOSE 8 +#define IDHELP 9 +#define WS_OVERLAPPED 0x00000000L +#define WS_POPUP 0x80000000L +#define WS_CHILD 0x40000000L +#define WS_MINIMIZE 0x20000000L +#define WS_VISIBLE 0x10000000L +#define WS_DISABLED 0x08000000L +#define WS_CLIPSIBLINGS 0x04000000L +#define WS_CLIPCHILDREN 0x02000000L +#define WS_MAXIMIZE 0x01000000L +#define WS_CAPTION 0x00C00000L +#define WS_BORDER 0x00800000L +#define WS_DLGFRAME 0x00400000L +#define WS_VSCROLL 0x00200000L +#define WS_HSCROLL 0x00100000L +#define WS_SYSMENU 0x00080000L +#define WS_THICKFRAME 0x00040000L +#define WS_GROUP 0x00020000L +#define WS_TABSTOP 0x00010000L +#define WS_MINIMIZEBOX 0x00020000L +#define WS_MAXIMIZEBOX 0x00010000L +#define ES_LEFT 0x00000000L +#define ES_CENTER 0x00000001L +#define ES_RIGHT 0x00000002L +#define ES_MULTILINE 0x00000004L +#define ES_UPPERCASE 0x00000008L +#define ES_LOWERCASE 0x00000010L +#define ES_PASSWORD 0x00000020L +#define ES_AUTOVSCROLL 0x00000040L +#define ES_AUTOHSCROLL 0x00000080L +#define ES_READONLY 0x00000800L +#define ES_WANTRETURN 0x00001000L +#define BS_PUSHBUTTON 0x00000000L +#define BS_DEFPUSHBUTTON 0x00000001L +#define BS_AUTOCHECKBOX 0x00000003L +#define BS_GROUPBOX 0x00000007L +#define BS_USERBUTTON 0x00000008L +#define BS_AUTORADIOBUTTON 0x00000009L +#define BS_OWNERDRAW 0x0000000BL +#define BS_LEFTTEXT 0x00000020L +#define BS_TEXT 0x00000000L +#define BS_ICON 0x00000040L +#define BS_BITMAP 0x00000080L +#define BS_LEFT 0x00000100L +#define BS_RIGHT 0x00000200L +#define BS_CENTER 0x00000300L +#define BS_TOP 0x00000400L +#define BS_BOTTOM 0x00000800L +#define BS_VCENTER 0x00000C00L +#define BS_PUSHLIKE 0x00001000L +#define BS_MULTILINE 0x00002000L +#define BS_FLAT 0x00008000L +#define SS_LEFT 0x00000000L +#define SS_CENTER 0x00000001L +#define SS_RIGHT 0x00000002L +#define SS_ICON 0x00000003L +#define SS_BLACKRECT 0x00000004L +#define SS_GRAYRECT 0x00000005L +#define SS_WHITERECT 0x00000006L +#define SS_BLACKFRAME 0x00000007L +#define SS_GRAYFRAME 0x00000008L +#define SS_WHITEFRAME 0x00000009L +#define SS_SIMPLE 0x0000000BL +#define SS_LEFTNOWORDWRAP 0x0000000CL +#define SS_NOPREFIX 0x00000080L +#define SS_BITMAP 0x0000000EL +#define SS_ETCHEDHORZ 0x00000010L +#define SS_ETCHEDVERT 0x00000011L +#define SS_ETCHEDFRAME 0x00000012L +#define SS_NOTIFY 0x00000100L +#define SS_CENTERIMAGE 0x00000200L +#define SS_RIGHTJUST 0x00000400L +#define SS_REALSIZEIMAGE 0x00000800L +#define SS_SUNKEN 0x00001000L +#define DS_SYSMODAL 0x00000002L +#define DS_3DLOOK 0x00000004L +#define DS_SETFONT 0x00000040L +#define DS_MODALFRAME 0x00000080L +#define DS_CONTROL 0x00000400L +#define LBS_NOTIFY 0x00000001L +#define LBS_MULTIPLESEL 0x00000008L +#define LBS_HASSTRINGS 0x00000040L +#define LBS_USETABSTOPS 0x00000080L +#define LBS_NOINTEGRALHEIGHT 0x00000100L +#define LBS_MULTICOLUMN 0x00000200L +#define LBS_EXTENDEDSEL 0x00000800L +#define LBS_DISABLENOSCROLL 0x00001000L +#define LBS_NOSEL 0x00004000L +#define CBS_SIMPLE 0x00000001L +#define CBS_DROPDOWN 0x00000002L +#define CBS_DROPDOWNLIST 0x00000003L +#define CBS_OWNERDRAWFIXED 0x00000010L +#define CBS_AUTOHSCROLL 0x00000040L +#define CBS_SORT 0x00000100L +#define CBS_HASSTRINGS 0x00000200L +#define CBS_DISABLENOSCROLL 0x00000800L +#define CBS_UPPERCASE 0x00002000L +#define CBS_LOWERCASE 0x00004000L +#define WS_EX_DLGMODALFRAME 0x00000001L +#define WS_EX_WINDOWEDGE 0x00000100L +#define WS_EX_CLIENTEDGE 0x00000200L +#define WS_EX_LEFTSCROLLBAR 0x00004000L +#define WS_EX_STATICEDGE 0x00020000L +#define TCS_TABS 0x0000 +#define TCS_BUTTONS 0x0100 +#define TCS_SINGLELINE 0x0000 +#define TCS_MULTILINE 0x0200 +#define TCS_RIGHTJUSTIFY 0x0000 +#define TCS_FIXEDWIDTH 0x0400 +#define TCS_RAGGEDRIGHT 0x0800 +#define TCS_FOCUSONBUTTONDOWN 0x1000 +#define TCS_FOCUSNEVER 0x8000 +#define GS_REPCUTPASTE 0x00000040L +#define GS_DEFROWLABELS 0x00000080L +#define GS_NOINTEGRALHEIGHT 0x00000100L +#define GS_COLUMNLABELS 0x00000200L +#define GS_ROWLABELS 0x00000400L +#define GS_READONLY 0x00000800L +#define GS_WANTRETURN 0x00001000L +#define GS_RESIZECOLUMNS 0x00002000L +#define GS_WANTTAB 0x00004000L +#define GS_WRAP 0x00008000L +#define TBS_AUTOTICKS 0x0001 +#define TBS_VERT 0x0002 +#define TBS_HORZ 0x0000 +#define TBS_TOP 0x0004 +#define TBS_BOTTOM 0x0000 +#define TBS_LEFT 0x0004 +#define TBS_RIGHT 0x0000 +#define TBS_BOTH 0x0008 +#define TBS_NOTICKS 0x0010 +#define TBS_ENABLESELRANGE 0x0020 +#define TBS_FIXEDLENGTH 0x0040 +#define TBS_NOTHUMB 0x0080 +#define TVS_HASBUTTONS 0x0001 +#define TVS_HASLINES 0x0002 +#define TVS_LINESATROOT 0x0004 +#define TVS_EDITLABELS 0x0008 +#define TVS_DISABLEDRAGDROP 0x0010 +#define TVS_SHOWSELALWAYS 0x0020 +#define VK_LBUTTON 0x01 +#define VK_RBUTTON 0x02 +#define VK_CANCEL 0x03 +#define VK_MBUTTON 0x04 +#define VK_BACK 0x08 +#define VK_TAB 0x09 +#define VK_CLEAR 0x0C +#define VK_RETURN 0x0D +#define VK_SHIFT 0x10 +#define VK_CONTROL 0x11 +#define VK_MENU 0x12 +#define VK_PAUSE 0x13 +#define VK_CAPITAL 0x14 +#define VK_ESCAPE 0x1B +#define VK_SPACE 0x20 +#define VK_PRIOR 0x21 +#define VK_NEXT 0x22 +#define VK_END 0x23 +#define VK_HOME 0x24 +#define VK_LEFT 0x25 +#define VK_UP 0x26 +#define VK_RIGHT 0x27 +#define VK_DOWN 0x28 +#define VK_SELECT 0x29 +#define VK_PRINT 0x2A +#define VK_EXECUTE 0x2B +#define VK_SNAPSHOT 0x2C +#define VK_INSERT 0x2D +#define VK_DELETE 0x2E +#define VK_HELP 0x2F +#define VK_NUMPAD0 0x60 +#define VK_NUMPAD1 0x61 +#define VK_NUMPAD2 0x62 +#define VK_NUMPAD3 0x63 +#define VK_NUMPAD4 0x64 +#define VK_NUMPAD5 0x65 +#define VK_NUMPAD6 0x66 +#define VK_NUMPAD7 0x67 +#define VK_NUMPAD8 0x68 +#define VK_NUMPAD9 0x69 +#define VK_MULTIPLY 0x6A +#define VK_ADD 0x6B +#define VK_SEPARATOR 0x6C +#define VK_SUBTRACT 0x6D +#define VK_DECIMAL 0x6E +#define VK_DIVIDE 0x6F +#define VK_F1 0x70 +#define VK_F2 0x71 +#define VK_F3 0x72 +#define VK_F4 0x73 +#define VK_F5 0x74 +#define VK_F6 0x75 +#define VK_F7 0x76 +#define VK_F8 0x77 +#define VK_F9 0x78 +#define VK_F10 0x79 +#define VK_F11 0x7A +#define VK_F12 0x7B +#define VK_F13 0x7C +#define VK_F14 0x7D +#define VK_F15 0x7E +#define VK_F16 0x7F +#define VK_F17 0x80 +#define VK_F18 0x81 +#define VK_F19 0x82 +#define VK_F20 0x83 +#define VK_F21 0x84 +#define VK_F22 0x85 +#define VK_F23 0x86 +#define VK_F24 0x87 +#define VK_NUMLOCK 0x90 +#define VK_SCROLL 0x91 +#define VK_LSHIFT 0xA0 +#define VK_RSHIFT 0xA1 +#define VK_LCONTROL 0xA2 +#define VK_RCONTROL 0xA3 +#define VK_LMENU 0xA4 +#define VK_RMENU 0xA5 +#define VK_ATTN 0xF6 +#define VK_CRSEL 0xF7 +#define VK_EXSEL 0xF8 +#define VK_EREOF 0xF9 +#define VK_PLAY 0xFA +#define VK_ZOOM 0xFB +#define VK_NONAME 0xFC +#define VK_PA1 0xFD +#define VK_OEM_CLEAR 0xFE diff --git a/src/src83e/winteracter.mod b/src/src83e/winteracter.mod new file mode 100644 index 0000000..d471d09 Binary files /dev/null and b/src/src83e/winteracter.mod differ diff --git a/src/src83e/winttypes.mod b/src/src83e/winttypes.mod new file mode 100644 index 0000000..450edd4 Binary files /dev/null and b/src/src83e/winttypes.mod differ diff --git a/src/srcrmagen83e.zip b/src/srcrmagen83e.zip new file mode 100644 index 0000000..51e3d71 Binary files /dev/null and b/src/srcrmagen83e.zip differ diff --git a/src/srcrmagen83f.zip b/src/srcrmagen83f.zip new file mode 100644 index 0000000..5d3dc15 Binary files /dev/null and b/src/srcrmagen83f.zip differ diff --git a/src/srcrmagen83f2.zip b/src/srcrmagen83f2.zip new file mode 100644 index 0000000..7d02335 Binary files /dev/null and b/src/srcrmagen83f2.zip differ