สันทนาการของ Piet Mondrian Composition


23

สวัสดีตอนบ่าย,

เป้าหมายของคุณคือในการสร้างไบต์ของซอร์สโค้ดอย่างน้อยที่สุดให้สร้างภาพเขียน 'Composition' ของ Piet Mondrian (เช่น Composition # 10 )

การพักผ่อนหย่อนใจสามารถใช้สีจริงหรือแทนที่ด้วยสีที่เหมาะสมจากจานสี 16 ค่าเริ่มต้นของ Windows

การพักผ่อนหย่อนใจของคุณสามารถแสดงผลใน PNG, BMP หรือ NetPBM ไม่ว่าจะเป็นไฟล์หรือไปที่ STDOUT หรือตรงไปที่หน้าจอ

นันทนาการของคุณต้องมีความละเอียด 512x512 หรือสูงกว่า

นันทนาการของคุณต้องไม่ใช้อินเทอร์เน็ต หากโปรแกรมของคุณต้องการไฟล์ข้อมูลขนาดของไฟล์นั้นจะถูกเพิ่มเข้าไปในขนาดแหล่งที่มาของคุณ

คะแนนของคุณจะเป็นขนาดของไฟล์ต้นฉบับในหน่วยไบต์

โปรดระบุสิ่งที่คุณกำลังวาดใหม่และระบุลิงก์ไปยังภาพต้นฉบับและรูปภาพของการพักผ่อนหย่อนใจของคุณ

โชคดี.


ขั้นตอนที่หนึ่ง: ค้นหาภาษาที่มีตัวเข้ารหัส PNG, BMP หรือ NetPBM ในตัว
John Dvorak

6
เกี่ยวข้อง: Piet
Griffin

4
มันเป็นภาษาที่ยากที่จะทำงานใน ... ทุกขณะนี้จากนั้นฉันพยายามที่จะทำ Quine แสดงผล NetPBM ... แต่ใช่ ฉันจะประทับใจมากถ้าใครสามารถสร้าง Piet Mondrian ใน Piet ได้!
lochok

2
เราสามารถแสดงผลตัวอักษรโดยใช้สีเทอร์มินัลและตัวบล็อกการวาดบล็อก (เช่น. ▃▃▌) หรือนี่เป็นการท้าทายที่ดีที่สุดหรือไม่?
Tobia

2
@lochok ฉันจะให้รางวัลสำหรับคำตอบ Piet ถ้าใครสนใจจริงจังในการลอง
Jerry Jeremiah

คำตอบ:


14

Tikz, 175 ไบต์

องค์ประกอบที่สามในขาวดำ 175 ไบต์

\documentclass[tikz]{standalone}\begin{document}\tikz{\def\b{;\draw[line width=}\def\a{)--(}\clip(1,1\a1,5\a5,5\a5,1)\b2mm](0,4\a6,4\a6,3\a4,3)\b1mm](4,0\a4,5);}\end{document}

ตรวจสอบใน Blogosphere

นี่อาจเป็นหนึ่งในผลงานที่เรียบง่ายที่สุดของ Mondrian และฉันประหลาดใจที่ยังไม่มีใครพบ อย่างไรก็ตามมันไม่น่าสนใจอย่างยิ่งดังนั้นฉันจึงได้รวมภาพเขียนอื่น ๆ ไว้ในคำตอบของฉัน

คำอธิบาย

มี wrapper เล็กน้อยที่เกี่ยวข้องกับคำตอบทุก tikz เสื้อคลุมคือ:

\documentclass[tikz]{standalone}\begin{document}\tikz{
}\end{document}

เมื่อคุณได้รับ wrapper ที่ผ่านมามี\defคำสั่งไม่กี่คำที่บันทึกไบต์ แต่น่าเสียดายที่ทำให้รหัสสับสน:

\def\b{;\draw[line width=}\def\a{)--(}

หากเราทำการทดแทนที่เหมาะสมทั้งหมดรหัสของเราจะออกมาเหมือน:

\clip(1,1)--(1,5)--(5,5)--(5,1);
\draw[line width=2mm](0,4)--(6,4)--(6,3)--(4,3);
\draw[line width=1mm](4,0)--(4,5);

บิตแรกคือ a \clipและสำคัญมาก แต่เราจะข้ามผ่านไปในขณะนี้

ตอนนี้เราวาดบรรทัดแรกบนผืนผ้าใบที่ว่างเปล่าบรรทัดนี้ค่อนข้างหนาดังนั้นเราจึงใช้[line width=2mm]การตั้งค่าความหนาเป็น2mm:

\draw[line width=2mm](0,4)--(6,4)--(6,3)--(4,3);

สิ่งนี้เชื่อมต่อสองโหนดและสร้างรูปร่างนี้:

ต่อไปเรา\drawเป็นโรคหลอดเลือดสมองที่สองอย่างไรก็ตามโรคหลอดเลือดสมองนี้เป็นน้ำมันทินเนอร์ดังนั้นเราจึงต้องกำหนดความหนาของเส้นเป็น1mm:

\draw[line width=1mm](4,0)--(4,5);

ตอนนี้ภาพวาดของเราดูเหมือน:

นี้อยู่ใกล้กับต้นฉบับ แต่ไม่มากดังนั้นที่นี่เป็นที่ที่เข้า\clipมาเล่น เราใช้\clipเพื่อลบบรรทัดพิเศษทั้งหมดออกจากผืนผ้าใบของเราและตั้งค่าผืนผ้าใบให้มีขนาดที่ถูกต้อง เมื่อผ้าใบปรับขนาดเราจะได้ภาพ:

องค์ประกอบที่สามในขาวดำ


องค์ประกอบด้วยแพทช์สีเหลือง 214 ไบต์

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(7,7);\draw(0,8)rectangle(4,3.5)rectangle(6.5,1.2)rectangle(4,0);\draw[fill=yellow](6.5,3.5)rectangle(8,2.5);}\end{document}

ประเมินมันในไซเบอร์สเปซ

คำอธิบายที่จะมา


องค์ประกอบที่สองในสีน้ำเงินและสีเหลือง 225 ไบต์

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(7,10);\draw(8,9)rectangle(3,6)rectangle(0,0);\draw[fill=yellow](0,0)rectangle(3,2);\draw[fill=blue](0,11)rectangle(3,9);}\end{document}

ประเมินมันผ่าน Webbernetz!

คำอธิบายที่จะมา


องค์ประกอบ B (หมายเลข 2) ในสีแดง 232 ไบต์

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(10,13);\draw[line width=1mm](1.2,5)--(1.2,9);\draw[fill=red](0,14)rectangle(5,9);\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);}\end{document}

พยายามภายในอินเทอร์เน็ต!

คำอธิบาย

ก่อนอื่นนี่คือรหัสที่แทรกตัวแบ่งบรรทัดเพื่อให้อ่านง่ายขึ้น:

\documentclass[tikz]{standalone}
\begin{document}
\tikz[line width=2mm]{
\clip(1,1)rectangle(10,13);
\draw[line width=1mm](1.2,5)--(1.2,9);
\draw[fill=red](0,14)rectangle(5,9);
\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);
}
\end{document}

คำสั่งแรกที่น่าสนใจคือ

\draw[fill=red](0,14)rectangle(5,9);

นี่วาดสี่เหลี่ยมสีแดงที่มีโครงร่างสีดำ สำหรับมุมซ้ายบนของภาพเขียน

จากนั้นเราวาดอีกสองสี่เหลี่ยมด้วยการตกแต่งภายในสีขาวและโครงร่างสีดำเพื่อสร้างรูปแบบกริดบนภาพวาด

\draw(0,9)rectangle(11,5)(7,0)rectangle(5,14);

จากนั้นเราวาดเป็นเส้นบาง ๆ

\draw[line width=1mm](1.2,5)--(1.2,9);

และครอบตัดรูปภาพให้มีขนาดที่เหมาะสม

\clip(1,1)rectangle(10,13);


องค์ประกอบที่สองในสีแดงสีน้ำเงินและสีเหลือง 251 ไบต์

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=1mm]{\clip(1,1)rectangle(9,9);\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);\draw[fill=red](3,3)rectangle(10,10);\draw[fill=blue](0,0)rectangle(3,3);}\end{document}

ทดสอบบนเวิลด์ไวด์เว็บ!

คำอธิบาย

ก่อนอื่นฉันจะแทรกตัวแบ่งบรรทัดเพื่อให้โค้ดอ่านได้

\documentclass[tikz]{standalone}
\begin{document}
\tikz[line width=1mm]{
\clip(1,1)rectangle(9,9);
\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);
\draw[fill=red](3,3)rectangle(10,10);
\draw[fill=blue](0,0)rectangle(3,3);
}
\end{document}

บรรทัดแรกของความสำคัญคือ:

\draw[fill=yellow](8.5,6)--(0,6)--(8.5,6)--(8.5,2)rectangle(10,0);

สิ่งนี้วาดรูปร่างดังต่อไปนี้:

รูปร่างแปลก ๆ นี้เป็นรูปสี่เหลี่ยมผืนผ้าสีเหลืองที่มุมขวาล่างและสองบรรทัดที่ไม่มีขอบของรูปสี่เหลี่ยมผืนผ้าสี ต่อไปเราจะแทรกสี่เหลี่ยมจัตุรัสสีแดงและปกปิดเส้นพิเศษที่ทำขึ้นด้วยรูปร่างสุดท้าย:

\draw[fill=red](3,3)rectangle(10,10);

สิ่งนี้ออกมาเหมือน:

ตอนนี้เราแทรกสี่เหลี่ยมสีน้ำเงินของเรา:

\draw[fill=blue](0,0)rectangle(3,3);

ตอนนี้สิ่งที่เหลือคือตัดส่วนที่ไม่จำเป็นทั้งหมดของภาพออกโดยใช้ a \clip

\clip(1,1)rectangle(10,10);

องค์ประกอบที่สองในสีแดงสีน้ำเงินและสีเหลือง


องค์ประกอบที่สอง , 308 ไบต์

\documentclass[tikz]{standalone}\begin{document}\tikz[line width=2mm]{\clip(1,1)rectangle(12.6,13);\draw(0,0)rectangle(10,4)rectangle(2,12)--(0,12);\draw[fill=red](10,1.6)rectangle(14,0);\draw[fill=yellow](6,12)rectangle(10,14);\draw[fill=blue](0,4)rectangle(2,8);\fill(10,10)rectangle(14,14);}\end{document}

ลองดูที่Information-Super-Highway

คำอธิบายที่จะมา


12

Mathematica 202 287 ไบต์

แค่เล่น ๆ! 330 ไบต์: Mondrian กับ "Boogie Woogie" ในหัวข้อ

Column[{"Boogie Woogie", Grid[{{"",i["",b->Red],\[SpanFromLeft]},{"",\[SpanFromAbove],\[SpanFromBoth]},{i["",b->Blue],"",""},{\[SpanFromAbove],\[SpanFromAbove],i["",b -> Yellow]}},Dividers->{{2->t@5,3->t@6},{2->t@9,3->t@7,4->t@6}},ItemSize->{{1->3,2->9,3->1},{1->6,2->6,3->2,4->2}}]},Alignment->Center]

ป้อนคำอธิบายรูปภาพที่นี่


การส่งตามจริง [287 ไบต์]

\[SpanFromLeft]และนิพจน์ที่คล้ายกันใช้เวลาประมาณ 85 ไบต์ ในวิชาคณิตศาสตร์การแสดงออกแต่ละอย่างนั้นมีสัญลักษณ์ตัวเดียว

t=Thickness;b=Background;i=Item;
Grid[{{"",i["",b->Red], \[SpanFromLeft]},{"",\[SpanFromAbove],\[SpanFromBoth]},{i["",b->Blue],"",""},{\[SpanFromAbove],\[SpanFromAbove],i[ "",b->Yellow]}},
Dividers->{{2->t@5, 3->t@6},{2->t@9,3->t@7,4->t@6}},ItemSize->{{1->3, 2->9, 3->1},
{1->6, 2->6, 3->2, 4->2}}] 

เคียงบ่าเคียงไหล่

ด้านซ้าย ภาพถ่ายของ Piet Mondrian, องค์ประกอบสีแดงสีน้ำเงินเหลืองที่อยู่ด้านขวา


3
พยายามได้ดี. คุณไม่ได้รับเงินรางวัลอย่างง่ายดาย
ข้าวสาลีตัวช่วยสร้าง

11

Ruby, 112 (111) ตัวอักษร

Piet Mondrian - องค์ประกอบใน B (No.II) กับสีแดง

b="0 "*9
w="2 "*9
puts"P3 609 771 2",["1 0 0 "*267,w*8+b*2+w*79,w*89].map{|x|(x+b*3+w*42+b*3+w*66)*249}*(b*2436)

การผลิตของฉันทางด้านซ้ายการอ้างอิงที่เพิ่มสเกลทางด้านขวา

ป้อนคำอธิบายรูปภาพที่นี่

สีสามารถปรับแต่งเล็กน้อย - ถึงความแม่นยำ 1/9 - โดยไม่สูญเสียคะแนนโดยการปรับค่าสูงสุดใน PPM ฉันเลือกวิธี "สี Win16 ที่เหมาะสม" 8/9 สีขาวน่าจะใกล้เคียงกับสีดั้งเดิมของผืนผ้าใบ แต่ 9/9 นั้นใกล้เคียงกับความตั้งใจของผู้เขียน

สามารถบันทึกหนึ่งอักขระถ้าเราแทนที่"1 0 0 "ด้วย(w+b+b)(# F00 สีแดง) ฉันเชื่อว่านับว่า "ใกล้พอ"

รุ่นไฟล์ ouptut (ไม่เล่นกอล์ฟ)

File.open "tmp.ppm", ?w do |f|
    b="0 "
    w="2 "
    s=b*27+w*378+b*27+w*594
    f.puts"P3 609 771 2",["1 0 0 "*267,w*72+b*18+w*711,w*801].map{|x|(x+s)*249}*(b*21924)
end

วิธีง่ายๆ: "0 "->b
Howard

@ ฮาวาร์ดด่า พลาดอันนี้ในขณะที่การลดขนาด ขอบคุณ
John Dvorak

และอื่น ๆ อีกมากมายถ้าคุณเปลี่ยนw="2 "ไปw="2 "*9และbยัง
Howard

อืมม ... ฉันเข้าใจแล้ว (มันจะเกิดขึ้นตลอดไป)
Doorknob

@Doorknob บันทึกว่าเป็นppmไฟล์และเปิดในโปรแกรมแก้ไขภาพ
จอห์น Dvorak

9

SmileBASIC, 2774 1892 ไบต์

Broadway Boogie Woogie

GCLS-920851D$="w$BȜąr:BȂąr7?Ƣǘy1SƑǘb<?ŵǘw-/ƶvyFMƮeb<<ŶIr:,ėǭy:Sėǘw-LŒƄw7;ėƎrkLćƄrBMĜey26ğ¸bKBē²y,Bć²w<Dđïw+DüïyDÒïw--çvyU8Òpw.1±syBM¨eb;<Iy28¥żrJNůbwN{ůr?@Ǣb3>Sǭw.Fb¤w24D­rMF5¤w,7Nnr[75ny1X=e
FOR I=1TO 36G A(),A(),A(),A(),A()NEXT
D$=" w*+r6,r1+b<*w1+b/+b++r(+w*+w,Br )b+*b()w0,w=+b,,r5+b1+r ,w24-Ȃ  w  w#.r-#-Ǥ  w*+r4,b3+r6*w2+b,-r-,b++r*+b**r(*b(*r*+b<-w@+b -w ,r4+b1+b%-w,5-ǔ  w +r)+w?#-ƹǘ w +r%-b,#-ƭ +w *r +w/,b2,r1-b;-w7+b*.w5+r1+r +-ƒ> w +r'-b*#-ž *r+)w +r?+b:+b1-b2+w:+w*+w3-b4-r4-b6,w2+r--w3+b1+r )w52-ş  w*+r )w ,b>+r7+b :w -b,+r:+w*+w7,r 6w ,r7-r0.w/+bM+b1+b ,w24-ľ *w +r)+r *w5+r9,b7.w++w ,r.+w*+w6*b Dw *r06w -r5+b *w8+w +r1+b ,w *r(7-ü  w*+w )b +w*+r*+bD-rC/r7+b*+r5+bD-r,.b/.w.+b *w8+r +w1+b'+r,4-Ò  w*+b )w+*r+*w +b )w<0wX-w +r*+b /wd-w/.b/*w+-r 7w)+bC+r,3-p *w+)w +b*+w*+b )w@2wU*w+*w++wx-wQ-w.,bT+b,.-* +w +r++r5,w6+w %|üŭ w3+r1*w(+r0+r7*b (w )r3*w+*w,+r-*w +b5+r )w6+w.,r1+w *b*-w +b *w(,r()w ,r+*r :| ȋ+w7*b 1w4)w +r %|şǷ+r,*w)+w.*w*)w ?r -w+'|pǷ)w,)w +b*#| Ƿ+r/+b()w ?r -w+*w),r(*w *b +w *r +| Ǣ w+(w +b1*w(+r0+b7)b *w *r2)w +b *w,+r7+b5+r )w6+b/+b )w1,r7+b.*b9*w +b*8| Ǎ w3+w )b0*w +r4)w +r/+w**w**b +w6+w )r1*b3+w /|üň+b-*w1+w%*r(-w +r *w.+w')r (w5*| ň w3+w )r0*w +b )r5*b/+w3+w *r +w *r,+w9+r3+w-*b (w +r,+b2,w /r3+b0)r *b+-w+*r :| ij w3+b )w)*r 'w +b (w+)w *r1+b0*w.+r6+b )w0)w,)w +b4+w +b0)w'*r1*b))w+*b.*b1(w+*r ;| 3w +b )w*)b 'w +b.)r 'w )b0+r <b,+b6+b.,b=+r 3w ,b +w *b 6w *r);b)+b7+b 1w=9| Z w3+r (w.-w +b1+w +r0+r )w +r (w,+r6+b *w),r8+b?+bJ*w:)w+)w.*r1)w+*r 7| >+r )w6+r2*b1+r6*b1*w +b*(| ,
FOR Q=1TO 27S=A()T=A()R=A()L=A()FOR I=1TO L
R A(),89R A(),A()NEXT
NEXT
DEF A()RETURN-32+ASC(POP(D$))END
DEF R L,C
IF L THEN IF R-13THEN G C,L,11,T,S:T=T+L ELSE G C,11,L,T,S:S=S+L
END
DEF G C,H,W,Y,X
GFILL X,Y,X+W-1,Y+H-1,-1716698*(C>88)-2302505*(C==87)-6080725*(C==82)-14597488*(C<67)END

ภาพหน้าจอ

แต่ละ "เส้น" ในภาพจะถูกเก็บไว้ในรูปแบบนี้:

x,y,direction,numberOfSegments,
yellowLength,nextColor,colorLength,
yellowLength,nextColor,colorLength,...

ตัวเลขทั้งหมดจะถูกเก็บไว้เป็นCHR$(number+32)สีจะถูกเก็บไว้เป็นตัวละครตัวหนึ่ง; w, y, rหรือb, และทิศทางถูกเก็บไว้เป็น|หรือ-

สี่เหลี่ยมพิเศษถูกเก็บไว้เป็น:

x,y,width,height,color,
x,y,width,height,color,...

ในทางเดียวกัน.


ดี! ฉันกำลังคิดเกี่ยวกับการทำ QBasic แต่ไม่มีโหมดหน้าจอ 512x512
DLosc

ฉันโชคดีมาก หน้ากราฟิกของ SmileBASIC มีขนาด 512x512 พิกเซล
12Me21

7

SVG - 455 480- Mondrian Composition II เป็นสีแดงน้ำเงินและเหลือง

หากคุณสามารถฝัง Javascript ลงใน SVG และทำให้มันเป็นแบบไดนามิกมันเป็นภาษาการเขียนโปรแกรม ดังนั้นนี้เป็นโปรแกรม ปรากฎว่ามีxหรือไม่มีycoord หายไปใน SVG ค่าเริ่มต้นที่ 0 ยังredสั้นกว่า#f00!

<?xml version="1.0" encoding="utf-8"?><svg xmlns="http://www.w3.org/2000/svg"><rect x="145" fill="red" width="455" height="440"/><rect y="432" fill="#00F" width="150" height="168"/><rect x="550" y="517" fill="#FF0" width="50" height="83"/><rect x="140" width="16" height="600"/><rect y="430" width="600" height="16"/><rect y="180" width="140" height="25"/><rect x="550" y="430" width="15" height="170"/><rect x="550" y="515" width="50" height="16"/></svg>

พริตตี้พิมพ์:

<?xml version="1.0" encoding="utf-8"?>
<svg xmlns="http://www.w3.org/2000/svg">
  <rect x="145" fill="red" width="455" height="440"/>
  <rect y="432" fill="#00F" width="150" height="168"/>
  <rect x="550" y="517" fill="#FF0" width="50" height="83"/>
  <rect x="140" width="16" height="600"/>
  <rect y="430" width="600" height="16"/>
  <rect y="180" width="140" height="25"/>
  <rect x="550" y="430" width="15" height="170"/>
  <rect x="550" y="515" width="50" height="16"/>
</svg>

เดี๋ยวก่อนฉันคิดว่าองค์ประกอบ B (No.II) กับ Red 1935คือ # 2
John Dvorak

4
@JanDvorak ฉันไม่รู้ฉันแค่มองเขาบน Wikipedia จริง ๆ แล้ว Piet เป็นจิตรกรที่ขี้เกียจ พวกเขาทั้งหมดดูเหมือนกัน

ฉันคิดว่าคุณสามารถหลีกเลี่ยงอัญประกาศคู่ใหญ่และยังคงใช้งานได้ในเบราว์เซอร์ส่วนใหญ่ ไม่แน่ใจเกี่ยวกับการปฏิบัติตามแม้ว่า
John Dvorak

@ LegoStormtroopr Lazy? มันค่อนข้างรวยมาจากคนที่แฮงค์เอาท์บนเว็บไซต์เพื่อเขียนโปรแกรมสั้น ๆ
บูธตาม

1
@boothby Touche ฉันจะเถียงว่าฉันได้เรียนรู้อะไรมากมายจากการเล่นโค๊ดกอล์ฟเนื่องจากวิธีไฮเปอร์มินัลลิสต์ แต่ ... สิ่งเดียวกันอาจเป็นที่ถกเถียงกันเกี่ยวกับงานของ Piet ด้วย

3

SmileBASIC ขนาด 67 ไบต์

GCLS-1GFILL 353,0,367,#R,0GFILL.,121,#R,156,0GFILL 367,266,#R,293,0

ฉันเลือกง่าย ๆ : Composition III ในขาวดำ

โชคดีที่หน้ากราฟิกของ SB นั้นมีขนาด 512x512 พิกเซล แต่มันไม่พอดีกับหน้าจอ 400x240 ดังนั้นฉันจึงไม่สามารถจับภาพหน้าจอได้อย่างง่ายดาย

อธิบาย:

GCLS -1 'fill screen with &HFFFFFFFF (white)
GFILL 353,0,367,511,0 'draw vertical line in &H00000000 (black)
GFILL 0,121,#R,156,0 'draw horizontal line
GFILL 367,266,#R,293,0 'draw small horizontal line

3

กำลังประมวลผล15,447 15,441 15,439 ไบต์

String i="";PImage x=loadImage(i);void draw(){image(x);}

กำลังดุร้ายและฉันไม่ได้หาวิธีลบฟังก์ชั่นการวาด

มันผิดพลาดในเครื่องมือประมวลผลหลักฉันคิดว่าเพราะมันใหญ่เกินไปของ 64 คุณสามารถทดสอบได้ที่นี่

JS fiddles ทำการครอบตัดได้ถึง 100 * 100px base64 ของฉันใช้งานได้ แต่สภาพแวดล้อมออนไลน์ไม่ได้ :(


คุณสามารถเล่นกอล์ฟนี้โดยใช้PImage x=loadImage(i);แทน
Kritixi Lithos

1
คำถามต้องการความละเอียด 512x512 หรือสูงกว่า แต่ผืนผ้าใบในซอของคุณมีเพียง 100x100 นี่เป็นเรื่องแปลกสำหรับ JSFiddle หรือไม่?
เดนนิส

@Dennis ไม่เพียง แต่ขนาดผ้าใบเท่านั้น ภาพถูกตัดทั้งด้านขวาและด้านล่างทำให้ผลลัพธ์ไม่ถูกต้อง
mbomb007

@ เดนนิสใช่มันเป็น ตั้งค่าด้วยตนเองเป็น 512 * 512 px ยังคงครอบตัดเป็นขนาดเดียวกัน มันเป็นแค่ซอฟเดิ้ลของเจและ b64 ที่ฉันใช้มีค่ามากกว่า 512
Rɪᴋᴇʀ

data:;base64ทำงานได้เป็นอย่างดี
Kritixi Lithos

2

Love2D, 4956 + 395 + 1 = 5351 ไบต์

f=io.open("d","rb")s=f:read("*a"):gsub("(.)(.)",function(a,b)return a:rep(b:byte())end)o=love.image.newImageData(512,512)c={{244,243,248},{173,24,0},{250,209,5},{30,64,164}}o:mapPixel(function(x,y)i=math.floor((x+math.floor(y/4)*512)/4)O=3-i%4 n=s:sub(math.floor(i/4)+1,math.floor(i/4)+1)if n and#n>0 then b=math.floor(n:byte()/(4^O))%4 else b=0 end return unpack(c[b+1])end)o:encode("png","o") 

ไฟล์ข้อมูลถูกเก็บไว้ที่นี่

เอาท์พุท:

เอาท์พุต

เดิม:

เป็นต้นฉบับ

คำอธิบาย

f = io.open("d","rb")                                                   -- Open the image in raw format.
s = f:read("*a"):gsub("(.)(.)",function(a,b)return a:rep(b:byte())end)  -- And read it's contents. 
o=love.image.newImageData(512,512)                                      -- Make the output image
c = {{244,243,248},{173,24,0},{250,209,5},{30,64,164}}                  -- Build the Pallet
o:mapPixel(function(x,y)                                                -- Fill the image, based on a function
    i = (x+y*512)                                   -- The position this pixel exists on the string, 0 indexed.
    O = 3-i%4                                       -- The offset. The byte stores 4 pixels, so this is the id among a group of 4.
    n = s:sub(math.floor(i/4)+1,math.floor(i/4)+1)  -- And this gets the byte itself.
    if n and #n > 0 then                            -- Sometimes this is null and I don't like it.
        b = math.floor(n:byte()/(4^O))%4            -- /4^offset % 4 gives us the value of the index on the pallet.
    else
        b = 0                                       -- Fallback plan.
    end
    return unpack(c[b+1])                           -- Set the pixel to the colour required.
end)
o:encode("png","o") -- Store it in Appdata as "o", which is a png file.

เครื่องเข้ารหัส

นี่เป็นเพียงสคริปต์ที่ฉันใช้ในการเข้ารหัสภาพ Gif ใช้การบีบอัดได้มากกว่า แต่ฉันไม่ได้ท้าทายให้แสดง gif

img = love.image.newImageData("mondrian.jpg")
-- white    0
-- blue     3
-- yellow   2
-- red      1

cols = {{244,243,248},{173,24,0},{250,209,5},{30,64,164}}

local s = ""
for y = 0, 511 do
    for x = 0, 511 do
        local r,g,b = img:getPixel(x,y)
        local n = 0
        local D = math.huge
        for k,v in pairs(cols) do
            local d = (v[1]-r)^2 + (v[2]-g)^2 + (v[3]-b)^2
            if d < D then
                n = k-1
                D = d
            end
        end
        s = s .. n
    end
end
-- Convert base 4 to base 256
-- How many digits do we need- Every 4 digits
encd = ""
for str in s:gmatch"...." do
    local n = str:sub(1,1) * 4^3 +
              str:sub(2,2) * 4^2 +
              str:sub(3,3) * 4^1 +
              str:sub(4,4) * 4^0
    encd = encd .. string.char(n)
end

f = io.open("stored.dat","wb")

smlr = ""
lst = ""
c = 0
for s in encd:gmatch"." do
    if s == lst then
        c = c + 1
        while c > 255 do
            smlr = smlr .. lst .. string.char(255)
            c = c - 255
        end
    else
        if c > 0 then
            smlr = smlr .. lst .. string.char(c)
        end
        lst = s
        c = 1
    end
end

f:write(smlr)

ส่วนใหญ่แข่งขันกันเพื่อรับรางวัล มีวิธีที่ดีกว่าในการทำเช่นนี้ แต่ฉันคิดว่ามันน่าสนใจที่จะลองใช้แท่นวางสินค้าแบบง่าย ๆ และการถอดรหัสแบบรันไทม์

แก้ไข: ภาพอินพุตง่ายขึ้นมีความแม่นยำน้อยกว่าเล็กน้อย แต่มีขนาดน้อยกว่าไบต์


2
เหตุใดส่วนต่าง ๆ ของผลลัพธ์ของคุณดูเหมือนเป็นชิ้นส่วนปริศนา นั่นคือสิ่งที่คุณหมายถึงโดย "ความแม่นยำน้อยกว่าเล็กน้อย แต่มีขนาดน้อยกว่าไบต์" หรือไม่ สำหรับฉันแล้วดูเหมือนว่าช่องว่างที่เกิดขึ้นในแถบสีทำให้สิ่งนี้ไม่ใช่กิจกรรมสันทนาการที่ถูกต้อง
DLosc
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.