",{"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+=""+Ht([r[c]],!0,!0)+" ";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/MERGEDEMO/skins/overlay/spritesheet.min.css b/MERGEDEMO/skins/overlay/spritesheet.min.css
new file mode 100644
index 0000000..936b7b9
--- /dev/null
+++ b/MERGEDEMO/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/MERGEDEMO/skins/overlay/spritesheet.png b/MERGEDEMO/skins/overlay/spritesheet.png
new file mode 100644
index 0000000..fa3a68a
Binary files /dev/null and b/MERGEDEMO/skins/overlay/spritesheet.png differ
diff --git a/MERGEDEMO/skins/overlay/techsmith-smart-player.min.css b/MERGEDEMO/skins/overlay/techsmith-smart-player.min.css
new file mode 100644
index 0000000..49f76f3
--- /dev/null
+++ b/MERGEDEMO/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/RMAGEN/RMAGEN.common.settings b/RMAGEN/RMAGEN.common.settings
new file mode 100644
index 0000000..c26faac
--- /dev/null
+++ b/RMAGEN/RMAGEN.common.settings
@@ -0,0 +1,22 @@
+
+
+
+
+ true
+
+
+ C:\Users\RMA5440\Fortran-Projects\RMAGEN\RMAGEN\INSTALL\RMAGENV83X.EXE
+
+ C:\Users\RMA5440\proj-17\ftn\jan31\RMA2 test files
+
+ true
+
+
+ true
+ true
+
+ false
+ true
+ false
+
+
\ No newline at end of file
diff --git a/RMAGEN/fort.155 b/RMAGEN/fort.155
new file mode 100644
index 0000000..8c4aad7
--- /dev/null
+++ b/RMAGEN/fort.155
@@ -0,0 +1,9 @@
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
+ 0.0000000E+00 0.0000000E+00 0.0000000E+00
diff --git a/RMAGEN/test.rm1 b/RMAGEN/test.rm1
new file mode 100644
index 0000000..aa8bde4
Binary files /dev/null and b/RMAGEN/test.rm1 differ
diff --git a/Untitled.camproj b/Untitled.camproj
new file mode 100644
index 0000000..c2b4457
--- /dev/null
+++ b/Untitled.camproj
@@ -0,0 +1,130 @@
+
+
+
+
+1920
+1080
+1
+1
+-1
+
+
+
+C:\Users\RMA5440\AppData\Local\TechSmith\Camtasia Studio\8.0\Auto-Saves\Untitled4eaa9470.autosave.camproj
+
+B0BE3E18-C5DF-40FA-A859-8E865C918D77
+
+0
+
+
+
+
+
+
+
+
+
+8
+Untitled
+
+
+13
+2017-02-07 04:09:51 PM
+
+
+16
+ENU
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/capture-3.trec b/capture-3.trec
new file mode 100644
index 0000000..832bf08
Binary files /dev/null and b/capture-3.trec differ
diff --git a/src/BLK1.f90 b/src/BLK1.f90
index 2ffe1b5..539c563 100644
--- a/src/BLK1.f90
+++ b/src/BLK1.f90
@@ -12,7 +12,7 @@
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
+ 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
@@ -42,7 +42,7 @@
,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
+ ,JPTSB,ILINEL
!IPK MAR02 ADD BS1
!IPK FEB02 ADD LOCK
!IPK MAY01 ADD NODDEL AND IELDEL
@@ -111,7 +111,7 @@
ALLOCATABLE ICN(:)
- ALLOCATABLE ICONNCT(:,:)
+ ALLOCATABLE ICONNCT(:,:),NKEP(:)
ALLOCATABLE IOUTLST(:,:),NOUTLST(:),XOUT(:,:),YOUT(:,:)
diff --git a/src/D.INC b/src/D.INC
index df2bea6..70b1d42 100644
--- a/src/D.INC
+++ b/src/D.INC
@@ -1,4 +1,4 @@
-! Winteracter resource identifiers. Created : 03/Aug/2016 15:52:15
+! 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
@@ -361,3 +361,7 @@
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/EVENT.F90 b/src/EVENT.F90
index 64f956c..2eda33a 100644
--- a/src/EVENT.F90
+++ b/src/EVENT.F90
@@ -833,8 +833,16 @@
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
@@ -1067,6 +1075,10 @@
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
@@ -1234,6 +1246,12 @@
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)
@@ -1346,6 +1364,7 @@
CASE (ID_SMOOTHMAP)
CALL SMOOTHMP
GO TO 101
+
CASE (ID_DRAG)
MENUS=8
iflag='d'
@@ -1702,11 +1721,20 @@
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
+ CALL OUTLINES(0)
GO TO 100
END SELECT
diff --git a/src/EXP.rc b/src/EXP.rc
deleted file mode 100644
index af4f1ff..0000000
--- a/src/EXP.rc
+++ /dev/null
@@ -1,47 +0,0 @@
-///////////////////////////////////////////////////
-//
-// THIS FILE SHOULD NOT BE EDITED USING A TEXT
-// EDITOR OR 3RD PARTY RESOURCE EDITOR, EXCEPT
-// WHEN SPECIFICALLY INSTRUCTED BY I.S.S.
-//
-///////////////////////////////////////////////////
-//
-// Winteracter exported resources.
-//
-// Exported : 08/May/2015 15:41:09
-//
-///////////////////////////////////////////////////
-//
-// To use this file it should be imported into
-// your main resource script
-//
-///////////////////////////////////////////////////
-
-///////////////////////////////////////////////////
-//
-// Parameter Definitions
-//
-#define IDF_LABEL1 1001
-#define IDF_INTEGER1 1057
-#define IDD_SELELT 119
-
-///////////////////////////////////////////////////
-//
-// Dialogs
-//
-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
-
diff --git a/src/FILLTR.F90 b/src/FILLTR.F90
index dec64f5..dfad3e1 100644
--- a/src/FILLTR.F90
+++ b/src/FILLTR.F90
@@ -4,6 +4,7 @@
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)
@@ -168,9 +169,9 @@
! OPTIONS = ' -pqa5000V TEST'
OPTIONS(1:3) = ' -p'
nct=3
-! iswq=1
-! iswy=0
-! id1=105
+ iswq=1
+ iswy=0
+ id1=100
CALL PANELFILLT(ISWQ,ISWY,ID1)
IF(ISWQ .EQ. 1) THEN
@@ -202,9 +203,29 @@
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)
@@ -239,12 +260,12 @@
! real ::
! character*3 ::
DATA ITIME/0/
- IF(ITIME .EQ. 0) THEN
- ITIME=1
- N1=1
- N2=0
- N3=100
- ENDIF
+! IF(ITIME .EQ. 0) THEN
+! ITIME=1
+! N1=1
+! N2=0
+! N3=100
+! ENDIF
call wdialogload(IDD_FTRIAN)
ierr=infoerror(1)
diff --git a/src/GETNEWFIL - Copy.F90 b/src/GETNEWFIL - Copy.F90
new file mode 100644
index 0000000..2a598d6
--- /dev/null
+++ b/src/GETNEWFIL - Copy.F90
@@ -0,0 +1,757 @@
+ 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
+ CALL WRTFIL(IFILOUT)
+ CALL ZEROOUT
+ IACTVFIL=ITOTFIL
+ ELSEIF(IACTVFIL .EQ. 0) THEN
+ IACTVFIL=1
+ ENDIF
+ IF(abs(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)
+ ENDIF
+ IF(ITRIAN .EQ. 1) THEN
+ CALL READGFG(IIN,1)
+
+! 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
+
+ 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
+! INCLUDE 'BLK1.COM'
+
+ CLOSE (IFILOUT)
+ OPEN(IFILOUT,STATUS='scratch',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 GETNEWFIL', 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
+ 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'
+ 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(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
+
+ 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 (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
+ NOP(J,2*KK-1) = NTMP(KK)
+ 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
+ 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(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)
+ CORD(J,1) = CX
+ CORD(J,2) = CY
+ XUSR(J) = CX
+ YUSR(J) = CY
+ 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/GETNEWFIL.F90 b/src/GETNEWFIL.F90
index e6d485e..f94d4af 100644
--- a/src/GETNEWFIL.F90
+++ b/src/GETNEWFIL.F90
@@ -4,12 +4,13 @@
! WRITE CURRENT DATA TO A SCRATCH FILE
- IF(IACTVFIL .GT. 0) THEN
+ IF(IACTVFIL .GT. 0 .AND. ISWT .NE. -1) THEN
IFILOUT=IACTVFIL+50
+ WRITE(90,*) 'INGETNEWFIL IFILOUT',IFILOUT
CALL WRTFIL(IFILOUT)
CALL ZEROOUT
IACTVFIL=ITOTFIL
- ELSE
+ ELSEIF(IACTVFIL .EQ. 0) THEN
IACTVFIL=1
ENDIF
IF(ISWT .EQ. 1) THEN
@@ -19,9 +20,11 @@
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(ITRIAN .EQ. 1) THEN
- CALL READGFG(IIN,1)
+ IF(ABS(ITRIAN) .EQ. 1) THEN
+ CALL READGFG(IIN,ITRIAN)
! TEST FOR GFG FORMAT
ELSEIF(IGFG .EQ. 1) THEN
@@ -42,7 +45,8 @@
CALL RDBIN(IIN)
ENDIF
-
+ IF(ITRIAN .EQ. -1) RETURN
+
IFILOUT=IACTVFIL+50
WRITE(90,*) 'IFILOUT', IFILOUT
CALL WRTFIL(IFILOUT)
@@ -62,10 +66,16 @@
USE BLK1MOD
CHARACTER*80 ALINE
+ CHARACTER*10 FMT
! INCLUDE 'BLK1.COM'
CLOSE (IFILOUT)
- OPEN(IFILOUT,STATUS='scratch',FORM='binary')
+ 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
@@ -93,13 +103,14 @@
xadded=0.
yadded=0.
ntempin=0.
-! WRITE(90,*) 'IN GETNEWFIL', IFILOUT,NP,NE,IPRT
+ 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(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)
@@ -355,6 +366,7 @@
USE BLK1MOD
INCLUDE "BFILES.I90"
! INCLUDE 'BLK1.COM'
+ INCLUDE 'TXFRM.COM'
CHARACTER*1 ANS
CHARACTER*32 ANS32
CHARACTER*3 ID
@@ -394,7 +406,7 @@
yadded=0.
ntempin=0.
KLIN=0
- IF(ISW .EQ. 1) GO TO 500
+ IF(ABS(ISW) .EQ. 1) GO TO 500
DO I=1,10000
READ(IIN,'(A3,A77)') ID,DLIN
IF(ID .EQ. 'T1 ') THEN
@@ -626,11 +638,15 @@
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'
@@ -644,7 +660,11 @@
STOP
ENDIF
DO KK=1,3
- NOP(J,2*KK-1) = NTMP(KK)
+ 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
@@ -654,7 +674,8 @@
ENDIF
NCORN(J)=6
IESKP(J)=0
- ENDDO
+ ENDDO
+ NE=J
CLOSE(IUNIT)
DO L=255,1,-1
IF(FNAMKEP(L:L) .EQ. '.') THEN
@@ -668,6 +689,7 @@
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
@@ -691,10 +713,10 @@
STOP
ENDIF
NP = MAX(NP,J)
- CORD(J,1) = CX
- CORD(J,2) = CY
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.
diff --git a/src/GETWT.F90 b/src/GETWT.F90
index aae3c8e..1d21ee1 100644
--- a/src/GETWT.F90
+++ b/src/GETWT.F90
@@ -6,8 +6,26 @@
! 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
@@ -43,23 +61,28 @@
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(xusr(m) .lt. xminl .or. xusr(m) .gt. xmaxl) then
+! 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 .or. yusr(m) .gt. ymaxl) then
+ 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
-! write(142,*) m,n,disq,rads(n)**2,xusr(m),xcen(n)
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',n,disq,rads(n)**2,wgt(1),wgt(2),wgt(3)
+ WRITE(142,*) 'REJECT',m,n,disq,rads(n)**2,wgt(1),wgt(2),wgt(3)
GO TO 250
ENDIF
ENDDO
diff --git a/src/HEDR.F90 b/src/HEDR.F90
index f27a03c..f74ad71 100644
--- a/src/HEDR.F90
+++ b/src/HEDR.F90
@@ -27,7 +27,7 @@
common /cols/ ibakk,icolr,iblkk
CHARACTER*8 HED(10),HEAD(10,16)
- CHARACTER*47 MESOUT,MESS(47)
+ 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)
@@ -37,7 +37,7 @@
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 ',' (s)ave ',&
+ 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
@@ -98,8 +98,9 @@
'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
-! last line Jan 2001
+ ,' ','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*' ',&
diff --git a/src/HELPS.F90 b/src/HELPS.F90
index 632bb25..3d45694 100644
--- a/src/HELPS.F90
+++ b/src/HELPS.F90
@@ -30,8 +30,9 @@
Filter='HTM file -- *.htm|*.htm|'
- CALL WSelectFile(FILTER,PromptOn,DIRECT,'Help files not available - BROWSE')
+! 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
diff --git a/src/INITSIZ.f90 b/src/INITSIZ.f90
index 45177f2..8aef61d 100644
--- a/src/INITSIZ.f90
+++ b/src/INITSIZ.f90
@@ -9,8 +9,8 @@
IF(K1 .EQ. 0) THEN
MAXPL=200000
- MAXP=100000
- MAXE=60000
+ MAXP=200000
+ MAXE=120000
MAXSTO=2
MAXLIN=3000
MAXECON=60
diff --git a/src/INOUT.F90 b/src/INOUT.F90
index 862fe42..0d054db 100644
--- a/src/INOUT.F90
+++ b/src/INOUT.F90
@@ -206,6 +206,8 @@
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
@@ -2288,7 +2290,7 @@
IF(IECHG .EQ. 0) IEM(J)=J
WRITE(IOF,5004) &
& J, (NOP(J,K),K=1,8), IMAT(J),THTA(J)
- 5004 FORMAT('GE',10I6,F10.4)
+ 5004 FORMAT('GE',10(1X,I6),F17.4)
ENDIF
ENDDO
DO J=1,NP
@@ -2360,13 +2362,22 @@
CHARACTER*80 ALINE
IF(IENT .EQ. 1) THEN
- READ(IUNIT) TITLE,NP,NE
+! 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
- IF(IPP .GT. 0) READ(IIN) ALINE
+ 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
@@ -2383,7 +2394,7 @@
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)
@@ -2396,20 +2407,29 @@
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
diff --git a/src/JOINEL.F90 b/src/JOINEL.F90
index 5e311b8..00dcc4e 100644
--- a/src/JOINEL.F90
+++ b/src/JOINEL.F90
@@ -167,7 +167,7 @@
! get adjacent corner save corner
m=2
list1(m)=nd3
- write(90,*) 'm',nd3
+ write(90,*) m,nd3
nelc=nel1
nelcsv=nel1
! start looop
@@ -197,6 +197,7 @@
RETURN
ENDIF
list1(m)=nd3
+ write(90,*) m,nd3
! test for last element
if(nelc .eq. nel2) go to 250
enddo
@@ -209,10 +210,12 @@
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
@@ -225,6 +228,7 @@
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
@@ -242,6 +246,7 @@
CALL HEDR
ENDIF
list2(m)=nd3
+ write(90,*) m,nd3
! test for last element
if(nelc .eq. nel4) go to 350
enddo
@@ -312,8 +317,10 @@
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
diff --git a/src/LOADFIL.F90 b/src/LOADFIL.F90
index 94d7173..e7e38f2 100644
--- a/src/LOADFIL.F90
+++ b/src/LOADFIL.F90
@@ -10,6 +10,7 @@
CALL ZEROOUT
IFNUM=IACTVFIL+50
+ WRITE(90,*) 'IN LOADFIL IFNUM',IFNUM
CALL RDRST(1,IFNUM)
CALL RDRST(2,IFNUM)
CALL RDRST(3,IFNUM)
diff --git a/src/NEWRMGN.F90 b/src/NEWRMGN.F90
index 463e191..0fabdb2 100644
--- a/src/NEWRMGN.F90
+++ b/src/NEWRMGN.F90
@@ -34,6 +34,8 @@
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
@@ -56,7 +58,7 @@
IRES=GETDRIVEDIRQQ (fname)
! lnnnam=windowstringlength(fname)
lnnnam=lenstr(fname)
- direct=fname(1:lnnnam)//'\doc\rmagen81M.htm'
+ direct=fname(1:lnnnam)//'\doc\rmagen83d.htm'
! write(128,*) fname,lnnnam,direct
@@ -144,6 +146,10 @@
! 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.
@@ -238,6 +244,7 @@
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
@@ -473,6 +480,7 @@
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)
diff --git a/src/OUTLINES.F90 b/src/OUTLINES.F90
index 8dfe87e..19c7c1c 100644
--- a/src/OUTLINES.F90
+++ b/src/OUTLINES.F90
@@ -1,4 +1,4 @@
- SUBROUTINE OUTLINES
+ SUBROUTINE OUTLINES(ISWT)
USE WINTERACTER
USE BLK1MOD
@@ -10,17 +10,21 @@
CHARACTER(LEN=255) :: FNAME,FILTER
CHARACTER(LEN=4) :: SUB
- LOGICAL OPENED
+ 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,2),IOUTLST(10,5000),NOUTLST(10))
+ 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
@@ -73,17 +77,20 @@
ENDIF
!
! FORM LIST OF ELEMENT SIDES THAT ARE ON THE OUTSIDE
-
+ 80 CONTINUE
DO N=1,NP
MSN(N)=0
- ENDDO
+ 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)
@@ -92,6 +99,21 @@
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
@@ -101,6 +123,7 @@
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)
@@ -111,7 +134,15 @@
IOUTLST(K,2)=J
IOUTLST(K,3)=ICONNCT(J,2)
JJ=3
- endif
+ 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
@@ -155,7 +186,61 @@
ENDIF
ENDIF
- ENDDO
+ 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
@@ -179,13 +264,40 @@
WRITE(IOUTOUT,*) NZERO
ELSE
DO L=1,NOUTLST(K)
- XOUT(L,K)=XUSR(IOUTLST(K,L))
- YOUT(L,K)=YUSR(IOUTLST(K,L))
- WRITE(IOUTOUT,*) XOUT(L,K),YOUT(L,K)
- ENDDO
+ 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
+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
\ No newline at end of file
+ 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/PLOTR.F90 b/src/PLOTR.F90
index 8628043..52c5fa5 100644
--- a/src/PLOTR.F90
+++ b/src/PLOTR.F90
@@ -174,3 +174,31 @@
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/PLOTR1.F90 b/src/PLOTR1.F90
index 94012bf..7911c95 100644
--- a/src/PLOTR1.F90
+++ b/src/PLOTR1.F90
@@ -27,6 +27,7 @@
IFIRST=1
ENDIF
HT=0.2
+! CALL CHEXIT
!
if(imz .ne. 2) CALL CLSCRN
!
@@ -67,6 +68,28 @@
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
@@ -74,7 +97,6 @@
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)
@@ -84,7 +106,7 @@
! write(90,*) 'finished drawbk'
!
! Plot map data
-!
+!
IF(IMP .NE. 0) THEN
IF(IPSW(1) .EQ. 1) THEN
CALL PLTMAP
@@ -131,8 +153,10 @@
cycle
endif
enddo
- if(abs(wdmin) .ge. abs(wdmax)) then
+ if(abs(wdmin) .gt. abs(wdmax)) then
temp=log10(abs(wdmin))
+ elseif(wdmin .eq. 0) then
+ temp=2.5
else
temp=log10(wdmax)
endif
@@ -145,10 +169,10 @@
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(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
@@ -218,15 +242,15 @@
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(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
+20 CONTINUE
IF(IERC .GT. 0) THEN
! call clscrn()
! WRITE(LIND,*) ' Zero node corner nodes'
@@ -250,6 +274,9 @@
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)
@@ -308,7 +335,7 @@
IF(IMZ .NE. 1) THEN
CALL DOPLOT(IMZ)
ENDIF
-
+ CALL CHEXIT
RETURN
END
!
diff --git a/src/REATTACH.F90 b/src/REATTACH.F90
index de7d884..4403408 100644
--- a/src/REATTACH.F90
+++ b/src/REATTACH.F90
@@ -4,7 +4,7 @@
USE BLK1MOD
USE BLK2MOD
- INTEGER NS1(3),NT1(3)
+ INTEGER NS1(3,4),NT1(3,4)
CHARACTER*1 IFLAG,ANSW(10)
DATA ANSW/' ',' ',' ',' ',' ',' ','n','z','r','q'/
@@ -12,34 +12,50 @@
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)
- call fillem(ielem)
- IF(IRMAIN .EQ. 1) RETURN
+ 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
- RETURN
+ 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
- NS1(1)=NOP(IELEM,K-1)
- NS1(2)=NSX
- KK=MOD(K,NCORN(IELEM))+1
- NS1(3)=NOP(IELEM,KK)
- GO TO 280
+! 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
+280 CONTINUE
+
! SELECT NEXT ELEMENT
@@ -48,24 +64,38 @@
! 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
- NT1(1)=NOP(IELEM1,K-1)
- NT1(2)=NSX
- KK=MOD(K,NCORN(IELEM1))+1
- NT1(3)=NOP(IELEM1,KK)
- GO TO 300
+ 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)
- NOP(J,K+4)=NT1(K)
+ NOP(J,K)=NS1(K,NNN)
+ NOP(J,K+4)=NT1(K,MMM)
ENDDO
NOP(J,4)=0
NOP(J,8)=0
@@ -74,6 +104,7 @@
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/REGSTR.F90 b/src/REGSTR.F90
index 44a4d45..c7c4238 100644
--- a/src/REGSTR.F90
+++ b/src/REGSTR.F90
@@ -294,14 +294,16 @@
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 file?', 'SAVE ORG FILE')
+ 'save locations as ORG or JPGW file?', 'SAVE ORG/JPGW FILE')
!
! If answer 'NO', return
!
@@ -309,16 +311,34 @@
ENDIF
! Otherwise process
-
- CALL WSelectFile(ID_STRING11,SaveDialog+PromptOn,FNAME,'Save ORG File')
+ 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'
- CALL ADDSUB(FNAME,SUB)
+! SUB='org'
OPEN(104,FILE=FNAME,STATUS ='UNKNOWN', FORM ='FORMATTED')
- WRITE(104,'(4G16.8)') (BFMINMAX(NN,I),I=1,4)
- CLOSE(104)
+ 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
diff --git a/src/RMAGEN - Shortcut.lnk b/src/RMAGEN - Shortcut.lnk
deleted file mode 100644
index a126725..0000000
Binary files a/src/RMAGEN - Shortcut.lnk and /dev/null differ
diff --git a/src/RMAGEN.F90 b/src/RMAGEN.F90
index 869581d..0b55c8a 100644
--- a/src/RMAGEN.F90
+++ b/src/RMAGEN.F90
@@ -188,10 +188,10 @@
IPSW(8)=0
IPSW(9)=0
IPSW(12)=0
- IF(N8 .GT. 100000) THEN
- IPSW(2)=1
- IPSW(4)=0
- ENDIF
+! IF(N8 .GT. 100000) THEN
+! IPSW(2)=1
+! IPSW(4)=0
+! ENDIF
MAXPTS=MAXPL
!ipk jan98
call file(1)
diff --git a/src/RMAGENV83c.rc b/src/RMAGENV83d.rc
similarity index 99%
rename from src/RMAGENV83c.rc
rename to src/RMAGENV83d.rc
index cd4e683..33d9f03 100644
--- a/src/RMAGENV83c.rc
+++ b/src/RMAGENV83d.rc
@@ -8,7 +8,7 @@
//
// Winteracter resource script.
//
-// Modified : 03/Aug/2016 15:52:15
+// Modified : 13/Feb/2017 12:04:28
//
///////////////////////////////////////////////////
//
@@ -371,6 +371,10 @@
#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
///////////////////////////////////////////////////
//
@@ -1045,7 +1049,7 @@ BEGIN
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, 180, 196, 40, 14
+ 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
@@ -1056,6 +1060,7 @@ BEGIN
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
@@ -2095,6 +2100,22 @@ BEGIN
,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
@@ -2147,6 +2168,7 @@ BEGIN
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
@@ -2217,6 +2239,7 @@ BEGIN
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
@@ -2256,6 +2279,7 @@ BEGIN
MENUITEM "Group Colour", ID_IGPC
END
MENUITEM "Map Options", ID_MAPOPD
+ MENUITEM "Force Direct Draw", ID_DDRAW
END
POPUP "&Help"
BEGIN
@@ -2269,7 +2293,7 @@ BEGIN
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 Mesh to Map Contours", ID_SMOOTHMAP
+ 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
@@ -2404,5 +2428,5 @@ END
//*WI* FORTSAVE 1
//*WI* FILENAME D.INC
//*WI* FMODNAME
-//*WI* LASTTYPE 2
-//*WI* LASTRES 67
+//*WI* LASTTYPE 1
+//*WI* LASTRES 1
diff --git a/src/RVSDIAG.F90 b/src/RVSDIAG.F90
index f0d4587..9fe8d99 100644
--- a/src/RVSDIAG.F90
+++ b/src/RVSDIAG.F90
@@ -2,7 +2,14 @@
! 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)
@@ -90,6 +97,7 @@
! 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)
@@ -98,7 +106,8 @@
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 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)
diff --git a/src/TXFRM.COM b/src/TXFRM.COM
index f277e40..b564d03 100644
--- a/src/TXFRM.COM
+++ b/src/TXFRM.COM
@@ -1,4 +1,4 @@
REAL*8 XS,YS,TXSCAL
- INTEGER IRGB
- COMMON /TXFRM/ XS, YS, TXSCAL,IRGB
+ INTEGER IRGB,IDDSW
+ COMMON /TXFRM/ XS, YS, TXSCAL,IRGB,IDDSW
diff --git a/src/UTIL.F90 b/src/UTIL.F90
index 49eafde..bae20fb 100644
--- a/src/UTIL.F90
+++ b/src/UTIL.F90
@@ -1083,7 +1083,8 @@
DO 25 K=1,NCNR
N = NOP(J,K)
!
- IF (N .EQ. 0 .OR. CORD(N,1) .LT. VDX) GOTO 25
+ 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
diff --git a/src/WINNEW.F90 b/src/WINNEW.F90
index af36efb..4b6ec46 100644
--- a/src/WINNEW.F90
+++ b/src/WINNEW.F90
@@ -413,7 +413,10 @@
!IPK MAY02 COMMON /TXFRM/ XS, YS, TXSCAL
INCLUDE 'BFILES.I90'
- DATA IHAND1,IHAND2/0,0/
+! 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)
@@ -493,7 +496,11 @@
CALL WBitMapCreate(IHAND2,IX2PIX,IY2PIX)
CALL IGrSelect(DrawBitmap,IHAND2)
CALL WBitMapPutPart(IHAND1,0,IXLPIX,IYLPIX,IXMPIX,IYMPIX)
- CALL IGrSelect(DrawWin)
+ 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)
@@ -672,12 +679,19 @@
CALL WDialogShow(-1,-1,0,Modal)
ierr=infoerror(1)
- IF (WInfoDialog(ExitButton) .EQ. IDOK) THEN
- call wdialogGetradiobutton(idf_radio1,iactvfil)
- ENDIF
- write(90,*) 'Selected iactvfil', iactvfil
- RETURN
+ 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)
@@ -687,4 +701,29 @@
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/addmesht - Copy.f90 b/src/addmesht - Copy.f90
new file mode 100644
index 0000000..01ffdfc
--- /dev/null
+++ b/src/addmesht - Copy.f90
@@ -0,0 +1,239 @@
+ 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
+ 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 - XS
+ 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
+
+ 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=105
+ 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
+ !
+ !RESULT= RUNQQ("C:\Program Files\RMA\TRIANGLE", OPTIONS)
+! RESULT= RUNQQ("TRIANGLE", OPTIONS)
+
+ 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 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
+ 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
+ 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
+
\ No newline at end of file
diff --git a/src/addmesht.f90 b/src/addmesht.f90
new file mode 100644
index 0000000..2301d0f
--- /dev/null
+++ b/src/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/addtomesh.f90 b/src/addtomesh.f90
index 5023939..939703a 100644
--- a/src/addtomesh.f90
+++ b/src/addtomesh.f90
@@ -6,6 +6,7 @@
USE WINTERACTER
USE BLK1MOD
+ USE BLK2MOD
INCLUDE 'D.INC'
@@ -16,10 +17,17 @@
CALL RDTOCLIP(IADD)
IF(ISWT .EQ. 1) THEN
+ CALL OUTLINES(1)
ISWT1=0
- CALL MERGEMESH1(ISWT1)
+! IF(NOUTLST(2) .EQ. 0) THEN
+ ISWT2=1
+! ELSE
+! ISWT2=0
+! ENDIF
+ CALL MERGEMESH1(ISWT1,ISWT2)
write(90,*) 'finished mergemesh1'
- CALL MERGEMESH
+ IF(ISWT2 .EQ. 0) CALL MERGEMESH
+! CALL MERGEMESH
write(90,*) 'finished mergemesh'
flush(90)
ENDIF
@@ -52,14 +60,14 @@
REWIND IUNIT
READ(IUNIT) TITLE,NPSTO(1),NESTO(1)
-! WRITE(90,*) 'IN RDTOCLIP',IUNIT
-! WRITE(90,*) 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
+ 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
+ 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))
@@ -161,22 +169,62 @@
RETURN
END
- SUBROUTINE MERGEMESH1(ISWT1)
+ 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))
@@ -258,7 +306,8 @@
IF(NOP(N,7) .EQ. 0) THEN
NCN=6
IT=2
- ELSEIF(NOP(N,6) .EQ. 0) THEN
+ ENDIF
+ IF(NOP(N,6) .EQ. 0) THEN
GOTO 350
ENDIF
! Test for point inside an element
@@ -439,25 +488,39 @@
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
@@ -465,6 +528,7 @@
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)
@@ -488,8 +552,10 @@
ENDIF
ENDDO
ENDIF
+360 CONTINUE
ENDDO
ENDIF
+380 CONTINUE
ENDDO
ENDIF
400 CONTINUE
@@ -497,3 +563,66 @@
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/backc.f90 b/src/backc.f90
new file mode 100644
index 0000000..f463e5f
--- /dev/null
+++ b/src/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/form999.f90 b/src/form999.f90
index c0eaa81..95fd482 100644
--- a/src/form999.f90
+++ b/src/form999.f90
@@ -74,6 +74,7 @@
CALL ADD999(ISWT9,NELC)
! WRITE(150,*) 'BACK FROM ADD999'
! FLUSH(150)
+ CALL HEDR
RETURN
ENDIF