サイズ変更可能ボックスの幅と高さの比率を指定

jQuery UI の Resizable プラグインを使った、ドラッグ&ドロップでサイズを変更できるボックスの、幅と高さの比率を指定には、aspectRatio オプションを使う。
幅と高さの比率を指定しておくと、ボックスの大きさを変更しても、常に幅と高さの比率(縦横比率)は変わらない。幅もしくは高さだけ変更するということはできなくなる。

実装例(サンプル)

Resizable

このボックスは、サイズを変更できる。

実装例の動作について

  • ボックスの右端にカーソルを合わせると、カーソルが左右リサイズ用カーソル形状に変わる。ドラッグして左右に動かすと、ボックスの大きさを変更できる。幅と高さの比率は、「3:1」になるように指定してあるので、幅だけでなく、高さも変わる。
  • ボックスの下端にカーソルを合わせると、カーソルが上下リサイズ用カーソル形状に変わる。ドラッグして上下に動かすと、ボックスの大きさを変更できる。幅と高さの比率は、「3:1」になるように指定してあるので、高さだけでなく、幅も変わる。
  • ボックスの右下端にカーソルを合わせると、カーソルが左上右下リサイズ用カーソル形状に変わる。ドラッグして左上か右下へ動かすと、ボックスの大きさを変更できる。幅と高さの比率は、常に「3:1」。

実装例のソースコード

読み込み

読み込み方は、2種類ある。パスは、それぞれ、アップロードした場所を指定する。

まとめて読み込む場合
<link rel="stylesheet" href="themes/base/jquery.ui.all.css">
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="ui/jquery-ui-1.8.12.custom.min.js"></script>
個別に読み込む場合
<link rel="stylesheet" href="themes/base/jquery.ui.all.css">
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" src="ui/jquery.ui.core.js"></script>
<script type="text/javascript" src="ui/jquery.ui.widget.js"></script>
<script type="text/javascript" src="ui/jquery.ui.mouse.js"></script>
<script type="text/javascript" src="ui/jquery.ui.resizable.js"></script>

JavaScript

<script>
<!--
jQuery( function() {
    jQuery( '#jquery-ui-resizable' ) . resizable( {
        aspectRatio: 3 / 1,
    } );
} );
// -->
</script>

CSS

<style>
<!--
#jquery-ui-resizable {
    width: 300px;
    height: 100px;
    padding: 0.5em;
}
#jquery-ui-resizable h3 {
    text-align: center;
    margin: 0px 0px 0.5em 0px;
}
-->
</style>

HTML

<div id="jquery-ui-resizable" class="ui-widget-content">
    <h3 class="ui-widget-header">Resizable</h3>
    <p>このボックスは、サイズを変更できる。</p>
</div>

スポンサード リンク

カテゴリー: GUI, JavaScript, jQuery, jQuery UI, Resizable パーマリンク