ドアドアドアドアの店まで来てよ!


9

課題は2つあります。

ドアを構築するプログラムを作成します。ASCII、HTMLまたはその他

ドアを機能させる。開閉

入力または対話を通じて開くことができます!

  • 非機能ドア+5ポイント。
  • 扉が開くだけで+10ポイント。
  • インタラクティブドア+15ポイント。
  • ファンシードア+20ポイント。これは回転、バイフォールドなどを意味します
  • アニメーション+20ポイント。
  • 100文字未満+50ポイント。
  • 描画またはアニメーション用に特別に設計されたプログラムを使用すると、-100ポイント。

基準の提案がある場合は、コメントに残してください。

機能しない開いたドアの例:

<?php
$idiots_in_room=true;

if($idiots_in_room)
{

$count=20;
$count2=7;
for($i=0;$i<$count;$i++)
{

if($i==0)
{
echo str_repeat("-",10);
if($i==0){echo ".";}
echo "\n";
}
elseif($i==9)
{
echo str_repeat("-",10);
echo str_repeat(" ",7)."o"."|";
echo "\n";
}
elseif($i<=9)
{

echo str_repeat("-",1).str_repeat(" ",8).str_repeat("-",1);

echo ($i<5) ? str_repeat(" ",$i*2)."\\" : str_repeat(" ",8)."|";
echo "\n";
}
elseif($i<=14)
{
if($i>9){echo str_repeat(" ",$i)."\\";}
echo str_repeat(" ",$count2--)."|";
echo "\n";
}

}
}

出力例:

----------.
-        -  \
-        -    \
-        -      \
-        -        \
-        -        |
-        -        |
-        -        |
-        -        |
----------       o|
          \       |
           \      |
            \     |
             \    |
              \   |

ドアの例はありますか?
beary605 2012

@ beary605非機能的な例が提供されています
Event_Horizo​​n

2
「扉」を定義
ジョエル・コルネット

ドアのASCIIコード(または画像)に外部ファイルを使用するのはどうですか?彼らはどのように数えるのですか?
jazzpi 2013

回答:


22

JavaScript、4380文字、65(?)ポイント

ASCII?小切手。HTML?小切手。ドアはありますか?小切手。開閉式ドア?小切手。インタラクティブ?小切手。ファンシー?適切に配置されたヒンジを備えた両開きドア、それが重要であることを願っています。アニメーション?小切手。100文字未満?ハ。描画を目的とした機能を使用していませんか?小切手。

ライブデモ。(注:Firefoxでのテストでは、ドアを2回以上クリックしても機能しません。何らかの理由で、イベントハンドラーが再び起動せず、理由がわからないので、間違ったことを指摘するのは大歓迎です。とにかく、まともなJSパフォーマンスを得るために、これをChromeで実行することをお勧めします。)

<title>Door</title>
<pre onmouseup="turn();" style="display: table; margin: auto; font-family: 'Monaco', monospace; font-size: 0.6em; line-height: 0.7em;">
</pre>
<p>Click doors to open or close.</p>
<script>

  // Appearance of hit surface - global used to avoid allocating a record to return
  var mat;

  // Scene construction tools
  function box(size,ms) {
    return function (x, y, z) {
      var vdist0 = Math.abs(x) - size[0];
      var vdist1 = Math.abs(y) - size[1];
      var vdist2 = Math.abs(z) - size[2];
      mat = vdist0 > vdist1 && vdist0 > vdist2 ? ms[0] :
            vdist1 > vdist0 && vdist1 > vdist2 ? ms[1] :
            ms[2];
      return Math.max(vdist0, vdist1, vdist2);
    };
  }
  function translate(vec, obj) {
    var dx = vec[0];
    var dy = vec[1];
    var dz = vec[2];
    return function (x, y, z) { return obj(x - dx, y - dy, z - dz); };
  }
  function mirror(obj) {
    return function (x, y, z) { return obj(-x, y, z); };
  }
  function spin(obj) {
    return function (x, y, z) {
      var a = Date.now() / 1000;
      var s = Math.sin(a);
      var c = Math.cos(a);
      return obj(
        x * c + z * s,
        y,
        x * -s + z * c
      );
    };
  }
  function doorturn(obj) {
    return function (x, y, z) {
      var a = pos;
      var s = Math.sin(a);
      var c = Math.cos(a);
      return obj(
        x * c + z * s,
        y,
        x * -s + z * c
      );
    };
  }
  function rotx(a, obj) {
    return function (x, y, z) {
      var s = Math.sin(a);
      var c = Math.cos(a);
      return obj(
        x,
        y * c + z * s,
        y * -s + z * c
      );
    };
  }
  function roty(a, obj) {
    return function (x, y, z) {
      var s = Math.sin(a);
      var c = Math.cos(a);
      return obj(
        x * c + z * s,
        y,
        x * -s + z * c
      );
    };
  }
  function union(as, bs) {
    return function (x, y, z) {
      var a = as(x, y, z); var am = mat;
      var b = bs(x, y, z);
      if (a < b) {
        mat = am;
        return a;
      } else {
        return b;
      }
    };
  }

  // Display parameters
  var vw = 80, vh = 80;
  var timestep = 1/30;

  // Scene
  var wallhwidth = 30;
  var wallhheight = 35;
  var wallmat = [";", "\u2014", ":"];
  var dhwidth = 10;
  var dhheight = 20;
  var hthick = 2;
  var door = translate([-dhwidth*2, 0, 0], doorturn(translate([hthick, 0, dhwidth], box([hthick, dhheight, dhwidth], [".", "\u2014", "|"]))));
  var doors = union(door, mirror(door));
  var wall = union(
    union(
      translate([dhwidth*2+wallhwidth, 0, -hthick], box([wallhwidth, wallhheight, hthick], wallmat)),
      translate([-dhwidth*2-wallhwidth, 0, -hthick], box([wallhwidth, wallhheight, hthick], wallmat))),
    translate([0, wallhheight-(wallhheight-dhheight)/2, -hthick], box([dhwidth*2, (wallhheight-dhheight)/2, hthick], wallmat)));
  var floor = translate([0, -dhheight - 1.1, 0], box([100, 1, 100], ["/","/","/"]));
  var sill = translate([0, -dhheight - 1, -hthick], box([dhwidth*2, 1, hthick], ["\\","%","\\"]));
  var sbox = translate([0, 0, -12], spin(box([8, 8, 8], ["x", "y", "z"])))
  var scene = union(sbox, union(union(wall, doors), union(floor, sill)));
  var view = translate([vw/2, vh/2, -100], rotx(0.2, roty(-0.6, scene)));

  // Animation state
  var pos = -Math.PI/2;
  var dpos = 0;
  var interval;

  // Main loop function
  function r() {
    // Update state
    pos += dpos * timestep;
    if (Math.abs(pos) >= Math.PI/2) {
      dpos = 0;
      pos = Math.PI/2 * pos / Math.abs(pos);
      if (pos < 0) { // no animation needed
        clearInterval(interval); interval = undefined;
      }
    }

    // Render scene
    var t = [];
    for (var y = vh - 1; y >= 0; y--) {
      for (var x = 0; x < vw; x++) {
        var z = 0, distance;
        while ((distance = view(x,y,z)) > 0.12) {
          z -= distance;
          if (!isFinite(z) || z < -1000) {
            mat = " ";
            break;
          }
        }
        t.push(mat);
      }
      t.push("\n");
    }
    document.getElementsByTagName("pre")[0].textContent = t.join("");
  }

  // Click handler
  function turn() {
    if (dpos !== 0) {
      dpos *= -1;
    } else {
      dpos = (pos < 0 ? 1 : -1) * 2.3;
    }
    if (!interval) {
      interval = setInterval(r, timestep*1000);
    }
  }

  // Render initial state
  r();
</script>

ドアを閉じると、次のようになります。

(閉じたドアのスクリーンショット。)


1
お奨めは、それはそこにいくつかの美しい作品です。
Event_Horizo​​n

1
それはすごいね。
MrZander

9

HTML&CSS3、55ポイント

ファンシーでインタラクティブなアニメーションドアは55ポイントだと思います。

はい、これは他のドアと同じように開きますが、スライドドアが派手なものとして数えられる場合、なぜ回転ドアではないのですか?回転するドアが派手でなければ、引き戸は問題ありません:)

デモはhttp://result.dabblet.com/gist/3132160/ac475112dbba493d2dd7d98493d4f4ceaa209a7cから入手できます。ドアノブをクリックして開閉します。JavaScriptは必要ありません。それはCSS3の魔法です。

#wall {
    background-color: #eee;
    bottom: 0;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    transform: rotateX(-10deg);
    transform-origin: 0 100%;
    transform-style: preserve-3d;
}

#door-container {
    background-color: black;
    height: 100%;
    margin: 0 auto;
    width: 300px;
}

#door {
    background-color: brown;
    height: 100%;
    margin: auto;
    position: relative;
    transform-origin: 0 0;
    transition: transform 0.5s ease;
    width: 300px;
}

#door .knob {
    background-color: gold;
    border-radius: 10px;
    height: 20px;
    margin-top: -10px;
    position: absolute;
    right: 10px;
    top: 50%;
    width: 20px;
}

#open:target + #wall #door {
    transform: rotateY(-145deg);
}

#open:target + #wall #open-link {
    display: none;
}

#close-link {
    display: none;
}

#open:target + #wall #close-link {
    display: inline;
}
<span id="open"></span>
<div id="wall">
    <div id="door-container">
        <div id="door">
            <a href="#open" id="open-link" class="knob"></a>
            <a href="#closed" id="close-link" class="knob"></a>
        </div>
    </div>
</div>

スライディングとは、元々はパティオのように「スライドガラスのドア」を意味していましたが、それが派手であるとは考えられないこともわかりました(特に、回転よりもはるかに簡単であるため、コーディング用語では)。また、回転ドアとは回転を意味しました。修正します。
Event_Horizo​​n

6

Mathematica 271文字

Manipulate[a = {0, 0, 0}; b = {0, 0, h}; p = Polygon; c = Cuboid; t = Rotate;Graphics3D[{c@{{-w - 1, 0, 0}, {-w, 1, h}}, c@{{w + 1, 0, 0}, {w, 1, h}},t[p@{a, b, {-w, 0, h}, {-w, 0, 0}}, r, {0, 0, 1}, {- 2 w/3, -w/3, 0}], t[p@{a, b, {w, 0, h}, {w, 0, 0}}, -r, {0, 0, 1}, { 2 w/3, -w/3, 0}]}],{{r, 0}, 0, 3/2}, {{w, 2}, 1, 3}, {{h, 4}, 3, 5}]

ドア

両開きドア

  • 0から90度の回転で開く(スライダーを使用r
  • スライダー(hおよびw)で高さと幅を設定できます。
  • 3D照明環境にある
  • インタラクティブに回転させて、さまざまな角度から見ることができます。

コードはSándorKabalによるプログラムに基づいています。


4

Python-65ポイント、86文字

インタラクティブで100文字未満。

入力を待ち、ドア表示します。有効な入力は、「open」、「close」、「bye」です。

g,s=1,'open close'
while g:
 i=raw_input()
 print '_'+'/_ '[s.find(i)/5]+'_'
 g=i in s

コマンドを入力せずにオープン/クローズを切り替えるように設定し、要件を満たせば、文字数を節約できます。
Joel Cornett、2012

2
おそらく、しかし再び、これはコードゴルフではないので、それは本当に問題ではありません;)
daniero

1
かなり退屈に見えるドアですが、見栄えの良いネズミ
捕り

4

Mathematica 127文字

これは、先に提出したものよりも合理化された実装です。それは単一のドアを持っています。片開き

  • 0から90度の回転で開きます(スライダーを使用o
  • 3D照明環境にあります
  • インタラクティブに回転させて、さまざまな角度から見ることができます。

ただし、ドアの高さと幅は固定されています。

Manipulate[a = {0, 0, 0}; Graphics3D[{Tube[{a, {1, 0, 0}, {1, 0, 2}, {0, 0, 2}, a}, .03],Rotate[Cuboid@{a, {1, -.1, 2}}, o, {0, 0, 1}, a]}], {o, 0, -Pi/2}]

door2


新しい投稿を送信するのではなく、以前の投稿を編集したはずです。
Joe the Person

@ fireDude67これがコードゴルフの課題だった場合は、以前のエントリを短いコードに置き換えただけです。ただし、SOは短いプログラムとより複雑なプログラム(より多くの機能を備えたドア)の両方への関心を示しました。
DavidC

ああごめんなさい、混乱しました
Joe the Person

@ fireDude67問題ありません。
DavidC
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.