Всплывающая подсказка jQuery Tools для использования специальных событий - PullRequest
1 голос
/ 21 сентября 2009

Кто-нибудь знает, как изменить подсказку для инструментов jquery: http://flowplayer.org/tools/tooltip.html

, чтобы использовать событие особого наведения: http://blog.threedubmedia.com/2008/08/eventspecialhover.html

Подсказка к инструментам jQuery не зависит от метода наведения, поэтому просто загрузить плагин недостаточно.

Источник для наведения на событие: http://threedubmedia.googlecode.com/files/jquery.event.hover-1.0.js Вот источник подсказки для инструментов jquery: http://flowplayer.org/js/tools/tools.tooltip-1.1.1.js

Я пытался заставить это работать некоторое время. Заранее спасибо.

1 Ответ

0 голосов
/ 21 сентября 2009

@ Jourkey , что я понял из вопроса, так это то, что вы хотите показывать всплывающую подсказку только тогда, когда событие HOVER сообщается jquery.event.hover plugin. Если это так, то после множества проб и ошибок я получил это так:

<script type="text/javascript" src="jquery-1.3.2.js"></script>
<script type="text/javascript" src="jquery.event.hover-1.0.js"></script>
<script type="text/javascript" src="tools.tooltip-1.1.1.js"></script>
<style type="text/css">
  div.hovering{background-color:yellow;}
  div.normal{background-color:white;}
  #demotip { display:none; background:transparent url(tooltip/white.png); 
  font-size:12px; height:60px; width:160px; padding:25px; color:#0505ff;}
</style>

<div id="rect" style="height:200px;width:200px;border:2px blue groove;" 
    class="normal" title='This is testing tooltip'></div> 
<div id="demotip">&nbsp;</div>
<span id="btnShow" style="border:1px solid black;">click</span>
<span id="btnClose" style="border:1px solid black;">close</span>

JavaScript:

<script type="text/javascript">
var api; //TO TAKE CARE OF TOOLTIP OBJECT
var hovering=false; //TO TRACK IF HOVERING STARTED BY HOVER PLUGIN OR NOT
    $(document).ready(function(){
    $.tools.tooltip.conf.position=["center","right"];
    $.tools.tooltip.conf.api=true;
    $.tools.tooltip.conf.effect='fade';
    $.tools.tooltip.conf.onBeforeShow = function(a){
                    return hovering;};
        $.tools.tooltip.conf.onBeforeHide = function(a){
                    return !hoveRing;};

        var api = $("#rect[title]").tooltip("#demotip");//CREATE TOOLTIP

    $("#btnShow").click(function(){
            hovering=true;
            api.show();});

    $("#btnClose").click(function(){
            hovering=false;
            api.hide();});

    $.event.special.hover.delay = 500;//REPORT HOVER AFTER DELAY OF 500MS
    $("#rect").hover(function(){},//HOVER START (BEFORE HOVERING)
            function(){
                hovering=true;
                api.show();}, //HOVERING
            function(){
                hovering=false;
                api.hide();}//HOVER END
        );
    });     
</script>
...