Dessine le drapeau sud-coréen


58

Lorsque je suis tombé par hasard sur cette question, je me suis rappelé que j'avais déjà vu des règles précises pour la construction du drapeau sud-coréen. Et c'est une construction assez différente.

entrez la description de l'image ici

Source: Wikipedia

Donc, vous devez dessiner une construction exacte de celui-ci maintenant!

spécification

Vous pouvez rendre l'indicateur au fichier ou à l'écran à l'aide de graphiques vectoriels ou raster. Si votre sortie est pixellisée, votre image doit avoir des dimensions de 450 x 300 pixels ou plus.

Tous les rapports de longueur et les positions doivent être exactement comme indiqué dans le diagramme suivant:

entrez la description de l'image ici

Source: Wikipedia

Notez que les centres des deux petits cercles s'alignent sur la diagonale.

Pour les couleurs, vous devez utiliser la palette suivante:

  • Blanc: #FFFFFF
  • Noir: # 000000
  • Rouge: # C60C30
  • Bleu: # 003478

La limite noire ne doit pas être tracée sauf si votre système de dessin ne vous permet pas de spécifier une toile 3: 2 pour des raisons techniques (sinon, vous devez utiliser une toile 3: 2 et le drapeau doit la remplir en totalité). Si vous devez ajouter la limite, elle peut être arbitrairement épaisse - le drapeau doit être considéré strictement à l' intérieur de la limite noire. Aucune autre ligne d'aide ou indicateur de longueur ne doit être tracé. C'est-à-dire que le drapeau devrait apparaître exactement comme dans la première image.

Notation

C'est le code de golf, donc la réponse la plus courte (en octets) gagne.

En guise de mise en garde, l’utilisation de la compression existante (comme l’incorporation d’un fichier GIF compressé) tombe dans plusieurs failles standard .


2
Fait intéressant, le drapeau coréen contient une forme ancienne du système de nombres binaires ( britton.disted.camosun.bc.ca/jbbinflag.htm )
britishtea

Devons-nous tracer la bordure lorsque nous utilisons une page HTML plus grande que le drapeau, étant blanc, aucune séparation n'est visible même si la taille de la zone de dessin / de l'élément est similaire à celle du drapeau
Optimiseur,

@Optimizer, non, si le canevas est délimité de manière à pouvoir être rendu visible (par exemple, en mettant en surbrillance "l'élément inspecté" de votre navigateur), vous n'avez pas besoin de limite. La bordure noire ne doit être tracée que dans les rares cas où l'étendue de la toile ne peut pas être définie techniquement.
Martin Ender

3
Je suppose que CountryData["ROK","Flag"]ça ne compte pas?
wchargin

Réponses:


13

PHP / HTML / SVG, 324

(sauts de ligne ajoutés pour plus de lisibilité)

<?=gzinflate(base64_decode('tVHBioMwFPyVwF5WSOzLi/tswQjdu9cevIk1KqtriaFd9utrgpSWFva0PPImMwzDkGTz
uWXnvrl8Tj8aOPAUebLNs5Y5W33PZrKjtpOrXPOuVEy7KMiD54mKMY3yrO5tPTTMaonM9MOg32qCWgHb5Nmpch076kIih/2y
PC4jRRCIU6BhbkwGV7lmAagk3d5nCfwQdKByVBwOFLagQu6exZLNzk5fjU+B9S4u/dF1Gh/apRw6Cb83uzHm0S69/cWbSIkx
YfSf5QT6dkk5UoACIeAfXTftepb/za8='));

Les données compressées sont étendues aux mêmes données SVG que ma réponse précédente, mais avec deux modifications pour faciliter la compression:

  1. Les deux <use>sections sont étendues au contenu d'origine de la <defs>section. Cela allonge le texte source, mais réduit l'entropie et compresse mieux.

  2. Dans le premier <g>élément, j'ai changé transform=translate(36,24)rotate(33.69)pour transform=rotate(33.69)translate(43.27). Cela a le même effet géométrique, mais compresse mieux car la séquence ><g transform=rotate(apparaît maintenant deux fois.

Par défaut, PHP utilisera ceci comme Content-Type: text/html, donc la syntaxe XML invalide ne devrait pas être un problème.

SVG / HTML, 463

L'analyseur HTML ne s'inquiète pas trop de la syntaxe correcte. Nous pouvons donc supprimer les guillemets dans les paramètres tant qu'ils ne contiennent pas d'espaces. Il devrait être possible de réduire cela avec un peu de Javascript.

<svg viewBox=0,0,72,48><defs><path d=M-25-6V6Zm3,0V6m3,0V-6M19-6V6Zm3,0V6m3,0V-6Z stroke=#000
stroke-width=2 id=p /></defs><g transform=translate(36,24)rotate(33.69)><circle r=12 fill=#c60c30
/><path d=M12,0A12,12,0,0,1-12,0A6,6,0,0,0,0,0A6,6,0,0,1,12,0Z fill=#003478 /><use xlink:href=#p
/><path d=M17,0h10z stroke=#fff stroke-width=1 /><g transform=rotate(112.62)><use xlink:href=#p
/><path d=M-27,0h4Zm6,0h4ZM20,0h4Z stroke=#fff stroke-width=1 /></g></g></svg>


44

Python + Pycairo, 371 370 366 octets

Drapeau

from cairo import*
p=3.141593
c=Context(SVGSurface("F",12,8))
C=c.set_source_rgb;R=c.rectangle;T=c.rotate;F=c.fill
C(1,1,1);R(0,0,12,8);F()
c.translate(6,4);T(.588);b=3188
for o in[(0,.2,.47),(.77,.05,.19)]*2:C(*o);i=b/2%2;b+=1;c.arc(i,0,2-i,0,p+i*p);F();T(p)
C(0,0,0)
for x in(p,1.966)*2:
 for y in.5,0,1:
    for z in-1,1:R(3+y,-z,1./3,z*(2.75+b%2)/3);F()
    b/=2
 T(x)

Sort un fichier SVG nommé F.


C(*[.77,0,.05,.2,.19,.47][i::2])est plus court queC(*[(.77,.05,.19),(0,.2,.47)][i%2])
isaacg

Pourquoi écrivez-vous s=SVGSurface("F",12,8);c=Context(s)au lieu de juste c=Context(SVGSurface("F",12,8))?
Lily Chung

@ IstvanChung Bon point.
Ell

32

HTML + CSS, 966 906 843 792 762 octets

Pas un gagnant à tout moment, mais beaucoup de plaisir à dessiner en CSS. Cela peut être beaucoup joué au golf cependant.

CSS, HTML :

*{position:fixed}a{background:linear-gradient(0deg,#003478 50%,#C60C30 50%);width:2in;height:2in;transform:rotate(.6rad);top:1in;left:2in}d,e{width:50%;height:50%;background:#C60C30;left:0;top:25%}a,d,e{border-radius:50%}d{background:#003478;left:50%}b,i{width:1in;height:26em;top:-1em;left:15em;transform:rotate(.98rad)}g,f,k,j{width:1in;height:17%;background:repeating-linear-gradient(0deg,#000,#000 1em,#fff 1em,#fff 1.5em);bottom:0;left:0}g,j,p{top:-.5em}b{transform:rotate(-.98rad)}c,p,v,x{height:2em;width:.5em;background:#fff;transform:rotate(.98rad)}p{top:2.8in;left:28em;transform:rotate(-.98rad) scale(1,4)}x{top:3.9em;left:28.4em}c,v{top:23.8em;transform:none}c{top:3.5em}body{height:4in;width:6in;border:1px solid
<a><d><e></a><b><f><g></b><i><j><k></i><p></p><x><v><c

;border:1px solidest juste pour montrer car l' <body>étiquette a des limites claires qui peuvent être observées par Inspector ou des outils similaires, comme indiqué par le PO

REMARQUE Fonctionne uniquement dans Firefox (ou Chrome canary / dev) en raison de l'utilisation de transformations et de dégradés non spécifiques au fournisseur.

Le voir en action


Je pense que vous devriez inclure des balises <link> ou <style> dans le nombre de vos personnages. Vous pouvez sauvegarder quelques caractères: en CSS 0deg-> 0(deux fois) et supprimer left:0de a:before. En HTML, vous pouvez utiliser <p><ul></ul>. ( <p>sera implicitement fermé avant <ul>)
gronostaj

1
Fonctionne dans Firefox 32. Échec spectaculaire dans Safari 7.1.
200_success

1
Utilisez LESS ou SASS pour le CSS, ce qui devrait vous donner pas mal d’options pour le raccourcir un peu. De plus :before{content:''}et :after{content:''}sont plus longs que le simple ajout d' un autre élément ( en dépit de cette recherche bien mieux).
David Mulder

@ DavidMulder Je voulais le facteur amusant dans ce code plutôt que plus court. Les gens peuvent se rapporter au CSS pur plus facilement que LESS ou SASS :)
Optimiseur,

Fonctionne également dans le dernier Chrome. @ 200_success Vous devriez pouvoir le faire fonctionner dans Safari en ajoutant -webkit-avant tout le transform:s, mais inutile de dire que cela le rendrait un peu plus long!
Poignée de porte

20

BBC Basic, 349 343 caractères ASCII, taille de fichier avec jeton 330

Téléchargez l'émulateur à l' adresse http://www.bbcbasic.co.uk/bbcwin/bbcwin.html

  p=1049q=25r=100VDU4118;275;-1,49,3076;19,7,-1;-1;531;255;7693;q;40;0;q,97,1200;800;29,640;400;
  FORa=38TO56STEP0.01x=r*COS(a)y=r*SIN(a)b=a*7DIV44/2IFb=3.5z=y<0ELSEz=x>0
  VDU18;1,p;-x;-y;q,153,r;0;18;2,p;x;y;q,153,r;0;18;0
  IFABS(y)DIV1=56VDUp;x*b+y;y*b-x;q;x/3;y/3;q,113,-2*y;2*x;18;7:b-=0.1VDUp;x*b+y/12;y*b-x/12;q;x/2;y/2;q,112-z,-y/6;x/6;
  NEXT

L’utilisation des couleurs correctes a ajouté beaucoup, mais la mise en jeu de toutes les commandes graphiques jusqu’à des codes vDU bruts permet d’économiser 6 caractères au total par rapport à mon message original. Tous les graphiques sur le micro BBC sont créés via des codes de contrôle ASCII spécifiques à la machine. Ainsi, au lieu d’utiliser des commandes graphiques de haut niveau, vous pouvez envoyer des octets directement au contrôleur VDU (généralement plus court, mais la lisibilité est très coûteuse). Une valeur se terminant par un point-virgule au lieu d'une virgule est une représentation little-endian de 16 bits de 2 octets.

Version non-golfée

  MODE16
  VDU19,1,-1,49,4,12                :REM adjust shade of red 
  VDU19,7,-1,-1,-1,-1               :REM adjust shade of white to full brightness (63 is 2's complement representation of -1
  VDU19,4,-1,0,13,30                :REM adjust shade of blue
  RECTANGLEFILL40,0,1200,800        :REM plot background rectangle
  ORIGIN640,400
  FORa=38TO56STEP0.01
    x=COS(a)*100
    y=SIN(a)*100
    GCOL1:CIRCLEFILL-x,-y,100       :REM red
    GCOL4:CIRCLEFILLx,y,100         :REM blue
    GCOL0                           :REM black
    b=a*7DIV44/2                    :REM divide a by 2*(22/7) to get integer representation, then divide by 2 again.
    IFb=3.5THENz=y<0ELSEz=x>0       :REM decide whether to cut bar
    REM If the angle is correct (100*sin(a) = 56) draw bar. If required, cut out the middle of the bar.
    IFABS(INT(y))=56 MOVEx*b+y,y*b-x:MOVEBY x/3,y/3:PLOT113,-2*y,2*x:GCOL7:b-=0.1:MOVEx*b+y/12,y*b-x/12:MOVEBY x/2,y/2:IFz PLOT113,-y/6,x/6
  NEXT

Au début du programme, je déplace l'origine au centre de l'écran.

Je ne trace pas de grands demi-cercles colorés. Au lieu de cela, je lance une boucle qui dessine de petits cercles rouges et bleus, tournant dans le sens contraire des aiguilles d'une montre. Je fais presque 3 tours complets (en commençant par le bleu à droite), ce qui est évidemment plus que suffisant pour remplir le disque. Je m'arrête au 3ème tour, juste quand le bleu en bas à droite est dans la bonne position pour s'aligner avec les barres (qui doivent être tracées.)

Lorsque l'angle est correct, je dessine une des barres. le vecteur x, y servant à dessiner le petit cercle bleu actuel sert à indiquer la direction dans laquelle la barre doit être. Pour chacune des 3 révolutions, une valeur différente de l’entier a*7DIV44est calculée. Elle indique si la première, la deuxième ou la troisième barre doit être dessinée, avec son bord intérieur à 6 / 8,7 / 8 ou 8/8 unités du centre ( en fonction des unités utilisées dans la spécification de la question.) Étant donné que les unités du programme correspondent à 1/4 de celles spécifiées, il s'agit toujours d'une demi-unité; nous divisons donc à nouveau par 2 avant d'enregistrer dans la variable ´b´ afin d'éviter une répétition de la moitié plus tard.

Les barres sont dessinées pleines, puis le milieu est supprimé si nécessaire. Cela évite que des nœuds ne rejoignent les demi-barres. La variable z indique si une barre doit être coupée. C'est-à-dire que lorsque y est négatif pour les barres du milieu et lorsque x est positif pour les autres barres.

MOVEest un coup absolu. MOVEBYest un mouvement relatif. PLOT133considère les deux dernières positions du curseur graphique, plus la nouvelle spécifiée (en coordonnées relatives) comme les trois coins d'un parallélogramme, et trace le tracé de ce parallélogramme.

Résultat (et discussion sur les limitations linguistiques)

J'ai sélectionné un mode d'écran de 1280x800 pixels logiques = 640x400 pixels physiques, qui ont par défaut un fond noir. Sur cela, je dessine un rectangle blanc de -600, -400 à 600.400 qui agira comme ma "toile".

BBC Basic peut gérer 16 couleurs à la fois, à partir d’une palette reprogrammable. Mais il ne prend en charge que les couleurs 18 bits, alors que la question précise que les couleurs sont au format 24 bits. Les couleurs aussi proches que possible.

entrez la description de l'image ici


2
J'ai reformulé un peu les spécifications concernant les limites. La façon dont vous l'avez géré correspond à peu près à mes intentions.
Martin Ender

16

Tortue Python 3 ( 552 549 octets)

Drapeau

( Image en taille réelle )

Edit: Maintenant que nous avons Stack Snippets, voici un test Stack Snippet utilisant Skulpt , avec l’aide de la réponse d’ArtOfCode ici . Malheureusement, Skulpt n’ayant pas encore complètement implémenté Python, j’ai dû mutiler la moitié de mon code pour que cela fonctionne. En d'autres termes, cet extrait de code n'a pour but que d'indiquer le fonctionnement de mon programme (sans avoir à extraire Python).

(En outre, je constate que cela pourrait ne pas fonctionner avec certains navigateurs ...)

function out(a){var b=document.getElementById("output");b.innerHTML+=a}function builtinRead(a){if(void 0===Sk.builtinFiles||void 0===Sk.builtinFiles.files[a])throw"File not found: '"+a+"'";return Sk.builtinFiles.files[a]}
$(document).ready(function run(){Sk.canvas="canvas";Sk.configure({output:out,read:builtinRead});try{Sk.importMainWithBody("<stdin>",!1,'import turtle\nimport math\nt=turtle.Turtle()\nt.speed(9)\nR="#c60c30"\nr=56.3\nk=0.6\ns=60*k\noffsetx,offsety=-215,-145\nt.up()\nt.goto(offsetx,offsety)\nt.down()\ndef q():t.rt(90)\ndef Q():t.lt(90)\ndef K():t.color("black");t.begin_fill();q()\ndef A(g,G):t.fd(g);Q();t.fd(G);Q();t.fd(g);Q();t.fd(G);Q()\ndef E():t.up();t.fd(s);t.down();Q();t.end_fill();t.up();t.fd(30*k);t.down();\ndef i():K();t.up();t.bk(s);t.down();A(120*k,20*k);E()\ndef I():K();t.up();t.fd(5*k);t.down();A(55*k,20*k);t.up();t.bk(65*k);t.down();A(55*k,20*k);E()\ndef C():t.circle(120*k,180)\nA(720*k,480*k)\nt.seth(r)\nt.up()\nt.goto(459.8*k+offsetx,173.4*k+offsety)\nt.down()\nt.color(R)\nt.begin_fill()\nC()\nt.end_fill()\nt.begin_fill()\nt.color("#003478")\nC()\nt.circle(s)\nt.end_fill()\nt.color(R)\nC()\nt.begin_fill()\nt.circle(s)\nt.end_fill()\nq()\nt.up()\nt.fd(s)\nt.down()\ni()\ni()\ni()\nt.up()\nt.bk(530*k)\nt.down()\nI()\nI()\nI()\nt.up()\nt.fd(170*k)\nt.rt(2*r)\nt.fd(180*k)\nt.down()\nI()\ni()\nI()\nt.up()\nt.bk(530*k)\nt.down()\ni()\nI()\ni()\n')}catch(a){throw Error(a.toString());}})
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js"></script><script src="http://www.skulpt.org/static/skulpt.min.js" type="text/javascript"></script><script src="http://www.skulpt.org/static/skulpt-stdlib.js" type="text/javascript"></script>
<canvas height="320" width="480" id="canvas" style="border:1px solid gray">Your browser does not support HTML5 Canvas!</canvas>


Code actuel:

import turtle as t
b=t.begin_fill
c=t.circle
e=t.end_fill
f=t.fillcolor
R="#c60c30"
r=56.3
F=t.fd
B=t.bk
s=60
def q():t.rt(90)
def Q():t.lt(90)
def K():f(0,0,0);b();q()
def A(g,G):exec("F(g);Q();F(G);Q();"*2)
def E():F(s);Q();e();F(30)
def i():K();B(s);A(120,20);E()
def I():K();F(5);A(55,20);B(65);A(55,20);E()
def C():c(120,180)
A(720,480)
t.seth(r)
t.up()
t.goto(459.8,173.4)
f(R)
b()
C()
e()
b()
f("#003478")
C()
c(s)
e()
C()
f(R)
b()
c(s)
e()
q()
F(s)
i()
i()
i()
B(530)
I()
I()
I()
F(170)
t.rt(2*r)
F(180)
I()
i()
I()
B(530)
i()
I()
i()
t.ht()

Comme la tortue est si lente, si vous voulez des résultats instantanés, vous pouvez les ajouter t.tracer(0)après la première ligne avant d'exécuter le script.

Remarque: pour une raison quelconque, tortue continue à dessiner ce qui ressemble à des pixels noirs supplémentaires même si je l’ai déjà appelé up(), et je ne sais pas pourquoi ...


Je crois que quelqu'un a implémenté Python (avec la tortue!) Dans le post de Stack Snippets; Si vous vouliez savoir comment, vous pourriez être l'un des premiers à utiliser cette nouvelle fonctionnalité! ;)
Poignée de porte

@Doorknob J'ai dû détruire la moitié de mon code pour qu'il puisse même faire ce que je voulais, mais au moins il fait visuellement la même chose qu'en Python maintenant. (Mais cela ne fonctionne pas sur mon Chrome pour une raison quelconque ...)
Sp3000

2
Fonctionne bien sur Chrome iOS. Heureux de voir que quelqu'un a trouvé une utilité à mon projet cependant :)
ArtOfCode

14

HTML + ES6, 388

<canvas id=D width=576 height=384><script>c=D.getContext('2d')
T=x=>c.translate(x*72,x*48)
R=(x,y)=>T(4)+c.rotate(x*.59)+T(-4)+eval('for(i=j=0;i*j<6;i+=(j^=1))c.fillRect(72+24*i+(i>2)*288,144+j*52,16,44+52*(y>>i&1-j))')
A=(w,x,y,z)=>(c.fillStyle=c.fill()+c.beginPath()||w)*c.arc(x*4,192-y,48*y,0,3.1,z)||A
R(-1,21)
R(2,7)
A(r='#C60C30',72,2,1)('#003478',72,2)(0,84,1,1)(r,60,1)()</script>

Si votre navigateur prend en charge ES6, vous pouvez le visualiser sur JSFiddle ou exécuter l'extrait de code .

Il construit le drapeau à partir de certaines formes de base, en faisant d'abord pivoter la toile pour tenir compte des angles.


Juste une remarque, cela ne fonctionne pas dans Chrome 39, mais dans FF> 29.
JBCP

<canvas width=576 height=384 id=D><script>c=D.getContext('2d')est de 9 octets de moins. De plus, comme toute la page est blanche, je pense que vous devez dessiner la bordure.
Optimiseur

@ Optimiseur Merci. Si j'ai bien compris, la bordure n'est nécessaire que lorsque vous avez une toile infinie.
grc

5
Vous pouvez essayer ceci avec Stack Snippets!
Beta Decay

@BetaDecay cela a réellement fonctionné: o
grc

6

Mathematica 404 450

b=1&~Array~13;a=ReplacePart[b,7-> 0];d=Disk;r=RGBColor;
z@{q_,p_,s_}:=ArrayPlot[{q,q,{},p,p,{},s,s},Frame-> False,ImageSize-> 155];
m=r@@{0,.2,.5};
o=r@@{.8,0,.2};
t=-19.1;u=-12.75;v=-5;q=-3.33;
Graphics[{Line[{{-36,-24},{36,-24},{36,24},{-36,24},{-36,-24}}],
Inset[Rotate[z@#,#2 125 Degree],#3]&@@@{{{b,a,b},1,{t,u}},{{a,b,a},1,{-t,-u}},
{{a,a,a},-1,{-t,u}},{{b,b,b},-1,{t,-u}}},
{o,d[{0,0},12,{-.2 Pi,.8Pi}],m, d[{0,0},12,{.8Pi,1.8Pi}],o,d[{v,-q},6],m,d[{-v,q},6]}}]

drapeau


3

C ++ TROP GRAND

A tenté cela en utilisant ma bibliothèque de dessins PPM faite à la maison . Il est techniquement évolutif, mais je suis limité par ma fonction de remplissage récursif, car elle est peu fiable et aime les erreurs de segmentation. Je pense qu’elle utilise trop de mémoire, je ne laisse donc pas l’utilisateur régler l’échelle. L'image est irrégulière car les coordonnées que j'ai entrées pour chaque coin des barres sont légèrement décalées. entrez la description de l'image ici

Je l'ai configuré pour commencer avec un fond noir, puis j'ai placé un cercle blanc au centre, puis des cercles rouges et bleus. Utilisé des remplissages récursifs pour ajouter le reste de rouge et de bleu. Ensuite, a dessiné des rectangles avec des lignes blanches pour marquer les barres noires. Divisez le fond noir en 4 sections avec des lignes blanches et utilisez 4 remplissages récursifs pour rendre chaque section blanche. Le faire en un seul passage aurait causé une erreur de segmentation. C'est toujours très lent à rendre.

Code principal non-golé (le reste de la bibliothèque est trop volumineux, jouer au golf importe peu)

#include "PPMDraw.h"
#include <iostream>

int main(){
    std::cout << "Drawing Korean Flag" << std::endl;

    int scale = 150;
    int width = 3 * scale;
    int height = 2 * scale;

    int xc = width/2;
    int yc = height/2;

    // coords for the bar corners
    float nwax = -0.773; float nway = -0.813;
    float nwbx = -0.707; float nwby = -0.773;
    float nwcx = -1.000; float nwcy = -0.360;
    float nwdx = -1.050; float nwdy = -0.400;
    float nwex = -0.667; float nwey = -0.747;
    float nwfx = -0.613; float nwfy = -0.693;
    float nwgx = -0.880; float nwgy = -0.293;
    float nwhx = -0.947; float nwhy = -0.333;
    float nwix = -0.560; float nwiy = -0.667;
    float nwjx = -0.507; float nwjy = -0.627;
    float nwkx = -0.773; float nwky = -0.227;
    float nwlx = -0.840; float nwly = -0.267;

    float neax = 0.747; float neay = -0.813;
    float nebx = 0.867; float neby = -0.627;
    float necx = 0.813; float necy = -0.587;
    float nedx = 0.680; float nedy = -0.773;
    float neex = 0.893; float neey = -0.587;
    float nefx = 1.030; float nefy = -0.400;
    float negx = 0.960; float negy = -0.360;
    float nehx = 0.840; float nehy = -0.547;
    float neix = 0.640; float neiy = -0.747;
    float nejx = 0.920; float nejy = -0.333;
    float nekx = 0.853; float neky = -0.293;
    float nelx = 0.587; float nely = -0.693;
    float nemx = 0.533; float nemy = -0.667;
    float nenx = 0.667; float neny = -0.493;
    float neox = 0.600; float neoy = -0.440;
    float nepx = 0.480; float nepy = -0.627;
    float neqx = 0.693; float neqy = -0.440;
    float nerx = 0.813; float nery = -0.267;
    float nesx = 0.747; float nesy = -0.227;
    float netx = 0.627; float nety = -0.400;

    float swax = -0.773; float sway = 0.200;
    float swbx = -0.507; float swby = 0.613;
    float swcx = -0.560; float swcy = 0.653;
    float swdx = -0.840; float swdy = 0.253;
    float swex = -0.880; float swey = 0.280;
    float swfx = -0.760; float swfy = 0.453;
    float swgx = -0.813; float swgy = 0.493;
    float swhx = -0.947; float swhy = 0.320;
    float swix = -0.733; float swiy = 0.507;
    float swjx = -0.613; float swjy = 0.680;
    float swkx = -0.667; float swky = 0.720;
    float swlx = -0.787; float swly = 0.547;
    float swmx = -0.987; float swmy = 0.347;
    float swnx = -0.707; float swny = 0.760;
    float swox = -0.773; float swoy = 0.800;
    float swpx = -1.053; float swpy = 0.387;

    float seax = 0.747; float seay = 0.200;
    float sebx = 0.813; float seby = 0.253;
    float secx = 0.693; float secy = 0.427;
    float sedx = 0.627; float sedy = 0.387;
    float seex = 0.853; float seey = 0.280;
    float sefx = 0.920; float sefy = 0.320;
    float segx = 0.800; float segy = 0.507;
    float sehx = 0.733; float sehy = 0.453;
    float seix = 0.960; float seiy = 0.347;
    float sejx = 1.036; float sejy = 0.387;
    float sekx = 0.893; float seky = 0.573;
    float selx = 0.840; float sely = 0.520;
    float semx = 0.600; float semy = 0.427;
    float senx = 0.667; float seny = 0.467;
    float seox = 0.547; float seoy = 0.653;
    float sepx = 0.480; float sepy = 0.613;
    float seqx = 0.707; float seqy = 0.493;
    float serx = 0.773; float sery = 0.547;
    float sesx = 0.640; float sesy = 0.733;
    float setx = 0.547; float sety = 0.680;
    float seux = 0.813; float seuy = 0.573;
    float sevx = 0.880; float sevy = 0.613;
    float sewx = 0.747; float sewy = 0.800;
    float sexx = 0.693; float sexy = 0.747;

    PPMDraw flag = PPMDraw(width, height);
    flag.fill(0, 0, 0);

    // draw white circle in middle
    flag.set_color(255, 255, 255);
    flag.draw_fill_circle(xc, yc, scale/2);

    // draw red and blue portions of circle
    flag.set_color(255, 0, 0);
    flag.draw_fill_circle(xc - .21*scale, yc - .14*scale, scale/3.9);
    flag.set_color(0, 0, 255);
    flag.draw_fill_circle(xc + .21*scale, yc + .14*scale, scale/3.9);
    flag.set_color(255, 0, 0);
    flag.recursive_fill(xc + .21*scale, yc - .21*scale);
    flag.set_color(0, 0, 255);
    flag.recursive_fill(xc - .21*scale, yc + .21*scale);

    // draw the northwest bars
    flag.set_color(255, 255, 255);

    flag.draw_line(xc + nwax*scale, yc + nway*scale, xc + nwbx*scale, yc + nwby*scale);
    flag.draw_line(xc + nwax*scale, yc + nway*scale, xc + nwdx*scale, yc + nwdy*scale);
    flag.draw_line(xc + nwbx*scale, yc + nwby*scale, xc + nwcx*scale, yc + nwcy*scale);
    flag.draw_line(xc + nwcx*scale, yc + nwcy*scale, xc + nwdx*scale, yc + nwdy*scale);

    flag.draw_line(xc + nwex*scale, yc + nwey*scale, xc + nwfx*scale, yc + nwfy*scale);
    flag.draw_line(xc + nwex*scale, yc + nwey*scale, xc + nwhx*scale, yc + nwhy*scale);
    flag.draw_line(xc + nwfx*scale, yc + nwfy*scale, xc + nwgx*scale, yc + nwgy*scale);
    flag.draw_line(xc + nwhx*scale, yc + nwhy*scale, xc + nwgx*scale, yc + nwgy*scale);

    flag.draw_line(xc + nwix*scale, yc + nwiy*scale, xc + nwjx*scale, yc + nwjy*scale);
    flag.draw_line(xc + nwix*scale, yc + nwiy*scale, xc + nwlx*scale, yc + nwly*scale);
    flag.draw_line(xc + nwjx*scale, yc + nwjy*scale, xc + nwkx*scale, yc + nwky*scale);
    flag.draw_line(xc + nwlx*scale, yc + nwly*scale, xc + nwkx*scale, yc + nwky*scale);
    //NE
    flag.draw_line(xc + neax*scale, yc + neay*scale, xc + nebx*scale, yc + neby*scale);
    flag.draw_line(xc + neax*scale, yc + neay*scale, xc + nedx*scale, yc + nedy*scale);
    flag.draw_line(xc + nebx*scale, yc + neby*scale, xc + necx*scale, yc + necy*scale);
    flag.draw_line(xc + necx*scale, yc + necy*scale, xc + nedx*scale, yc + nedy*scale);

    flag.draw_line(xc + neex*scale, yc + neey*scale, xc + nefx*scale, yc + nefy*scale);
    flag.draw_line(xc + neex*scale, yc + neey*scale, xc + nehx*scale, yc + nehy*scale);
    flag.draw_line(xc + nefx*scale, yc + nefy*scale, xc + negx*scale, yc + negy*scale);
    flag.draw_line(xc + nehx*scale, yc + nehy*scale, xc + negx*scale, yc + negy*scale);

    flag.draw_line(xc + neix*scale, yc + neiy*scale, xc + nejx*scale, yc + nejy*scale);
    flag.draw_line(xc + neix*scale, yc + neiy*scale, xc + nelx*scale, yc + nely*scale);
    flag.draw_line(xc + nejx*scale, yc + nejy*scale, xc + nekx*scale, yc + neky*scale);
    flag.draw_line(xc + nelx*scale, yc + nely*scale, xc + nekx*scale, yc + neky*scale);

    flag.draw_line(xc + nemx*scale, yc + nemy*scale, xc + nenx*scale, yc + neny*scale);
    flag.draw_line(xc + nemx*scale, yc + nemy*scale, xc + nepx*scale, yc + nepy*scale);
    flag.draw_line(xc + nepx*scale, yc + nepy*scale, xc + neox*scale, yc + neoy*scale);
    flag.draw_line(xc + nenx*scale, yc + neny*scale, xc + neox*scale, yc + neoy*scale);

    flag.draw_line(xc + neqx*scale, yc + neqy*scale, xc + nerx*scale, yc + nery*scale);
    flag.draw_line(xc + neqx*scale, yc + neqy*scale, xc + netx*scale, yc + nety*scale);
    flag.draw_line(xc + nerx*scale, yc + nery*scale, xc + nesx*scale, yc + nesy*scale);
    flag.draw_line(xc + netx*scale, yc + nety*scale, xc + nesx*scale, yc + nesy*scale);

    //sw
    flag.draw_line(xc + swax*scale, yc + sway*scale, xc + swbx*scale, yc + swby*scale);
    flag.draw_line(xc + swax*scale, yc + sway*scale, xc + swdx*scale, yc + swdy*scale);
    flag.draw_line(xc + swbx*scale, yc + swby*scale, xc + swcx*scale, yc + swcy*scale);
    flag.draw_line(xc + swcx*scale, yc + swcy*scale, xc + swdx*scale, yc + swdy*scale);

    flag.draw_line(xc + swex*scale, yc + swey*scale, xc + swfx*scale, yc + swfy*scale);
    flag.draw_line(xc + swex*scale, yc + swey*scale, xc + swhx*scale, yc + swhy*scale);
    flag.draw_line(xc + swfx*scale, yc + swfy*scale, xc + swgx*scale, yc + swgy*scale);
    flag.draw_line(xc + swhx*scale, yc + swhy*scale, xc + swgx*scale, yc + swgy*scale);

    flag.draw_line(xc + swix*scale, yc + swiy*scale, xc + swjx*scale, yc + swjy*scale);
    flag.draw_line(xc + swix*scale, yc + swiy*scale, xc + swlx*scale, yc + swly*scale);
    flag.draw_line(xc + swjx*scale, yc + swjy*scale, xc + swkx*scale, yc + swky*scale);
    flag.draw_line(xc + swlx*scale, yc + swly*scale, xc + swkx*scale, yc + swky*scale);

    flag.draw_line(xc + swmx*scale, yc + swmy*scale, xc + swnx*scale, yc + swny*scale);
    flag.draw_line(xc + swmx*scale, yc + swmy*scale, xc + swpx*scale, yc + swpy*scale);
    flag.draw_line(xc + swpx*scale, yc + swpy*scale, xc + swox*scale, yc + swoy*scale);
    flag.draw_line(xc + swnx*scale, yc + swny*scale, xc + swox*scale, yc + swoy*scale);

    //se
    flag.draw_line(xc + seax*scale, yc + seay*scale, xc + sebx*scale, yc + seby*scale);
    flag.draw_line(xc + seax*scale, yc + seay*scale, xc + sedx*scale, yc + sedy*scale);
    flag.draw_line(xc + sebx*scale, yc + seby*scale, xc + secx*scale, yc + secy*scale);
    flag.draw_line(xc + secx*scale, yc + secy*scale, xc + sedx*scale, yc + sedy*scale);

    flag.draw_line(xc + seex*scale, yc + seey*scale, xc + sefx*scale, yc + sefy*scale);
    flag.draw_line(xc + seex*scale, yc + seey*scale, xc + sehx*scale, yc + sehy*scale);
    flag.draw_line(xc + sefx*scale, yc + sefy*scale, xc + segx*scale, yc + segy*scale);
    flag.draw_line(xc + sehx*scale, yc + sehy*scale, xc + segx*scale, yc + segy*scale);

    flag.draw_line(xc + seix*scale, yc + seiy*scale, xc + sejx*scale, yc + sejy*scale);
    flag.draw_line(xc + seix*scale, yc + seiy*scale, xc + selx*scale, yc + sely*scale);
    flag.draw_line(xc + sejx*scale, yc + sejy*scale, xc + sekx*scale, yc + seky*scale);
    flag.draw_line(xc + selx*scale, yc + sely*scale, xc + sekx*scale, yc + seky*scale);

    flag.draw_line(xc + semx*scale, yc + semy*scale, xc + senx*scale, yc + seny*scale);
    flag.draw_line(xc + semx*scale, yc + semy*scale, xc + sepx*scale, yc + sepy*scale);
    flag.draw_line(xc + sepx*scale, yc + sepy*scale, xc + seox*scale, yc + seoy*scale);
    flag.draw_line(xc + senx*scale, yc + seny*scale, xc + seox*scale, yc + seoy*scale);

    flag.draw_line(xc + seqx*scale, yc + seqy*scale, xc + serx*scale, yc + sery*scale);
    flag.draw_line(xc + seqx*scale, yc + seqy*scale, xc + setx*scale, yc + sety*scale);
    flag.draw_line(xc + serx*scale, yc + sery*scale, xc + sesx*scale, yc + sesy*scale);
    flag.draw_line(xc + setx*scale, yc + sety*scale, xc + sesx*scale, yc + sesy*scale);

    flag.draw_line(xc + seux*scale, yc + seuy*scale, xc + sevx*scale, yc + sevy*scale);
    flag.draw_line(xc + seux*scale, yc + seuy*scale, xc + sexx*scale, yc + sexy*scale);
    flag.draw_line(xc + sevx*scale, yc + sevy*scale, xc + sewx*scale, yc + sewy*scale);
    flag.draw_line(xc + sexx*scale, yc + sexy*scale, xc + sewx*scale, yc + sewy*scale);

    // fill in the black to white
    flag.draw_line(xc, yc - scale/2, xc, 0);
    flag.draw_line(xc, yc + scale/2, xc, height);
    flag.draw_line(xc - scale/2, yc, 0, yc);
    flag.draw_line(xc + scale/2, yc, width, yc);

    flag.recursive_fill(0, 0);
    flag.recursive_fill(0, height-1);
    flag.recursive_fill(width - 1, 0);
    flag.recursive_fill(width - 1, height - 1);

    flag.save("flag.ppm");

}

@SohamChowdhury Totalement non intentionnelle, SEXY correspond au coin Sud-Est, aux coordonnées Point X et Y.
user137

3
La vôtre est la seule solution où le drapeau flotte dans le vent!
CJ Dennis

2

PostScript , 572 477 octets

Code de golf:

5 5 scale 36 24 translate /R{.75 .05 .19 setrgbcolor}def/B{0 .20 .47 setrgbcolor}def/a 2 3 atan def/b{0 setgray[18 -6 2 12 21 -6 2 12 24 -6 2 12]rectfill 1 setgray{[18 -.5 2 1 24 -.5 2 1]rectfill}if{21 -.5 2 1 rectfill}if}def a neg rotate R 0 0 12 0 180 arc closepath fill B 0 0 12 180 0 arc closepath fill R -6 0 6 0 360 arc closepath fill B 6 0 6 0 360 arc closepath fill true true b 2 a mul rotate false true b 180 rotate true false b -2 a mul rotate false false b
showpage

Code non golfé:

5 5 scale                                     % over-all scale
36 24 translate                               % over-all shift
/R {.75 .05 .19 setrgbcolor} def              % prodecure for setting red color
/B {0 .20 .47 setrgbcolor} def                % procedure for setting blue color
/a 2 3 atan def                               % calculate angle = arctan(2/3) = 33.7°
/b {                                          % procedure for drawing bars
 0 setgray                                    %   black
 [18 -6 2 12 21 -6 2 12 24 -6 2 12] rectfill  %   draw 3 bars
 1 setgray                                    %   white
 {[18 -.5 2 1 24 -.5 2 1] rectfill} if        %   conditionally draw gap in inner/outer bars 
 {21 -.5 2 1 rectfill} if                     %   conditionally draw gap in middle bar 
} def
a neg rotate                                  % rotate -33.7°
R 0 0 12 0 180 arc closepath fill             % big red half circle
B 0 0 12 180 0 arc closepath fill             % big blue half circle
R -6 0 6 0 360 arc closepath fill             % small red circle
B  6 0 6 0 360 arc closepath fill             % small blue circle
true true b                                   % draw bars (with gap in all bars)
2 a mul rotate                                % rotate 67.4°
false true b                                  % draw bars (with gap in inner/outer bars)
180 rotate                                    % rotate 180°
true false b                                  % draw bars (with gap in middle bar)
-2 a mul rotate                               % rotate -67.4°
false false b                                 % draw bars (without gaps)
showpage

Résultat:

résultat


1

Python 2, 483 octets

from math import*
w,k,r,b="255 "*3,"0 "*3,"198 12 48 ","0 52 120 "
print "P3 600 400 255 "
a=atan2(2,3)
c,s=cos(a),sin(a)
T=lambda x,y:(c*x-s*y,s*x+c*y)
S=lambda x,y:150<x<216.6and x%25<16.6and y*y<2500
C=lambda x,y,p=50:(x-p)**2+y*y<2500
for y in range(-200,200):
 for x in range(-300,300):X,Y=T(x,y);W,Z=T(-x,y);print [[w,k][(S(abs(X),Y)and(Y*Y>16or(166.6<X<191.4or-200>X or 0>X>-166.6)))or(S(abs(W),Z)and(W>0 or abs(Z)>4))],[b,r][(Z<0 or C(W,Z))and not C(W,Z,-50)]][W*W+Z*Z<10000]

Améliorations possibles:

  • hardcode les constantes de sin, cos
  • PPM binaire
  • transformer en plan [3,2]
  • optimiser les déclarations booléennes

Sortie sous forme de texte PPM, utilisation:

python golf_korea.py > korea.ppm

entrez la description de l'image ici

version bêta non golfée

from math import*
w,k,r,b="255 255 255 ", "0 0 0 ", "255 0 0 ", "0 0 255 "
g="0 255 0 "
print "P3 600 400 255 "
a=atan2(2,3)
c,s=cos(a),sin(a)
trans=lambda x,y:(c*x-s*y,s*x+c*y)
stripe=lambda x:150<x<216.6 and x%25<16.6
small=lambda x,y,p=50:(x-p)**2+y*y<2500
for y in range(-200,200):
 for x in range(-300,300):
  X,Y=trans(x,y)
  W,Z=trans(-x,y)
  if stripe(abs(X)) and Y*Y<2500:
   if abs(Y)>4:  
    print k
   else:
    if X>0:
     if 166.6<X<191.4:
      print k
     else:
      print w
    else:
     if -200<X<-166.6:
      print w
     else:
      print k
  elif stripe(abs(W)) and Z*Z<2500 and(W>0 or abs(Z)>4):
   print k
  elif W*W+Z*Z<100*100:
   if (Z<0 or small(W,Z)) and not small(W,Z,-50):
    print r
   else:
    print b
  else:
   print w
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.