Welcome to IOPWiki, Commander.
With the release of the new game, we encourage contributions to topics related to Girls' Frontline 2. Learn how to contribute, read the maintenance guide, and join our Discord server to discuss major changes.
If you or someone you know can help deciphering the game files, contact our administrator.

MediaWiki:Gadget-live2dFairyAnimation.js: Difference between revisions

Welcome to IOP Wiki. This website is maintained by the Girls' Frontline community and is free to edit by anyone.
Jump to navigation Jump to search
m append instead of add
Added document-ready wait functionality as the MediaWiki does not wait for DOM
 
(14 intermediate revisions by the same user not shown)
Line 1: Line 1:
function getFilePath(name) {
function getFilePath(name) {
   return mw.config.get("wgServer") + "/images/" + window.gfUtils.createWikiPathPart(name) + name;
   return "/images/" + window.gfUtils.createWikiPathPart(name) + name;
}
}


Line 8: Line 8:
       var viewCanvas = containerDiv.find('.live2dstage').first();
       var viewCanvas = containerDiv.find('.live2dstage').first();
       var l2d_tdoll_stage = viewCanvas.data('live2dStage');
       var l2d_tdoll_stage = viewCanvas.data('live2dStage');
      l2d_tdoll_stage.removeChildren();
       l2d_tdoll_stage.addChild(l2d_tdoll_sprite);
       l2d_tdoll_stage.addChild(l2d_tdoll_sprite);
       finishedCallback();
       finishedCallback();
Line 23: Line 24:
     var linkButton = containerDiv.find(".tabs-gallery *[for='" + checkedModel.attr('id') + "']");
     var linkButton = containerDiv.find(".tabs-gallery *[for='" + checkedModel.attr('id') + "']");
     var modLevel = linkButton.text().length; // Number of stars :)
     var modLevel = linkButton.text().length; // Number of stars :)
     var modId = Math.floor(modLevel / 3.0);
     var modId = Math.floor(modLevel / 2.0) + 1;
      
      
     // Load model here
     // Load model here
    var filename = fairyName + "_model" + modId + "_live2d_model.txt";
     gfUtils.live2dUtils.loadLive2dGirl(containerDiv.find(".tabs-container"), fairyName, "model"+modId, null, successCallback, failureCallback);
     gfUtils.live2dUtils.loadLive2dGirl(containerDiv.find(".tabs-container"), fairyName, successCallback, failureCallback, getFilePath(filename));
   } catch (err) {
   } catch (err) {
     console.log("Error changing model", err);
     console.log("Error changing model", err);
Line 67: Line 67:
     radioButtons.change(function(evt) {
     radioButtons.change(function(evt) {
         // Make sure only the checked one is called
         // Make sure only the checked one is called
         if ($(this).is(':not(:checked)')) {
         if (radioButtons.parent().find(".live2dFairySwitcher input[type='checkbox']").is(':not(:checked)')) {
           return;
           return;
         }
         }
Line 78: Line 78:
      
      
     // Create Live2D Button
     // Create Live2D Button
     var live2dButton = $('<button></button>');
     var switchFairyLive2dButtonHandler = function(evt) {
    live2dButton.text('Live2D');
    containerDiv.find(".tabs-container").addClass("loading");
    live2dButton.click(function(evt) {
    mw.loader.using('ext.gadget.live2dLoader').then(function() {
      containerDiv.find(".tabs-container").addClass("loading");
    window.animations.Live2dLoader.init().then(function() {
      mw.loader.using('ext.gadget.live2d').then(function() {
        live2dButtonHandler(evt, containerDiv);
        live2dButtonHandler(evt, containerDiv);
    }, function(x,y,z) {
      });
        console.error("Loading Live2D framework failed",x,y,z);
     });
        containerDiv.removeClass("loading");
    });
    }, function(x,y,z) {
        console.error("Loading live2dLoader failed",x,y,z);
    });
     };
    var live2dButton = gfUtils.createSliderButton("/images/a/a3/live2d-logo.png", switchFairyLive2dButtonHandler);
      
      
     var live2dSwitcher = $('<div></div>');
     var live2dSwitcher = $('<div></div>');
     live2dSwitcher.addClass('live2dFairySwitcher');
     live2dSwitcher.addClass('live2dFairySwitcher');
     live2dSwitcher.append(live2dButton);
 
    var live2dSwitcherContainer = $('<div></div>');
    live2dSwitcherContainer.addClass('live2dSwitcherContainer');
    live2dSwitcherContainer.append(live2dButton);
 
     live2dSwitcher.append(live2dSwitcherContainer);
     live2dSwitcher.insertBefore(containerDiv.find('.tabs-container'));
     live2dSwitcher.insertBefore(containerDiv.find('.tabs-container'));
}
}


RLQ.push(function () {
RLQ.push(['jquery', function () {
   $(document).ready(function() {  
   $(document).ready(function() {
     var containerDiv = $('.fairystattable');
     var containerDiv = $('.fairystattable');
    console.log("Booting Live2D Fairy Animation Gadget. Found containers: ", containerDiv.length);
     if (containerDiv.length < 1) {
     if (containerDiv.length < 1) {
       // Nothing to do here
       // Nothing to do here
Line 101: Line 115:
     }
     }
      
      
     var urlToCheck = getFilePath(mw.config.get("wgPageName") + "_model1_live2d_model.txt");
     var live2dSettings = containerDiv.find('.live2dsettings');
      
     if (live2dSettings.length < 1 || live2dSettings.find('ul').length < 1) {
    $.ajax({
       console.log("No Live2D for this fairy :(");
      url: urlToCheck,
    } else {
      type:'HEAD',
       initFairyEngine(containerDiv);
       error: function() { console.log("No Live2D for this fairy :("); },
     }
       success: function() { initFairyEngine(containerDiv); }
     });
   });
   });
});
}]);
 
console.log("Loaded Live2D Fairy Animation Gadget.");

Latest revision as of 15:08, 14 October 2019

function getFilePath(name) {
  return "/images/" + window.gfUtils.createWikiPathPart(name) + name;
}

function modelChanged(containerDiv, finishedCallback) {
  try {
    var successCallback = function(l2d_tdoll_sprite) {
      var viewCanvas = containerDiv.find('.live2dstage').first();
      var l2d_tdoll_stage = viewCanvas.data('live2dStage');
      l2d_tdoll_stage.removeChildren();
      l2d_tdoll_stage.addChild(l2d_tdoll_sprite);
      finishedCallback();
    };
  
    var failureCallback = function(err) {
      console.log("Error loading model", err);
      finishedCallback();
    };
    
    var fairyName = mw.config.get("wgPageName");

    // Find out the Modifikation Level
    var checkedModel = containerDiv.find(".tabs-gallery input:checked");
    var linkButton = containerDiv.find(".tabs-gallery *[for='" + checkedModel.attr('id') + "']");
    var modLevel = linkButton.text().length; // Number of stars :)
    var modId = Math.floor(modLevel / 2.0) + 1;
    
    // Load model here
    gfUtils.live2dUtils.loadLive2dGirl(containerDiv.find(".tabs-container"), fairyName, "model"+modId, null, successCallback, failureCallback);
  } catch (err) {
    console.log("Error changing model", err);
    finishedCallback();
  }
}

function live2dButtonHandler(evt, containerDiv) {
  var live2dButton = $(evt.target);
  var fairyStatTable = live2dButton.closest('.fairystattable');
  var live2dContainer = fairyStatTable.find('.tabs-container');
  
  if (live2dButton.is('.enabled')) {
    live2dContainer.removeClass('live2dEnabled');
    live2dButton.removeClass('enabled');
    gfUtils.live2dUtils.createLive2dView(live2dContainer, function(view) {
      var l2d_tdoll_stage = view.data('live2dStage');
      l2d_tdoll_stage.removeChildren();
      containerDiv.find(".tabs-container").removeClass("loading");
    });
  } else {
    live2dContainer.addClass('live2dEnabled');
    live2dButton.addClass('enabled');
    gfUtils.live2dUtils.createLive2dView(live2dContainer, function(view) {
      if (live2dContainer.find('.live2dstage').length < 1) {
        live2dContainer.append(view);
      }
      
      modelChanged(fairyStatTable, function() {
        containerDiv.find(".tabs-container").removeClass("loading");
      });
    });
  }
  
}

function initFairyEngine(containerDiv) {
    var radioButtons = containerDiv.find(".tabs-gallery *[type='radio']");
    radioButtons.change(function(evt) {
        // Make sure only the checked one is called
        if (radioButtons.parent().find(".live2dFairySwitcher input[type='checkbox']").is(':not(:checked)')) {
          return;
        }
        
        containerDiv.find(".tabs-container").addClass("loading");
        modelChanged(containerDiv, function() {
          containerDiv.find(".tabs-container").removeClass("loading");
        });
    });
    
    // Create Live2D Button
    var switchFairyLive2dButtonHandler = function(evt) {
    	containerDiv.find(".tabs-container").addClass("loading");
	    mw.loader.using('ext.gadget.live2dLoader').then(function() {
	    	window.animations.Live2dLoader.init().then(function() {
		        live2dButtonHandler(evt, containerDiv);
		    }, function(x,y,z) {
		        console.error("Loading Live2D framework failed",x,y,z);
		        containerDiv.removeClass("loading");
		    });
	    }, function(x,y,z) {
	        console.error("Loading live2dLoader failed",x,y,z);
	    });
    };
    var live2dButton = gfUtils.createSliderButton("/images/a/a3/live2d-logo.png", switchFairyLive2dButtonHandler);
    
    var live2dSwitcher = $('<div></div>');
    live2dSwitcher.addClass('live2dFairySwitcher');

    var live2dSwitcherContainer = $('<div></div>');
    live2dSwitcherContainer.addClass('live2dSwitcherContainer');
    live2dSwitcherContainer.append(live2dButton);

    live2dSwitcher.append(live2dSwitcherContainer);
    live2dSwitcher.insertBefore(containerDiv.find('.tabs-container'));
}

RLQ.push(['jquery', function () {
  $(document).ready(function() {
    var containerDiv = $('.fairystattable');

    console.log("Booting Live2D Fairy Animation Gadget. Found containers: ", containerDiv.length);

    if (containerDiv.length < 1) {
      // Nothing to do here
      return;
    }
    
    var live2dSettings = containerDiv.find('.live2dsettings');
    if (live2dSettings.length < 1 || live2dSettings.find('ul').length < 1) {
      console.log("No Live2D for this fairy :(");
    } else {
      initFairyEngine(containerDiv);
    }
  });
}]);

console.log("Loaded Live2D Fairy Animation Gadget.");